forked from o1egl/go-wordpress
-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathusers_test.go
201 lines (172 loc) · 5.42 KB
/
users_test.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
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
package wordpress_test
import (
"context"
"net/http"
"testing"
"github.com/robbiet480/go-wordpress"
)
func factoryUser() *wordpress.User {
return &wordpress.User{
Username: "go-wordpress-test-user1",
Name: "go-wordpress-test-user1",
Email: "[email protected]",
Slug: "go-wordpress-test-user1",
Password: "password",
}
}
func cleanUpUser(t *testing.T, userID int) {
wp, ctx := initTestClient()
// Note that deleting a user requires `force=true` since `users` resource does not support trashing
deletedUser, resp, err := wp.Users.Delete(ctx, userID, "force=true&reassign=1")
if err != nil {
t.Errorf("Failed to clean up new user: %v", err.Error())
}
if resp != nil && resp.StatusCode != http.StatusOK {
t.Errorf("Expected 200 StatusOK, got %v", resp.Status)
}
if deletedUser.ID != userID {
t.Errorf("Deleted user ID should be the same as newly created user: %v != %v", deletedUser.ID, userID)
}
}
func getAnyOneUser(t *testing.T, ctx context.Context, wp *wordpress.Client) *wordpress.User {
users, resp, _ := wp.Users.List(ctx, nil)
if resp != nil && resp.StatusCode != http.StatusOK {
t.Errorf("Expected 200 OK, got %v", resp.Status)
}
if len(users) < 1 {
t.Fatalf("Should not return empty users")
}
userID := users[0].ID
user, resp, _ := wp.Users.Get(ctx, userID, "context=edit")
if resp != nil && resp.StatusCode != http.StatusOK {
t.Errorf("Expected 200 OK, got %v", resp.Status)
}
return user
}
func TestUsersList(t *testing.T) {
client, ctx := initTestClient()
users, resp, err := client.Users.List(ctx, nil)
if err != nil {
t.Errorf("Should not return error: %v", err.Error())
}
if resp != nil && resp.StatusCode != http.StatusOK {
t.Errorf("Expected 200 StatusOK, got %v", resp.Status)
}
if users == nil {
t.Errorf("Should not return nil users")
}
}
func TestUsersMe(t *testing.T) {
wp, ctx := initTestClient()
currentUser, resp, err := wp.Users.Me(ctx, "context=edit")
if err != nil {
t.Errorf("Should not return error: %v", err.Error())
}
if resp != nil && resp.StatusCode != http.StatusOK {
t.Errorf("Expected 200 StatusOK, got %v", resp.Status)
}
if currentUser == nil {
t.Errorf("currentUser should not be nil")
}
if currentUser.Name != USER {
t.Errorf("Logged in user has a different username: %v != %v", currentUser.Username, USER)
}
}
func TestUsersGet(t *testing.T) {
wp, ctx := initTestClient()
u := getAnyOneUser(t, ctx, wp)
user, resp, err := wp.Users.Get(ctx, u.ID, nil)
if err != nil {
t.Errorf("Should not return error: %v", err.Error())
}
if resp != nil && resp.StatusCode != http.StatusOK {
t.Errorf("Expected 200 StatusOK, got %v", resp.Status)
}
if user == nil {
t.Errorf("user should not be nil")
}
}
func TestUsersCreate(t *testing.T) {
wp, ctx := initTestClient()
u := &wordpress.User{
Username: "go-wordpress-test-user1",
Email: "[email protected]",
Name: "go-wordpress-test-user1",
Slug: "go-wordpress-test-user1",
Password: "password",
}
newUser, resp, err := wp.Users.Create(ctx, u)
if err != nil {
t.Errorf("Should not return error: %v", err.Error())
}
if resp != nil && resp.StatusCode != http.StatusCreated {
t.Errorf("Expected 201 Created, got %v", resp.Status)
}
if newUser == nil {
t.Errorf("newUser should not be nil")
}
// clean up
cleanUpUser(t, newUser.ID)
}
func TestUsersDelete(t *testing.T) {
wp, ctx := initTestClient()
u := factoryUser()
newUser, resp, _ := wp.Users.Create(ctx, u)
if resp != nil && resp.StatusCode != http.StatusCreated {
t.Errorf("Expected 201 Created, got %v", resp.Status)
}
if newUser == nil {
t.Errorf("newUser should not be nil")
}
// Note that deleting a user requires `force=true` since `users` resource does not support trashing
// If not specified, a 501 NotImplemented will be returned
deletedUser, resp, err := wp.Users.Delete(ctx, newUser.ID, "force=true&reassign=1")
if err != nil {
t.Errorf("Should not return error: %v", err.Error())
}
if resp != nil && resp.StatusCode != http.StatusOK {
t.Errorf("Expected 200 OK, got %v", resp.Status)
}
if deletedUser.ID != newUser.ID {
t.Errorf("Deleted user ID should be the same as newly created user: %v != %v", deletedUser.ID, newUser.ID)
}
}
func TestUsersUpdate(t *testing.T) {
wp, ctx := initTestClient()
u := factoryUser()
// create user
newUser, resp, _ := wp.Users.Create(ctx, u)
if resp != nil && resp.StatusCode != http.StatusCreated {
t.Errorf("Expected 201 Created, got %v", resp.Status)
}
if newUser == nil {
t.Errorf("newUser should not be nil")
}
// get user in `edit` context
user, resp, _ := wp.Users.Get(ctx, newUser.ID, "context=edit")
if resp != nil && resp.StatusCode != http.StatusOK {
t.Errorf("Expected 200 OK, got %v", resp.Status)
}
if user == nil {
t.Errorf("user should not be nil")
}
// modify user
newUserEmail := "[email protected]"
if user.Email == newUserEmail {
t.Errorf("Warning: Data must be different for proper test, %v === %v", user.Email, newUserEmail)
}
user.Email = newUserEmail
// update
updatedUser, resp, err := wp.Users.Update(ctx, user.ID, user)
if err != nil {
t.Errorf("Should not return error: %v", err.Error())
}
if resp != nil && resp.StatusCode != http.StatusOK {
t.Errorf("Expected 200 OK, got %v", resp.Status)
}
if updatedUser.ID != user.ID {
t.Errorf("updatedUser ID should be the same ass specified user: %v != %v", updatedUser.ID, user.ID)
}
// clean up
cleanUpUser(t, newUser.ID)
}