gitea源码

api_issue_tracked_time_test.go 4.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. // Copyright 2019 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package integration
  4. import (
  5. "fmt"
  6. "net/http"
  7. "testing"
  8. "time"
  9. auth_model "code.gitea.io/gitea/models/auth"
  10. issues_model "code.gitea.io/gitea/models/issues"
  11. "code.gitea.io/gitea/models/unittest"
  12. user_model "code.gitea.io/gitea/models/user"
  13. api "code.gitea.io/gitea/modules/structs"
  14. "code.gitea.io/gitea/tests"
  15. "github.com/stretchr/testify/assert"
  16. )
  17. func TestAPIGetTrackedTimes(t *testing.T) {
  18. defer tests.PrepareTestEnv(t)()
  19. user2 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
  20. issue2 := unittest.AssertExistsAndLoadBean(t, &issues_model.Issue{ID: 2})
  21. assert.NoError(t, issue2.LoadRepo(t.Context()))
  22. session := loginUser(t, user2.Name)
  23. token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeReadIssue)
  24. req := NewRequestf(t, "GET", "/api/v1/repos/%s/%s/issues/%d/times", user2.Name, issue2.Repo.Name, issue2.Index).
  25. AddTokenAuth(token)
  26. resp := MakeRequest(t, req, http.StatusOK)
  27. var apiTimes api.TrackedTimeList
  28. DecodeJSON(t, resp, &apiTimes)
  29. expect, err := issues_model.GetTrackedTimes(t.Context(), &issues_model.FindTrackedTimesOptions{IssueID: issue2.ID})
  30. assert.NoError(t, err)
  31. assert.Len(t, apiTimes, 3)
  32. for i, time := range expect {
  33. assert.Equal(t, time.ID, apiTimes[i].ID)
  34. assert.Equal(t, issue2.Title, apiTimes[i].Issue.Title)
  35. assert.Equal(t, issue2.ID, apiTimes[i].IssueID)
  36. assert.Equal(t, time.Created.Unix(), apiTimes[i].Created.Unix())
  37. assert.Equal(t, time.Time, apiTimes[i].Time)
  38. user, err := user_model.GetUserByID(t.Context(), time.UserID)
  39. assert.NoError(t, err)
  40. assert.Equal(t, user.Name, apiTimes[i].UserName)
  41. }
  42. // test filter
  43. since := "2000-01-01T00%3A00%3A02%2B00%3A00" // 946684802
  44. before := "2000-01-01T00%3A00%3A12%2B00%3A00" // 946684812
  45. req = NewRequestf(t, "GET", "/api/v1/repos/%s/%s/issues/%d/times?since=%s&before=%s", user2.Name, issue2.Repo.Name, issue2.Index, since, before).
  46. AddTokenAuth(token)
  47. resp = MakeRequest(t, req, http.StatusOK)
  48. var filterAPITimes api.TrackedTimeList
  49. DecodeJSON(t, resp, &filterAPITimes)
  50. assert.Len(t, filterAPITimes, 2)
  51. assert.Equal(t, int64(3), filterAPITimes[0].ID)
  52. assert.Equal(t, int64(6), filterAPITimes[1].ID)
  53. }
  54. func TestAPIDeleteTrackedTime(t *testing.T) {
  55. defer tests.PrepareTestEnv(t)()
  56. time6 := unittest.AssertExistsAndLoadBean(t, &issues_model.TrackedTime{ID: 6})
  57. issue2 := unittest.AssertExistsAndLoadBean(t, &issues_model.Issue{ID: 2})
  58. assert.NoError(t, issue2.LoadRepo(t.Context()))
  59. user2 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
  60. session := loginUser(t, user2.Name)
  61. token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeWriteIssue)
  62. // Deletion not allowed
  63. req := NewRequestf(t, "DELETE", "/api/v1/repos/%s/%s/issues/%d/times/%d", user2.Name, issue2.Repo.Name, issue2.Index, time6.ID).
  64. AddTokenAuth(token)
  65. MakeRequest(t, req, http.StatusForbidden)
  66. time3 := unittest.AssertExistsAndLoadBean(t, &issues_model.TrackedTime{ID: 3})
  67. req = NewRequestf(t, "DELETE", "/api/v1/repos/%s/%s/issues/%d/times/%d", user2.Name, issue2.Repo.Name, issue2.Index, time3.ID).
  68. AddTokenAuth(token)
  69. MakeRequest(t, req, http.StatusNoContent)
  70. // Delete non existing time
  71. MakeRequest(t, req, http.StatusNotFound)
  72. // Reset time of user 2 on issue 2
  73. trackedSeconds, err := issues_model.GetTrackedSeconds(t.Context(), issues_model.FindTrackedTimesOptions{IssueID: 2, UserID: 2})
  74. assert.NoError(t, err)
  75. assert.Equal(t, int64(3661), trackedSeconds)
  76. req = NewRequestf(t, "DELETE", "/api/v1/repos/%s/%s/issues/%d/times", user2.Name, issue2.Repo.Name, issue2.Index).
  77. AddTokenAuth(token)
  78. MakeRequest(t, req, http.StatusNoContent)
  79. MakeRequest(t, req, http.StatusNotFound)
  80. trackedSeconds, err = issues_model.GetTrackedSeconds(t.Context(), issues_model.FindTrackedTimesOptions{IssueID: 2, UserID: 2})
  81. assert.NoError(t, err)
  82. assert.Equal(t, int64(0), trackedSeconds)
  83. }
  84. func TestAPIAddTrackedTimes(t *testing.T) {
  85. defer tests.PrepareTestEnv(t)()
  86. issue2 := unittest.AssertExistsAndLoadBean(t, &issues_model.Issue{ID: 2})
  87. assert.NoError(t, issue2.LoadRepo(t.Context()))
  88. user2 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
  89. admin := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 1})
  90. session := loginUser(t, admin.Name)
  91. token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeWriteIssue)
  92. urlStr := fmt.Sprintf("/api/v1/repos/%s/%s/issues/%d/times", user2.Name, issue2.Repo.Name, issue2.Index)
  93. req := NewRequestWithJSON(t, "POST", urlStr, &api.AddTimeOption{
  94. Time: 33,
  95. User: user2.Name,
  96. Created: time.Unix(947688818, 0),
  97. }).AddTokenAuth(token)
  98. resp := MakeRequest(t, req, http.StatusOK)
  99. var apiNewTime api.TrackedTime
  100. DecodeJSON(t, resp, &apiNewTime)
  101. assert.EqualValues(t, 33, apiNewTime.Time)
  102. assert.Equal(t, user2.ID, apiNewTime.UserID)
  103. assert.EqualValues(t, 947688818, apiNewTime.Created.Unix())
  104. }