acme-dns/api_test.go

179 lines
4.9 KiB
Go
Raw Normal View History

2016-11-24 05:31:52 +07:00
package main
import (
"errors"
2016-11-24 05:31:52 +07:00
"github.com/gavv/httpexpect"
"github.com/kataras/iris"
"github.com/kataras/iris/httptest"
"gopkg.in/DATA-DOG/go-sqlmock.v1"
2016-11-24 05:31:52 +07:00
"testing"
)
2016-11-28 00:41:54 +07:00
func setupIris(t *testing.T, debug bool, noauth bool) *httpexpect.Expect {
2016-11-24 05:31:52 +07:00
iris.ResetDefault()
2016-11-28 00:46:50 +07:00
var dbcfg = dbsettings{
Engine: "sqlite3",
Connection: ":memory:"}
var httpapicfg = httpapi{
Domain: "",
Port: "8080",
TLS: "none",
CorsOrigins: []string{"*"},
}
var dnscfg = DNSConfig{
API: httpapicfg,
Database: dbcfg,
}
DNSConf = dnscfg
2016-11-24 05:31:52 +07:00
var ForceAuth = authMiddleware{}
iris.Get("/register", webRegisterGet)
iris.Post("/register", webRegisterPost)
if noauth {
iris.Post("/update", webUpdatePost)
} else {
iris.Post("/update", ForceAuth.Serve, webUpdatePost)
}
2016-11-24 05:31:52 +07:00
httptestcfg := httptest.DefaultConfiguration()
httptestcfg.Debug = debug
return httptest.New(iris.Default, t, httptestcfg)
}
func TestApiRegister(t *testing.T) {
2016-11-28 00:41:54 +07:00
e := setupIris(t, false, false)
2016-11-24 05:31:52 +07:00
e.GET("/register").Expect().
Status(iris.StatusCreated).
JSON().Object().
ContainsKey("fulldomain").
ContainsKey("subdomain").
ContainsKey("username").
ContainsKey("password").
NotContainsKey("error")
e.POST("/register").Expect().
Status(iris.StatusCreated).
JSON().Object().
ContainsKey("fulldomain").
ContainsKey("subdomain").
ContainsKey("username").
ContainsKey("password").
NotContainsKey("error")
}
func TestApiRegisterWithMockDB(t *testing.T) {
2016-11-28 00:41:54 +07:00
e := setupIris(t, false, false)
2016-11-28 04:21:46 +07:00
oldDb := DB.GetBackend()
db, mock, _ := sqlmock.New()
2016-11-28 04:21:46 +07:00
DB.SetBackend(db)
2016-11-28 00:41:54 +07:00
defer db.Close()
mock.ExpectBegin()
mock.ExpectPrepare("INSERT INTO records").WillReturnError(errors.New("error"))
e.GET("/register").Expect().
Status(iris.StatusInternalServerError).
JSON().Object().
ContainsKey("error")
2016-11-28 04:21:46 +07:00
DB.SetBackend(oldDb)
}
2016-11-24 05:31:52 +07:00
func TestApiUpdateWithoutCredentials(t *testing.T) {
2016-11-28 00:41:54 +07:00
e := setupIris(t, false, false)
2016-11-24 05:31:52 +07:00
e.POST("/update").Expect().
Status(iris.StatusUnauthorized).
JSON().Object().
ContainsKey("error").
NotContainsKey("txt")
}
func TestApiUpdateWithCredentials(t *testing.T) {
validTxtData := "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
updateJSON := map[string]interface{}{
"subdomain": "",
"txt": ""}
2016-11-28 00:41:54 +07:00
e := setupIris(t, false, false)
2016-11-24 05:31:52 +07:00
newUser, err := DB.Register()
if err != nil {
t.Errorf("Could not create new user, got error [%v]", err)
}
// Valid data
updateJSON["subdomain"] = newUser.Subdomain
updateJSON["txt"] = validTxtData
e.POST("/update").
WithJSON(updateJSON).
WithHeader("X-Api-User", newUser.Username.String()).
WithHeader("X-Api-Key", newUser.Password).
Expect().
Status(iris.StatusOK).
JSON().Object().
ContainsKey("txt").
NotContainsKey("error").
ValueEqual("txt", validTxtData)
}
func TestApiUpdateWithCredentialsMockDB(t *testing.T) {
validTxtData := "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
updateJSON := map[string]interface{}{
"subdomain": "",
"txt": ""}
// Valid data
updateJSON["subdomain"] = "a097455b-52cc-4569-90c8-7a4b97c6eba8"
updateJSON["txt"] = validTxtData
2016-11-24 05:31:52 +07:00
2016-11-28 00:41:54 +07:00
e := setupIris(t, false, true)
2016-11-28 04:21:46 +07:00
oldDb := DB.GetBackend()
db, mock, _ := sqlmock.New()
2016-11-28 04:21:46 +07:00
DB.SetBackend(db)
2016-11-28 00:41:54 +07:00
defer db.Close()
mock.ExpectBegin()
mock.ExpectPrepare("UPDATE records").WillReturnError(errors.New("error"))
e.POST("/update").
WithJSON(updateJSON).
Expect().
Status(iris.StatusInternalServerError).
JSON().Object().
ContainsKey("error")
2016-11-28 04:21:46 +07:00
DB.SetBackend(oldDb)
2016-11-24 05:31:52 +07:00
}
func TestApiManyUpdateWithCredentials(t *testing.T) {
// TODO: transfer to using httpexpect builder
2016-11-28 00:41:54 +07:00
// If test fails and more debug info is needed, use setupIris(t, true, false)
2016-11-24 05:31:52 +07:00
validTxtData := "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
updateJSON := map[string]interface{}{
"subdomain": "",
"txt": ""}
2016-11-28 00:41:54 +07:00
e := setupIris(t, false, false)
2016-11-24 05:31:52 +07:00
newUser, err := DB.Register()
if err != nil {
t.Errorf("Could not create new user, got error [%v]", err)
}
for _, test := range []struct {
user string
pass string
subdomain string
txt interface{}
2016-11-24 05:31:52 +07:00
status int
}{
{"non-uuid-user", "tooshortpass", "non-uuid-subdomain", validTxtData, 401},
{"a097455b-52cc-4569-90c8-7a4b97c6eba8", "tooshortpass", "bb97455b-52cc-4569-90c8-7a4b97c6eba8", validTxtData, 401},
{"a097455b-52cc-4569-90c8-7a4b97c6eba8", "LongEnoughPassButNoUserExists___________", "bb97455b-52cc-4569-90c8-7a4b97c6eba8", validTxtData, 401},
{newUser.Username.String(), newUser.Password, "a097455b-52cc-4569-90c8-7a4b97c6eba8", validTxtData, 401},
{newUser.Username.String(), newUser.Password, newUser.Subdomain, "tooshortfortxt", 400},
{newUser.Username.String(), newUser.Password, newUser.Subdomain, 1234567890, 400},
2016-11-24 05:31:52 +07:00
{newUser.Username.String(), newUser.Password, newUser.Subdomain, validTxtData, 200},
} {
updateJSON = map[string]interface{}{
"subdomain": test.subdomain,
"txt": test.txt}
e.POST("/update").
WithJSON(updateJSON).
WithHeader("X-Api-User", test.user).
WithHeader("X-Api-Key", test.pass).
Expect().
Status(test.status)
}
}