user_handler_test.go 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703
  1. package api_test
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "net/http"
  6. "net/http/httptest"
  7. "reflect"
  8. "strings"
  9. "testing"
  10. "github.com/porter-dev/porter/internal/models"
  11. )
  12. // ------------------------- TEST TYPES AND MAIN LOOP ------------------------- //
  13. type userTest struct {
  14. initializers []func(t *tester)
  15. msg string
  16. method string
  17. endpoint string
  18. body string
  19. expStatus int
  20. expBody string
  21. useCookie bool
  22. validators []func(c *userTest, tester *tester, t *testing.T)
  23. }
  24. func testUserRequests(t *testing.T, tests []*userTest, canQuery bool) {
  25. for _, c := range tests {
  26. // create a new tester
  27. tester := newTester(canQuery, nil)
  28. // if there's an initializer, call it
  29. for _, init := range c.initializers {
  30. init(tester)
  31. }
  32. req, err := http.NewRequest(
  33. c.method,
  34. c.endpoint,
  35. strings.NewReader(c.body),
  36. )
  37. tester.req = req
  38. if c.useCookie {
  39. req.AddCookie(tester.cookie)
  40. }
  41. if err != nil {
  42. t.Fatal(err)
  43. }
  44. tester.execute()
  45. rr := tester.rr
  46. // first, check that the status matches
  47. if status := rr.Code; status != c.expStatus {
  48. t.Errorf("%s, handler returned wrong status code: got %v want %v",
  49. c.msg, status, c.expStatus)
  50. }
  51. // if there's a validator, call it
  52. for _, validate := range c.validators {
  53. validate(c, tester, t)
  54. }
  55. }
  56. }
  57. // ------------------------- TEST FIXTURES AND FUNCTIONS ------------------------- //
  58. var createUserTests = []*userTest{
  59. &userTest{
  60. msg: "Create user",
  61. method: "POST",
  62. endpoint: "/api/users",
  63. body: `{
  64. "email": "belanger@getporter.dev",
  65. "password": "hello"
  66. }`,
  67. expStatus: http.StatusCreated,
  68. expBody: "",
  69. },
  70. &userTest{
  71. msg: "Create user invalid email",
  72. method: "POST",
  73. endpoint: "/api/users",
  74. body: `{
  75. "email": "notanemail",
  76. "password": "hello"
  77. }`,
  78. expStatus: http.StatusUnprocessableEntity,
  79. expBody: `{"code":601,"errors":["email validation failed"]}`,
  80. validators: []func(c *userTest, tester *tester, t *testing.T){
  81. userBasicBodyValidator,
  82. },
  83. },
  84. &userTest{
  85. msg: "Create user missing field",
  86. method: "POST",
  87. endpoint: "/api/users",
  88. body: `{
  89. "password": "hello"
  90. }`,
  91. expStatus: http.StatusUnprocessableEntity,
  92. expBody: `{"code":601,"errors":["required validation failed"]}`,
  93. validators: []func(c *userTest, tester *tester, t *testing.T){
  94. userBasicBodyValidator,
  95. },
  96. },
  97. &userTest{
  98. initializers: []func(tester *tester){
  99. initUserDefault,
  100. },
  101. msg: "Create user same email",
  102. method: "POST",
  103. endpoint: "/api/users",
  104. body: `{
  105. "email": "belanger@getporter.dev",
  106. "password": "hello"
  107. }`,
  108. expStatus: http.StatusUnprocessableEntity,
  109. expBody: `{"code":601,"errors":["email already taken"]}`,
  110. validators: []func(c *userTest, tester *tester, t *testing.T){
  111. userBasicBodyValidator,
  112. },
  113. },
  114. &userTest{
  115. msg: "Create user invalid field type",
  116. method: "POST",
  117. endpoint: "/api/users",
  118. body: `{
  119. "email": "belanger@getporter.dev",
  120. "password": 0
  121. }`,
  122. expStatus: http.StatusBadRequest,
  123. expBody: `{"code":600,"errors":["could not process request"]}`,
  124. validators: []func(c *userTest, tester *tester, t *testing.T){
  125. userBasicBodyValidator,
  126. },
  127. },
  128. }
  129. func TestHandleCreateUser(t *testing.T) {
  130. testUserRequests(t, createUserTests, true)
  131. }
  132. var createUserTestsWriteFail = []*userTest{
  133. &userTest{
  134. msg: "Create user db connection down",
  135. method: "POST",
  136. endpoint: "/api/users",
  137. body: `{
  138. "email": "belanger@getporter.dev",
  139. "password": "hello"
  140. }`,
  141. expStatus: http.StatusInternalServerError,
  142. expBody: `{"code":500,"errors":["could not read from database"]}`,
  143. validators: []func(c *userTest, tester *tester, t *testing.T){
  144. userBasicBodyValidator,
  145. },
  146. },
  147. }
  148. func TestHandleCreateUserWriteFail(t *testing.T) {
  149. testUserRequests(t, createUserTestsWriteFail, false)
  150. }
  151. var loginUserTests = []*userTest{
  152. &userTest{
  153. initializers: []func(tester *tester){
  154. initUserDefault,
  155. },
  156. msg: "Login user successful",
  157. method: "POST",
  158. endpoint: "/api/login",
  159. body: `{
  160. "email": "belanger@getporter.dev",
  161. "password": "hello"
  162. }`,
  163. expStatus: http.StatusOK,
  164. expBody: ``,
  165. validators: []func(c *userTest, tester *tester, t *testing.T){
  166. userBasicBodyValidator,
  167. },
  168. },
  169. &userTest{
  170. initializers: []func(tester *tester){
  171. initUserDefault,
  172. },
  173. msg: "Login user already logged in",
  174. method: "POST",
  175. endpoint: "/api/login",
  176. body: `{
  177. "email": "belanger@getporter.dev",
  178. "password": "hello"
  179. }`,
  180. expStatus: http.StatusOK,
  181. expBody: ``,
  182. useCookie: true,
  183. validators: []func(c *userTest, tester *tester, t *testing.T){
  184. userBasicBodyValidator,
  185. },
  186. },
  187. &userTest{
  188. msg: "Login user unregistered email",
  189. method: "POST",
  190. endpoint: "/api/login",
  191. body: `{
  192. "email": "belanger@getporter.dev",
  193. "password": "hello"
  194. }`,
  195. expStatus: http.StatusUnauthorized,
  196. expBody: `{"code":401,"errors":["email not registered"]}`,
  197. validators: []func(c *userTest, tester *tester, t *testing.T){
  198. userBasicBodyValidator,
  199. },
  200. },
  201. &userTest{
  202. initializers: []func(tester *tester){
  203. initUserDefault,
  204. },
  205. msg: "Login user incorrect password",
  206. method: "POST",
  207. endpoint: "/api/login",
  208. body: `{
  209. "email": "belanger@getporter.dev",
  210. "password": "notthepassword"
  211. }`,
  212. expStatus: http.StatusUnauthorized,
  213. expBody: `{"code":401,"errors":["incorrect password"]}`,
  214. useCookie: true,
  215. validators: []func(c *userTest, tester *tester, t *testing.T){
  216. userBasicBodyValidator,
  217. },
  218. },
  219. }
  220. func TestHandleLoginUser(t *testing.T) {
  221. testUserRequests(t, loginUserTests, true)
  222. }
  223. var logoutUserTests = []*userTest{
  224. &userTest{
  225. initializers: []func(tester *tester){
  226. initUserDefault,
  227. },
  228. msg: "Logout user successful",
  229. method: "POST",
  230. endpoint: "/api/logout",
  231. body: `{
  232. "email": "belanger@getporter.dev",
  233. "password": "hello"
  234. }`,
  235. expStatus: http.StatusOK,
  236. expBody: ``,
  237. useCookie: true,
  238. validators: []func(c *userTest, tester *tester, t *testing.T){
  239. func(c *userTest, tester *tester, t *testing.T) {
  240. req, err := http.NewRequest(
  241. "GET",
  242. "/api/users/1",
  243. strings.NewReader(""),
  244. )
  245. req.AddCookie(tester.cookie)
  246. if err != nil {
  247. t.Fatal(err)
  248. }
  249. rr2 := httptest.NewRecorder()
  250. tester.router.ServeHTTP(rr2, req)
  251. if status := rr2.Code; status != http.StatusForbidden {
  252. t.Errorf("%s, handler returned wrong status: got %v want %v",
  253. "validator failed", status, http.StatusForbidden)
  254. }
  255. },
  256. },
  257. },
  258. }
  259. func TestHandleLogoutUser(t *testing.T) {
  260. testUserRequests(t, logoutUserTests, true)
  261. }
  262. var readUserTests = []*userTest{
  263. &userTest{
  264. initializers: []func(tester *tester){
  265. initUserWithContexts,
  266. },
  267. msg: "Read user successful",
  268. method: "GET",
  269. endpoint: "/api/users/1",
  270. body: "",
  271. expStatus: http.StatusOK,
  272. expBody: `{"id":1,"email":"belanger@getporter.dev","contexts":["context-test"],"rawKubeConfig":"apiVersion: v1\nkind: Config\npreferences: {}\ncurrent-context: context-test\nclusters:\n- cluster:\n server: https://localhost\n name: cluster-test\ncontexts:\n- context:\n cluster: cluster-test\n user: test-admin\n name: context-test\nusers:\n- name: test-admin"}`,
  273. useCookie: true,
  274. validators: []func(c *userTest, tester *tester, t *testing.T){
  275. userModelBodyValidator,
  276. },
  277. },
  278. &userTest{
  279. initializers: []func(tester *tester){
  280. initUserDefault,
  281. },
  282. msg: "Read user unauthorized",
  283. method: "GET",
  284. endpoint: "/api/users/2",
  285. body: "",
  286. expStatus: http.StatusForbidden,
  287. expBody: http.StatusText(http.StatusForbidden) + "\n",
  288. validators: []func(c *userTest, tester *tester, t *testing.T){
  289. userBasicBodyValidator,
  290. },
  291. },
  292. }
  293. func TestHandleReadUser(t *testing.T) {
  294. testUserRequests(t, readUserTests, true)
  295. }
  296. var readUserContextsTests = []*userTest{
  297. &userTest{
  298. initializers: []func(tester *tester){
  299. initUserWithContexts,
  300. },
  301. msg: "Read user context selected successful",
  302. method: "GET",
  303. endpoint: "/api/users/1/contexts",
  304. body: "",
  305. expStatus: http.StatusOK,
  306. useCookie: true,
  307. expBody: `[{"name":"context-test","server":"https://localhost","cluster":"cluster-test","user":"test-admin","selected":true}]`,
  308. validators: []func(c *userTest, tester *tester, t *testing.T){
  309. userContextBodyValidator,
  310. },
  311. },
  312. &userTest{
  313. initializers: []func(tester *tester){
  314. func(tester *tester) {
  315. initUserDefault(tester)
  316. user, _ := tester.repo.User.ReadUserByEmail("belanger@getporter.dev")
  317. user.Contexts = ""
  318. user.RawKubeConfig = []byte("apiVersion: v1\nkind: Config\npreferences: {}\ncurrent-context: context-test\nclusters:\n- cluster:\n server: https://localhost\n name: cluster-test\ncontexts:\n- context:\n cluster: cluster-test\n user: test-admin\n name: context-test\nusers:\n- name: test-admin")
  319. tester.repo.User.UpdateUser(user)
  320. },
  321. },
  322. msg: "Read user context not selected successful",
  323. method: "GET",
  324. endpoint: "/api/users/1/contexts",
  325. body: "",
  326. expStatus: http.StatusOK,
  327. useCookie: true,
  328. expBody: `[{"name":"context-test","server":"https://localhost","cluster":"cluster-test","user":"test-admin","selected":false}]`,
  329. validators: []func(c *userTest, tester *tester, t *testing.T){
  330. userContextBodyValidator,
  331. },
  332. },
  333. }
  334. func TestHandleReadUserContexts(t *testing.T) {
  335. testUserRequests(t, readUserContextsTests, true)
  336. }
  337. var updateUserTests = []*userTest{
  338. &userTest{
  339. initializers: []func(tester *tester){
  340. initUserDefault,
  341. },
  342. msg: "Update user successful",
  343. method: "PUT",
  344. endpoint: "/api/users/1",
  345. body: `{"rawKubeConfig":"apiVersion: v1\nkind: Config\npreferences: {}\ncurrent-context: context-test\nclusters:\n- cluster:\n server: https://localhost\n name: cluster-test\ncontexts:\n- context:\n cluster: cluster-test\n user: test-admin\n name: context-test\nusers:\n- name: test-admin", "allowedContexts":[]}`,
  346. expStatus: http.StatusNoContent,
  347. expBody: "",
  348. useCookie: true,
  349. validators: []func(c *userTest, tester *tester, t *testing.T){
  350. func(c *userTest, tester *tester, t *testing.T) {
  351. req, err := http.NewRequest(
  352. "GET",
  353. "/api/users/1",
  354. strings.NewReader(""),
  355. )
  356. req.AddCookie(tester.cookie)
  357. if err != nil {
  358. t.Fatal(err)
  359. }
  360. rr2 := httptest.NewRecorder()
  361. tester.router.ServeHTTP(rr2, req)
  362. gotBody := &models.UserExternal{}
  363. expBody := &models.UserExternal{}
  364. json.Unmarshal(rr2.Body.Bytes(), gotBody)
  365. json.Unmarshal([]byte(`{"id":1,"email":"belanger@getporter.dev","contexts":[],"rawKubeConfig":"apiVersion: v1\nkind: Config\npreferences: {}\ncurrent-context: context-test\nclusters:\n- cluster:\n server: https://localhost\n name: cluster-test\ncontexts:\n- context:\n cluster: cluster-test\n user: test-admin\n name: context-test\nusers:\n- name: test-admin"}`), expBody)
  366. fmt.Println(rr2.Body.String())
  367. if !reflect.DeepEqual(gotBody, expBody) {
  368. t.Errorf("%s, handler returned wrong body: got %v want %v",
  369. "validator failed", gotBody, expBody)
  370. }
  371. },
  372. },
  373. },
  374. &userTest{
  375. initializers: []func(tester *tester){
  376. initUserDefault,
  377. },
  378. msg: "Update user successful without allowedContexts parameter",
  379. method: "PUT",
  380. endpoint: "/api/users/1",
  381. body: `{"rawKubeConfig":"apiVersion: v1\nkind: Config\npreferences: {}\ncurrent-context: context-test\nclusters:\n- cluster:\n server: https://localhost\n name: cluster-test\ncontexts:\n- context:\n cluster: cluster-test\n user: test-admin\n name: context-test\nusers:\n- name: test-admin"}`,
  382. expStatus: http.StatusNoContent,
  383. expBody: "",
  384. useCookie: true,
  385. validators: []func(c *userTest, tester *tester, t *testing.T){
  386. func(c *userTest, tester *tester, t *testing.T) {
  387. req, err := http.NewRequest(
  388. "GET",
  389. "/api/users/1",
  390. strings.NewReader(""),
  391. )
  392. req.AddCookie(tester.cookie)
  393. if err != nil {
  394. t.Fatal(err)
  395. }
  396. rr2 := httptest.NewRecorder()
  397. tester.router.ServeHTTP(rr2, req)
  398. gotBody := &models.UserExternal{}
  399. expBody := &models.UserExternal{}
  400. json.Unmarshal(rr2.Body.Bytes(), gotBody)
  401. json.Unmarshal([]byte(`{"id":1,"email":"belanger@getporter.dev","contexts":[],"rawKubeConfig":"apiVersion: v1\nkind: Config\npreferences: {}\ncurrent-context: context-test\nclusters:\n- cluster:\n server: https://localhost\n name: cluster-test\ncontexts:\n- context:\n cluster: cluster-test\n user: test-admin\n name: context-test\nusers:\n- name: test-admin"}`), expBody)
  402. if !reflect.DeepEqual(gotBody, expBody) {
  403. t.Errorf("%s, handler returned wrong body: got %v want %v",
  404. "validator failed", gotBody, expBody)
  405. }
  406. },
  407. },
  408. },
  409. &userTest{
  410. initializers: []func(tester *tester){
  411. initUserDefault,
  412. },
  413. msg: "Update user successful with allowedContexts",
  414. method: "PUT",
  415. endpoint: "/api/users/1",
  416. body: `{"rawKubeConfig":"apiVersion: v1\nkind: Config\npreferences: {}\ncurrent-context: context-test\nclusters:\n- cluster:\n server: https://localhost\n name: cluster-test\ncontexts:\n- context:\n cluster: cluster-test\n user: test-admin\n name: context-test\nusers:\n- name: test-admin", "allowedContexts":["context-test"]}`,
  417. expStatus: http.StatusNoContent,
  418. expBody: "",
  419. useCookie: true,
  420. validators: []func(c *userTest, tester *tester, t *testing.T){
  421. func(c *userTest, tester *tester, t *testing.T) {
  422. req, err := http.NewRequest(
  423. "GET",
  424. "/api/users/1",
  425. strings.NewReader(""),
  426. )
  427. req.AddCookie(tester.cookie)
  428. if err != nil {
  429. t.Fatal(err)
  430. }
  431. rr2 := httptest.NewRecorder()
  432. tester.router.ServeHTTP(rr2, req)
  433. gotBody := &models.UserExternal{}
  434. expBody := &models.UserExternal{}
  435. json.Unmarshal(rr2.Body.Bytes(), gotBody)
  436. json.Unmarshal([]byte(`{"id":1,"email":"belanger@getporter.dev","contexts":["context-test"],"rawKubeConfig":"apiVersion: v1\nkind: Config\npreferences: {}\ncurrent-context: context-test\nclusters:\n- cluster:\n server: https://localhost\n name: cluster-test\ncontexts:\n- context:\n cluster: cluster-test\n user: test-admin\n name: context-test\nusers:\n- name: test-admin"}`), expBody)
  437. if !reflect.DeepEqual(gotBody, expBody) {
  438. t.Errorf("%s, handler returned wrong body: got %v want %v",
  439. "validator failed", gotBody, expBody)
  440. }
  441. },
  442. },
  443. },
  444. &userTest{
  445. initializers: []func(tester *tester){
  446. initUserWithContexts,
  447. },
  448. msg: "Update user successful without rawKubeConfig",
  449. method: "PUT",
  450. endpoint: "/api/users/1",
  451. body: `{"allowedContexts":[]}`,
  452. expStatus: http.StatusNoContent,
  453. expBody: "",
  454. useCookie: true,
  455. validators: []func(c *userTest, tester *tester, t *testing.T){
  456. func(c *userTest, tester *tester, t *testing.T) {
  457. req, err := http.NewRequest(
  458. "GET",
  459. "/api/users/1",
  460. strings.NewReader(""),
  461. )
  462. req.AddCookie(tester.cookie)
  463. if err != nil {
  464. t.Fatal(err)
  465. }
  466. rr2 := httptest.NewRecorder()
  467. tester.router.ServeHTTP(rr2, req)
  468. gotBody := &models.UserExternal{}
  469. expBody := &models.UserExternal{}
  470. json.Unmarshal(rr2.Body.Bytes(), gotBody)
  471. json.Unmarshal([]byte(`{"id":1,"email":"belanger@getporter.dev","contexts":[],"rawKubeConfig":"apiVersion: v1\nkind: Config\npreferences: {}\ncurrent-context: context-test\nclusters:\n- cluster:\n server: https://localhost\n name: cluster-test\ncontexts:\n- context:\n cluster: cluster-test\n user: test-admin\n name: context-test\nusers:\n- name: test-admin"}`), expBody)
  472. if !reflect.DeepEqual(gotBody, expBody) {
  473. t.Errorf("%s, handler returned wrong body: got %v want %v",
  474. "validator failed", gotBody, expBody)
  475. }
  476. },
  477. },
  478. },
  479. &userTest{
  480. initializers: []func(tester *tester){
  481. initUserDefault,
  482. },
  483. msg: "Update user invalid id",
  484. method: "PUT",
  485. endpoint: "/api/users/alsdfjk",
  486. body: `{"rawKubeConfig":"apiVersion: v1\nkind: Config\npreferences: {}\ncurrent-context: context-test\nclusters:\n- cluster:\n server: https://localhost\n name: cluster-test\ncontexts:\n- context:\n cluster: cluster-test\n user: test-admin\n name: context-test\nusers:\n- name: test-admin", "allowedContexts":[]}`,
  487. expStatus: http.StatusForbidden,
  488. expBody: http.StatusText(http.StatusForbidden) + "\n",
  489. validators: []func(c *userTest, tester *tester, t *testing.T){
  490. userBasicBodyValidator,
  491. },
  492. },
  493. &userTest{
  494. initializers: []func(tester *tester){
  495. initUserDefault,
  496. },
  497. msg: "Update user bad kubeconfig",
  498. method: "PUT",
  499. endpoint: "/api/users/1",
  500. body: `{"rawKubeConfig":"notvalidyaml", "allowedContexts":[]}`,
  501. expStatus: http.StatusBadRequest,
  502. expBody: `{"code":600,"errors":["could not process request"]}`,
  503. useCookie: true,
  504. validators: []func(c *userTest, tester *tester, t *testing.T){
  505. userBasicBodyValidator,
  506. },
  507. },
  508. }
  509. func TestHandleUpdateUser(t *testing.T) {
  510. testUserRequests(t, updateUserTests, true)
  511. }
  512. var deleteUserTests = []*userTest{
  513. &userTest{
  514. initializers: []func(tester *tester){
  515. initUserDefault,
  516. },
  517. msg: "Delete user successful",
  518. method: "DELETE",
  519. endpoint: "/api/users/1",
  520. body: `{"password":"hello"}`,
  521. expStatus: http.StatusNoContent,
  522. expBody: "",
  523. useCookie: true,
  524. validators: []func(c *userTest, tester *tester, t *testing.T){
  525. func(c *userTest, tester *tester, t *testing.T) {
  526. req, err := http.NewRequest(
  527. "GET",
  528. "/api/users/1",
  529. strings.NewReader(""),
  530. )
  531. req.AddCookie(tester.cookie)
  532. if err != nil {
  533. t.Fatal(err)
  534. }
  535. rr2 := httptest.NewRecorder()
  536. tester.router.ServeHTTP(rr2, req)
  537. gotBody := &models.UserExternal{}
  538. expBody := &models.UserExternal{}
  539. if status := rr2.Code; status != 404 {
  540. t.Errorf("DELETE user validation, handler returned wrong status code: got %v want %v",
  541. status, 404)
  542. }
  543. json.Unmarshal(rr2.Body.Bytes(), gotBody)
  544. json.Unmarshal([]byte(`{"code":602,"errors":["could not find requested object"]}`), expBody)
  545. if !reflect.DeepEqual(gotBody, expBody) {
  546. t.Errorf("%s, handler returned wrong body: got %v want %v",
  547. "validator failed", gotBody, expBody)
  548. }
  549. },
  550. },
  551. },
  552. &userTest{
  553. initializers: []func(tester *tester){
  554. initUserDefault,
  555. },
  556. msg: "Delete user invalid id",
  557. method: "DELETE",
  558. endpoint: "/api/users/aldkjf",
  559. body: `{"password":"hello"}`,
  560. expStatus: http.StatusForbidden,
  561. expBody: http.StatusText(http.StatusForbidden) + "\n",
  562. validators: []func(c *userTest, tester *tester, t *testing.T){
  563. userBasicBodyValidator,
  564. },
  565. },
  566. &userTest{
  567. initializers: []func(tester *tester){
  568. initUserDefault,
  569. },
  570. msg: "Delete user missing password",
  571. method: "DELETE",
  572. endpoint: "/api/users/1",
  573. body: `{}`,
  574. expStatus: http.StatusUnprocessableEntity,
  575. expBody: `{"code":601,"errors":["required validation failed"]}`,
  576. useCookie: true,
  577. validators: []func(c *userTest, tester *tester, t *testing.T){
  578. userBasicBodyValidator,
  579. },
  580. },
  581. }
  582. func TestHandleDeleteUser(t *testing.T) {
  583. testUserRequests(t, deleteUserTests, true)
  584. }
  585. // ------------------------- INITIALIZERS AND VALIDATORS ------------------------- //
  586. func initUserDefault(tester *tester) {
  587. tester.createUserSession("belanger@getporter.dev", "hello")
  588. }
  589. func initUserWithContexts(tester *tester) {
  590. initUserDefault(tester)
  591. user, _ := tester.repo.User.ReadUserByEmail("belanger@getporter.dev")
  592. user.Contexts = "context-test"
  593. user.RawKubeConfig = []byte("apiVersion: v1\nkind: Config\npreferences: {}\ncurrent-context: context-test\nclusters:\n- cluster:\n server: https://localhost\n name: cluster-test\ncontexts:\n- context:\n cluster: cluster-test\n user: test-admin\n name: context-test\nusers:\n- name: test-admin")
  594. tester.repo.User.UpdateUser(user)
  595. }
  596. func userBasicBodyValidator(c *userTest, tester *tester, t *testing.T) {
  597. if body := tester.rr.Body.String(); body != c.expBody {
  598. t.Errorf("%s, handler returned wrong body: got %v want %v",
  599. c.msg, body, c.expBody)
  600. }
  601. }
  602. func userModelBodyValidator(c *userTest, tester *tester, t *testing.T) {
  603. gotBody := &models.UserExternal{}
  604. expBody := &models.UserExternal{}
  605. json.Unmarshal(tester.rr.Body.Bytes(), gotBody)
  606. json.Unmarshal([]byte(c.expBody), expBody)
  607. if !reflect.DeepEqual(gotBody, expBody) {
  608. t.Errorf("%s, handler returned wrong body: got %v want %v",
  609. c.msg, gotBody, expBody)
  610. }
  611. }
  612. func userContextBodyValidator(c *userTest, tester *tester, t *testing.T) {
  613. gotBody := &[]models.Context{}
  614. expBody := &[]models.Context{}
  615. json.Unmarshal(tester.rr.Body.Bytes(), gotBody)
  616. json.Unmarshal([]byte(c.expBody), expBody)
  617. if !reflect.DeepEqual(gotBody, expBody) {
  618. t.Errorf("%s, handler returned wrong body: got %v want %v",
  619. c.msg, gotBody, expBody)
  620. }
  621. }