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
|
package svc // import "github.com/getwtxt/getwtxt/svc"
import (
"fmt"
"net/http"
"net/http/httptest"
"net/url"
"strings"
"testing"
"github.com/getwtxt/registry"
)
var apiPostUserCases = []struct {
name string
nick string
uri string
wantErr bool
}{
{
name: "Known Good User",
nick: "gbmor",
uri: "https://gbmor.dev/twtxt.txt",
wantErr: false,
},
{
name: "Missing URI",
nick: "missinguri",
uri: "",
wantErr: true,
},
{
name: "Missing Nickname",
nick: "",
uri: "https://example.com/twtxt.txt",
wantErr: true,
},
{
name: "Missing URI and Nickname",
nick: "",
uri: "",
wantErr: true,
},
}
func Test_apiPostUser(t *testing.T) {
initTestConf()
portnum := fmt.Sprintf(":%v", confObj.Port)
twtxtCache = registry.NewIndex()
for _, tt := range apiPostUserCases {
t.Run(tt.name, func(t *testing.T) {
params := url.Values{}
params.Set("url", tt.uri)
params.Set("nickname", tt.nick)
req, err := http.NewRequest("POST", "https://localhost"+portnum+"/api/plain/users", strings.NewReader(params.Encode()))
if err != nil {
t.Errorf("%v\n", err)
}
req.Header.Add("Content-Type", "application/x-www-form-urlencoded")
rr := httptest.NewRecorder()
apiEndpointPOSTHandler(rr, req)
if !tt.wantErr {
if rr.Code != http.StatusOK {
t.Errorf("Received unexpected non-200 response: %v\n", rr.Code)
}
} else {
if rr.Code != http.StatusBadRequest {
t.Errorf("Expected 400 Bad Request, but received: %v\n", rr.Code)
}
}
})
}
}
|