Added API tests.
This commit is contained in:
parent
c0b54d821e
commit
0eae5fc6b8
5 changed files with 161 additions and 2 deletions
91
api/users_test.go
Normal file
91
api/users_test.go
Normal file
|
@ -0,0 +1,91 @@
|
|||
package api
|
||||
|
||||
import (
|
||||
"testing"
|
||||
|
||||
"github.com/thermokarst/bactdb/models"
|
||||
)
|
||||
|
||||
func TestUser_Get(t *testing.T) {
|
||||
setup()
|
||||
|
||||
wantUser := &models.User{Id: 1, UserName: "Test User"}
|
||||
|
||||
calledGet := false
|
||||
store.Users.(*models.MockUsersService).Get_ = func(id int64) (*models.User, error) {
|
||||
if id != wantUser.Id {
|
||||
t.Errorf("wanted request for user %d but got %d", wantUser.Id, id)
|
||||
}
|
||||
calledGet = true
|
||||
return wantUser, nil
|
||||
}
|
||||
|
||||
gotUser, err := apiClient.Users.Get(wantUser.Id)
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
|
||||
if !calledGet {
|
||||
t.Error("!calledGet")
|
||||
}
|
||||
if !normalizeDeepEqual(wantUser, gotUser) {
|
||||
t.Errorf("got user %+v but wanted user %+v", wantUser, gotUser)
|
||||
}
|
||||
}
|
||||
|
||||
func TestUser_Create(t *testing.T) {
|
||||
setup()
|
||||
|
||||
wantUser := &models.User{Id: 1, UserName: "Test User"}
|
||||
|
||||
calledPost := false
|
||||
store.Users.(*models.MockUsersService).Create_ = func(user *models.User) (bool, error) {
|
||||
if !normalizeDeepEqual(wantUser, user) {
|
||||
t.Errorf("wanted request for user %d but got %d", wantUser, user)
|
||||
}
|
||||
calledPost = true
|
||||
return true, nil
|
||||
}
|
||||
|
||||
success, err := apiClient.Users.Create(wantUser)
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
|
||||
if !calledPost {
|
||||
t.Error("!calledPost")
|
||||
}
|
||||
if !success {
|
||||
t.Error("!success")
|
||||
}
|
||||
}
|
||||
|
||||
func TestUser_List(t *testing.T) {
|
||||
setup()
|
||||
|
||||
wantUsers := []*models.User{{Id: 1, UserName: "Test User"}}
|
||||
wantOpt := &models.UserListOptions{ListOptions: models.ListOptions{Page: 1, PerPage: 10}}
|
||||
|
||||
calledList := false
|
||||
store.Users.(*models.MockUsersService).List_ = func(opt *models.UserListOptions) ([]*models.User, error) {
|
||||
if !normalizeDeepEqual(wantOpt, opt) {
|
||||
t.Errorf("wanted options %d but got %d", wantOpt, opt)
|
||||
}
|
||||
calledList = true
|
||||
return wantUsers, nil
|
||||
}
|
||||
|
||||
users, err := apiClient.Users.List(wantOpt)
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
|
||||
if !calledList {
|
||||
t.Error("!calledList")
|
||||
}
|
||||
for i, _ := range users {
|
||||
if !normalizeDeepEqual(wantUsers[i], users[i]) {
|
||||
t.Errorf("got users %+v but wanted users %+v", wantUsers, users)
|
||||
}
|
||||
}
|
||||
}
|
Reference in a new issue