forked from greenpau/caddy-auth-portal
/
eval.go
124 lines (115 loc) · 3.38 KB
/
eval.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
// Copyright 2020 Paul Greenberg greenpau@outlook.com
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package tests
import (
"fmt"
"github.com/google/go-cmp/cmp"
"io/ioutil"
"os"
"regexp"
"runtime"
"testing"
)
var (
pr = regexp.MustCompile(".*(github.com/silvajp2/caddy-auth-portal/.*)$")
)
// EvalErr evaluates whether there is an error. If there is, was it the
// expected error.
func EvalErr(t *testing.T, err error, data interface{}, shouldErr bool, expErr error) bool {
if !shouldErr {
if err == nil {
return false
}
t.Fatalf("expected success, but got error: %s", err)
}
if err == nil {
t.Fatalf("expected error '%v', but got success: %v", expErr, data)
}
if expErr == nil {
expErr = fmt.Errorf("")
}
if diff := cmp.Diff(expErr.Error(), err.Error()); diff != "" {
t.Fatalf("unexpected error (-want +got):\n%s", diff)
}
// t.Logf("received expected error: %v", err)
return true
}
// WriteLog writes logs from tests.
func WriteLog(t *testing.T, msgs []string) {
if len(msgs) == 0 {
return
}
for _, msg := range msgs {
t.Logf("%s", msg)
}
}
// EvalErrWithLog evaluates the error.
func EvalErrWithLog(t *testing.T, err error, data interface{}, shouldErr bool, expErr error, msgs []string) bool {
_, fileName, lineNum, ok := runtime.Caller(1)
if ok {
fileName = pr.ReplaceAllString(fileName, "$1")
msgs = append([]string{fmt.Sprintf("source: %s:%d", fileName, lineNum)}, msgs...)
}
if !shouldErr {
if err == nil {
return false
}
WriteLog(t, msgs)
t.Fatalf("expected success, but got error: %s", err)
}
if err == nil {
WriteLog(t, msgs)
t.Fatalf("expected error, but got success: %v", data)
}
if expErr == nil {
expErr = fmt.Errorf("")
}
if diff := cmp.Diff(expErr.Error(), err.Error()); diff != "" {
WriteLog(t, msgs)
t.Fatalf("unexpected error (-want +got):\n%s", diff)
}
// t.Logf("received expected error: %v", err)
return true
}
// EvalObjects compares two objects.
func EvalObjects(t *testing.T, name string, want, got interface{}) {
if diff := cmp.Diff(want, got); diff != "" {
t.Fatalf("%s mismatch (-want +got):\n%s", name, diff)
}
}
// EvalObjectsWithLog compares two objects and logs extra output when
// detects an error
func EvalObjectsWithLog(t *testing.T, name string, want, got interface{}, msgs []string) {
_, fileName, lineNum, ok := runtime.Caller(1)
if ok {
fileName = pr.ReplaceAllString(fileName, "$1")
msgs = append([]string{fmt.Sprintf("source: %s:%d", fileName, lineNum)}, msgs...)
}
if diff := cmp.Diff(want, got); diff != "" {
WriteLog(t, msgs)
t.Fatalf("%s mismatch (-want +got):\n%s", name, diff)
}
}
// TempDir creates temporary directory.
func TempDir(s string) (string, error) {
rootDir := os.TempDir() + "/testdata/caddy-auth-portal/" + s
if err := os.MkdirAll(rootDir, 0700); err != nil {
return "", err
}
tmpDir, err := ioutil.TempDir(rootDir, "")
if err != nil {
return "", err
}
return tmpDir, nil
}