4
1
Fork 0

Add UpdateUser test
continuous-integration/drone/push Build is failing Details

pull/24/head
Ambrose Chua 2019-09-03 10:52:21 +08:00
parent 5e9e8a57f2
commit e6499279ff
Signed by: ambrose
GPG Key ID: B34FBE029276BA5D
2 changed files with 99 additions and 20 deletions

View File

@ -12,7 +12,7 @@ func NewRouter(h *Handler) *httprouter.Router {
router.GET("/user", h.GetUserByPhone)
router.GET("/user/id/:user", h.GetUser)
router.GET("/user/username/:username", h.GetUserByUsername)
router.PATCH("/user", h.UpdateUser)
router.PATCH("/user", AuthMiddleware(h.UpdateUser))
// Conversations
router.POST("/user/conversation", AuthMiddleware(h.CreateConversation))

View File

@ -21,76 +21,155 @@ func TestUser(t *testing.T) {
t.Run("Create", testCreateUser(db, r))
t.Run("GetUserByPhone", testGetUserByPhone(db, r))
t.Run("GetUser", testGetUser(db, r))
t.Run("UpdateUser", testUpdateUser(db, r))
}
func testCreateUser(db *sql.DB, router http.Handler) func(t *testing.T) {
return func(t *testing.T) {
// Setup
mockUser := &User{
PhoneNumber: "+65 99999999",
FirstName: "Test",
LastName: "User",
LastName: "User 1",
}
b, _ := json.Marshal(mockUser)
// Test
w := httptest.NewRecorder()
r := httptest.NewRequest("POST", "/user", bytes.NewBuffer(b))
router.ServeHTTP(w, r)
assertCode(t, w, 200)
assertDB(t, db, `SELECT * FROM "user" WHERE phone_number = '+65 9999 9999' AND first_name = 'Test' AND last_name = 'User'`)
// Assert
got, want := new(User), mockUser
wantPhone, _ := ParsePhone(want.PhoneNumber)
json.NewDecoder(w.Body).Decode(got)
if got.FirstName != want.FirstName || got.LastName != want.LastName || got.PhoneNumber != wantPhone {
t.Error("Wanted a User with same FirstName, LastName, PhoneNumber. Got something else")
}
assertDB(t, db, `SELECT * FROM "user" WHERE phone_number = '+65 9999 9999' AND first_name = 'Test' AND last_name = 'User 1'`)
}
}
func testGetUserByPhone(db *sql.DB, router http.Handler) func(t *testing.T) {
return func(t *testing.T) {
mockUser := &User{
PhoneNumber: "+65 9999 9999",
FirstName: "Test",
LastName: "User",
}
// Setup
mockUser := &User{
PhoneNumber: "+65 99999998",
FirstName: "Test",
LastName: "User 2",
}
b, _ := json.Marshal(mockUser)
ws := httptest.NewRecorder()
rs := httptest.NewRequest("POST", "/user", bytes.NewBuffer(b))
router.ServeHTTP(ws, rs)
createdUser := new(User)
json.NewDecoder(ws.Body).Decode(createdUser)
// Test
w := httptest.NewRecorder()
r := httptest.NewRequest("GET", "/user?phone_number=%2B6599999999", nil)
r := httptest.NewRequest("GET", "/user?phone_number=%2B6599999998", nil)
router.ServeHTTP(w, r)
assertCode(t, w, 200)
got, want := new(User), mockUser
// Assert
got, want := new(User), createdUser
json.NewDecoder(w.Body).Decode(got)
if got.FirstName != want.FirstName || got.LastName != want.LastName || got.PhoneNumber != want.PhoneNumber {
t.Errorf("Want user %v, got %v", want, got)
if diff := cmp.Diff(got, want); len(diff) != 0 {
t.Error(diff)
}
}
}
func testGetUser(db *sql.DB, router http.Handler) func(t *testing.T) {
return func(t *testing.T) {
// Setup
mockUser := &User{
PhoneNumber: "+65 88888888",
PhoneNumber: "+65 99999997",
FirstName: "User",
LastName: "Test",
LastName: "Test 2",
}
cb, _ := json.Marshal(mockUser)
b, _ := json.Marshal(mockUser)
cw := httptest.NewRecorder()
cr := httptest.NewRequest("POST", "/user", bytes.NewBuffer(cb))
router.ServeHTTP(cw, cr)
ws := httptest.NewRecorder()
rs := httptest.NewRequest("POST", "/user", bytes.NewBuffer(b))
router.ServeHTTP(ws, rs)
createdUser := new(User)
json.NewDecoder(cw.Body).Decode(createdUser)
json.NewDecoder(ws.Body).Decode(createdUser)
// Test
w := httptest.NewRecorder()
r := httptest.NewRequest("GET", "/user/id/"+createdUser.ID, nil)
router.ServeHTTP(w, r)
assertCode(t, w, 200)
// Assert
got, want := new(User), createdUser
json.NewDecoder(w.Body).Decode(got)
if diff := cmp.Diff(got, want); len(diff) != 0 {
t.Error(diff)
}
}
}
func testUpdateUser(db *sql.DB, router http.Handler) func(t *testing.T) {
return func(t *testing.T) {
// Setup
mockUser := &User{
PhoneNumber: "+65 99999996",
FirstName: "User",
LastName: "Test 3",
}
bs, _ := json.Marshal(mockUser)
ws := httptest.NewRecorder()
rs := httptest.NewRequest("POST", "/user", bytes.NewBuffer(bs))
router.ServeHTTP(ws, rs)
createdUser := new(User)
json.NewDecoder(ws.Body).Decode(createdUser)
// Test
b := []byte(`{"first_name": "Ambrose", "last_name": "Chua"}`)
updateUser := new(User)
json.NewDecoder(bytes.NewBuffer(b)).Decode(updateUser)
updatedUser := createdUser
updatedUser.FirstName = updateUser.FirstName
updatedUser.LastName = updateUser.LastName
w := httptest.NewRecorder()
r := httptest.NewRequest("PATCH", "/user", bytes.NewBuffer(b))
claim, _ := json.Marshal(&RawClient{UserId: createdUser.ID, ClientId: "test"})
r.Header.Add("X-User-Claim", string(claim))
router.ServeHTTP(w, r)
assertCode(t, w, 200)
// Assert
wt := httptest.NewRecorder()
rt := httptest.NewRequest("GET", "/user/id/"+createdUser.ID, nil)
router.ServeHTTP(wt, rt)
got, want := new(User), updatedUser
json.NewDecoder(wt.Body).Decode(got)
if diff := cmp.Diff(got, want); len(diff) != 0 {
t.Error(diff)
}
}
}