* Helper functions for intergration test boilerplatetags/v1.21.12.1
| @@ -18,7 +18,7 @@ func testAPIGetBranch(t *testing.T, branchName string, exists bool) { | |||||
| session := loginUser(t, "user2") | session := loginUser(t, "user2") | ||||
| req := NewRequestf(t, "GET", "/api/v1/repos/user2/repo1/branches/%s", branchName) | req := NewRequestf(t, "GET", "/api/v1/repos/user2/repo1/branches/%s", branchName) | ||||
| resp := session.MakeRequest(t, req) | |||||
| resp := session.MakeRequest(t, req, NoExpectedStatus) | |||||
| if !exists { | if !exists { | ||||
| assert.EqualValues(t, http.StatusNotFound, resp.HeaderCode) | assert.EqualValues(t, http.StatusNotFound, resp.HeaderCode) | ||||
| return | return | ||||
| @@ -26,8 +26,7 @@ func TestAPIListComments(t *testing.T) { | |||||
| session := loginUser(t, repoOwner.Name) | session := loginUser(t, repoOwner.Name) | ||||
| req := NewRequestf(t, "GET", "/api/v1/repos/%s/%s/issues/%d/comments", | req := NewRequestf(t, "GET", "/api/v1/repos/%s/%s/issues/%d/comments", | ||||
| repoOwner.Name, repo.Name, issue.Index) | repoOwner.Name, repo.Name, issue.Index) | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| var comments []*api.Comment | var comments []*api.Comment | ||||
| DecodeJSON(t, resp, &comments) | DecodeJSON(t, resp, &comments) | ||||
| @@ -29,8 +29,7 @@ func TestAPIAddIssueLabels(t *testing.T) { | |||||
| Labels: []int64{label.ID}, | Labels: []int64{label.ID}, | ||||
| }) | }) | ||||
| session := loginUser(t, owner.Name) | session := loginUser(t, owner.Name) | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| var apiLabels []*api.Label | var apiLabels []*api.Label | ||||
| DecodeJSON(t, resp, &apiLabels) | DecodeJSON(t, resp, &apiLabels) | ||||
| assert.Len(t, apiLabels, models.GetCount(t, &models.IssueLabel{IssueID: issue.ID})) | assert.Len(t, apiLabels, models.GetCount(t, &models.IssueLabel{IssueID: issue.ID})) | ||||
| @@ -52,8 +51,7 @@ func TestAPIReplaceIssueLabels(t *testing.T) { | |||||
| Labels: []int64{label.ID}, | Labels: []int64{label.ID}, | ||||
| }) | }) | ||||
| session := loginUser(t, owner.Name) | session := loginUser(t, owner.Name) | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| var apiLabels []*api.Label | var apiLabels []*api.Label | ||||
| DecodeJSON(t, resp, &apiLabels) | DecodeJSON(t, resp, &apiLabels) | ||||
| assert.Len(t, apiLabels, 1) | assert.Len(t, apiLabels, 1) | ||||
| @@ -24,8 +24,7 @@ func TestAPIListIssues(t *testing.T) { | |||||
| session := loginUser(t, owner.Name) | session := loginUser(t, owner.Name) | ||||
| req := NewRequestf(t, "GET", "/api/v1/repos/%s/%s/issues?state=all", | req := NewRequestf(t, "GET", "/api/v1/repos/%s/%s/issues?state=all", | ||||
| owner.Name, repo.Name) | owner.Name, repo.Name) | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| var apiIssues []*api.Issue | var apiIssues []*api.Issue | ||||
| DecodeJSON(t, resp, &apiIssues) | DecodeJSON(t, resp, &apiIssues) | ||||
| assert.Len(t, apiIssues, models.GetCount(t, &models.Issue{RepoID: repo.ID})) | assert.Len(t, apiIssues, models.GetCount(t, &models.Issue{RepoID: repo.ID})) | ||||
| @@ -49,8 +48,7 @@ func TestAPICreateIssue(t *testing.T) { | |||||
| Title: title, | Title: title, | ||||
| Assignee: owner.Name, | Assignee: owner.Name, | ||||
| }) | }) | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusCreated, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusCreated) | |||||
| var apiIssue api.Issue | var apiIssue api.Issue | ||||
| DecodeJSON(t, resp, &apiIssue) | DecodeJSON(t, resp, &apiIssue) | ||||
| assert.Equal(t, apiIssue.Body, body) | assert.Equal(t, apiIssue.Body, body) | ||||
| @@ -21,8 +21,7 @@ func TestAPIViewPulls(t *testing.T) { | |||||
| session := loginUser(t, "user2") | session := loginUser(t, "user2") | ||||
| req := NewRequestf(t, "GET", "/api/v1/repos/%s/%s/pulls?state=all", owner.Name, repo.Name) | req := NewRequestf(t, "GET", "/api/v1/repos/%s/%s/pulls?state=all", owner.Name, repo.Name) | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| var pulls []*api.PullRequest | var pulls []*api.PullRequest | ||||
| DecodeJSON(t, resp, &pulls) | DecodeJSON(t, resp, &pulls) | ||||
| @@ -7,22 +7,18 @@ package integrations | |||||
| import ( | import ( | ||||
| "net/http" | "net/http" | ||||
| "testing" | "testing" | ||||
| "github.com/stretchr/testify/assert" | |||||
| ) | ) | ||||
| func TestAPIUserReposNotLogin(t *testing.T) { | func TestAPIUserReposNotLogin(t *testing.T) { | ||||
| prepareTestEnv(t) | prepareTestEnv(t) | ||||
| req := NewRequest(t, "GET", "/api/v1/users/user2/repos") | req := NewRequest(t, "GET", "/api/v1/users/user2/repos") | ||||
| resp := MakeRequest(req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| MakeRequest(t, req, http.StatusOK) | |||||
| } | } | ||||
| func TestAPISearchRepoNotLogin(t *testing.T) { | func TestAPISearchRepoNotLogin(t *testing.T) { | ||||
| prepareTestEnv(t) | prepareTestEnv(t) | ||||
| req := NewRequest(t, "GET", "/api/v1/repos/search?q=Test") | req := NewRequest(t, "GET", "/api/v1/repos/search?q=Test") | ||||
| resp := MakeRequest(req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| MakeRequest(t, req, http.StatusOK) | |||||
| } | } | ||||
| @@ -22,8 +22,7 @@ func TestAPITeam(t *testing.T) { | |||||
| session := loginUser(t, user.Name) | session := loginUser(t, user.Name) | ||||
| req := NewRequestf(t, "GET", "/api/v1/teams/%d", teamUser.TeamID) | req := NewRequestf(t, "GET", "/api/v1/teams/%d", teamUser.TeamID) | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| var apiTeam api.Team | var apiTeam api.Team | ||||
| DecodeJSON(t, resp, &apiTeam) | DecodeJSON(t, resp, &apiTeam) | ||||
| @@ -10,8 +10,6 @@ import ( | |||||
| "testing" | "testing" | ||||
| "code.gitea.io/gitea/models" | "code.gitea.io/gitea/models" | ||||
| "github.com/stretchr/testify/assert" | |||||
| ) | ) | ||||
| func TestChangeDefaultBranch(t *testing.T) { | func TestChangeDefaultBranch(t *testing.T) { | ||||
| @@ -22,29 +20,19 @@ func TestChangeDefaultBranch(t *testing.T) { | |||||
| session := loginUser(t, owner.Name) | session := loginUser(t, owner.Name) | ||||
| branchesURL := fmt.Sprintf("/%s/%s/settings/branches", owner.Name, repo.Name) | branchesURL := fmt.Sprintf("/%s/%s/settings/branches", owner.Name, repo.Name) | ||||
| req := NewRequest(t, "GET", branchesURL) | |||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| doc := NewHTMLParser(t, resp.Body) | |||||
| req = NewRequestWithValues(t, "POST", branchesURL, map[string]string{ | |||||
| "_csrf": doc.GetCSRF(), | |||||
| csrf := GetCSRF(t, session, branchesURL) | |||||
| req := NewRequestWithValues(t, "POST", branchesURL, map[string]string{ | |||||
| "_csrf": csrf, | |||||
| "action": "default_branch", | "action": "default_branch", | ||||
| "branch": "DefaultBranch", | "branch": "DefaultBranch", | ||||
| }) | }) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusFound, resp.HeaderCode) | |||||
| req = NewRequest(t, "GET", branchesURL) | |||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| doc = NewHTMLParser(t, resp.Body) | |||||
| session.MakeRequest(t, req, http.StatusFound) | |||||
| csrf = GetCSRF(t, session, branchesURL) | |||||
| req = NewRequestWithValues(t, "POST", branchesURL, map[string]string{ | req = NewRequestWithValues(t, "POST", branchesURL, map[string]string{ | ||||
| "_csrf": doc.GetInputValueByName("_csrf"), | |||||
| "_csrf": csrf, | |||||
| "action": "default_branch", | "action": "default_branch", | ||||
| "branch": "does_not_exist", | "branch": "does_not_exist", | ||||
| }) | }) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusNotFound, resp.HeaderCode) | |||||
| session.MakeRequest(t, req, http.StatusNotFound) | |||||
| } | } | ||||
| @@ -9,8 +9,6 @@ import ( | |||||
| "testing" | "testing" | ||||
| "code.gitea.io/gitea/models" | "code.gitea.io/gitea/models" | ||||
| "github.com/stretchr/testify/assert" | |||||
| ) | ) | ||||
| func TestDeleteUser(t *testing.T) { | func TestDeleteUser(t *testing.T) { | ||||
| @@ -18,16 +16,11 @@ func TestDeleteUser(t *testing.T) { | |||||
| session := loginUser(t, "user1") | session := loginUser(t, "user1") | ||||
| req := NewRequest(t, "GET", "/admin/users/8") | |||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| doc := NewHTMLParser(t, resp.Body) | |||||
| req = NewRequestWithValues(t, "POST", "/admin/users/8/delete", map[string]string{ | |||||
| "_csrf": doc.GetCSRF(), | |||||
| csrf := GetCSRF(t, session, "/admin/users/8") | |||||
| req := NewRequestWithValues(t, "POST", "/admin/users/8/delete", map[string]string{ | |||||
| "_csrf": csrf, | |||||
| }) | }) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| session.MakeRequest(t, req, http.StatusOK) | |||||
| models.AssertNotExistsBean(t, &models.User{ID: 8}) | models.AssertNotExistsBean(t, &models.User{ID: 8}) | ||||
| models.CheckConsistencyFor(t, &models.User{}) | models.CheckConsistencyFor(t, &models.User{}) | ||||
| @@ -19,8 +19,7 @@ func TestCreateFile(t *testing.T) { | |||||
| // Request editor page | // Request editor page | ||||
| req := NewRequest(t, "GET", "/user2/repo1/_new/master/") | req := NewRequest(t, "GET", "/user2/repo1/_new/master/") | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| doc := NewHTMLParser(t, resp.Body) | doc := NewHTMLParser(t, resp.Body) | ||||
| lastCommit := doc.GetInputValueByName("last_commit") | lastCommit := doc.GetInputValueByName("last_commit") | ||||
| @@ -34,8 +33,7 @@ func TestCreateFile(t *testing.T) { | |||||
| "content": "Content", | "content": "Content", | ||||
| "commit_choice": "direct", | "commit_choice": "direct", | ||||
| }) | }) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusFound, resp.HeaderCode) | |||||
| resp = session.MakeRequest(t, req, http.StatusFound) | |||||
| } | } | ||||
| func TestCreateFileOnProtectedBranch(t *testing.T) { | func TestCreateFileOnProtectedBranch(t *testing.T) { | ||||
| @@ -43,21 +41,14 @@ func TestCreateFileOnProtectedBranch(t *testing.T) { | |||||
| session := loginUser(t, "user2") | session := loginUser(t, "user2") | ||||
| // Open repository branch settings | |||||
| req := NewRequest(t, "GET", "/user2/repo1/settings/branches") | |||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| doc := NewHTMLParser(t, resp.Body) | |||||
| csrf := GetCSRF(t, session, "/user2/repo1/settings/branches") | |||||
| // Change master branch to protected | // Change master branch to protected | ||||
| req = NewRequestWithValues(t, "POST", "/user2/repo1/settings/branches?action=protected_branch", map[string]string{ | |||||
| "_csrf": doc.GetCSRF(), | |||||
| req := NewRequestWithValues(t, "POST", "/user2/repo1/settings/branches?action=protected_branch", map[string]string{ | |||||
| "_csrf": csrf, | |||||
| "branchName": "master", | "branchName": "master", | ||||
| "canPush": "true", | "canPush": "true", | ||||
| }) | }) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| // Check if master branch has been locked successfully | // Check if master branch has been locked successfully | ||||
| flashCookie := session.GetCookie("macaron_flash") | flashCookie := session.GetCookie("macaron_flash") | ||||
| assert.NotNil(t, flashCookie) | assert.NotNil(t, flashCookie) | ||||
| @@ -65,10 +56,9 @@ func TestCreateFileOnProtectedBranch(t *testing.T) { | |||||
| // Request editor page | // Request editor page | ||||
| req = NewRequest(t, "GET", "/user2/repo1/_new/master/") | req = NewRequest(t, "GET", "/user2/repo1/_new/master/") | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp = session.MakeRequest(t, req, http.StatusOK) | |||||
| doc = NewHTMLParser(t, resp.Body) | |||||
| doc := NewHTMLParser(t, resp.Body) | |||||
| lastCommit := doc.GetInputValueByName("last_commit") | lastCommit := doc.GetInputValueByName("last_commit") | ||||
| assert.NotEmpty(t, lastCommit) | assert.NotEmpty(t, lastCommit) | ||||
| @@ -81,8 +71,7 @@ func TestCreateFileOnProtectedBranch(t *testing.T) { | |||||
| "commit_choice": "direct", | "commit_choice": "direct", | ||||
| }) | }) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp = session.MakeRequest(t, req, http.StatusOK) | |||||
| // Check body for error message | // Check body for error message | ||||
| assert.Contains(t, string(resp.Body), "Can not commit to protected branch 'master'.") | assert.Contains(t, string(resp.Body), "Can not commit to protected branch 'master'.") | ||||
| } | } | ||||
| @@ -93,8 +82,7 @@ func testEditFile(t *testing.T, session *TestSession, user, repo, branch, filePa | |||||
| // Get to the 'edit this file' page | // Get to the 'edit this file' page | ||||
| req := NewRequest(t, "GET", path.Join(user, repo, "_edit", branch, filePath)) | req := NewRequest(t, "GET", path.Join(user, repo, "_edit", branch, filePath)) | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| htmlDoc := NewHTMLParser(t, resp.Body) | htmlDoc := NewHTMLParser(t, resp.Body) | ||||
| lastCommit := htmlDoc.GetInputValueByName("last_commit") | lastCommit := htmlDoc.GetInputValueByName("last_commit") | ||||
| @@ -110,13 +98,11 @@ func testEditFile(t *testing.T, session *TestSession, user, repo, branch, filePa | |||||
| "commit_choice": "direct", | "commit_choice": "direct", | ||||
| }, | }, | ||||
| ) | ) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusFound, resp.HeaderCode) | |||||
| resp = session.MakeRequest(t, req, http.StatusFound) | |||||
| // Verify the change | // Verify the change | ||||
| req = NewRequest(t, "GET", path.Join(user, repo, "raw", branch, filePath)) | req = NewRequest(t, "GET", path.Join(user, repo, "raw", branch, filePath)) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp = session.MakeRequest(t, req, http.StatusOK) | |||||
| assert.EqualValues(t, newContent, string(resp.Body)) | assert.EqualValues(t, newContent, string(resp.Body)) | ||||
| return resp | return resp | ||||
| @@ -128,8 +114,7 @@ func testEditFileToNewBranch(t *testing.T, session *TestSession, user, repo, bra | |||||
| // Get to the 'edit this file' page | // Get to the 'edit this file' page | ||||
| req := NewRequest(t, "GET", path.Join(user, repo, "_edit", branch, filePath)) | req := NewRequest(t, "GET", path.Join(user, repo, "_edit", branch, filePath)) | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| htmlDoc := NewHTMLParser(t, resp.Body) | htmlDoc := NewHTMLParser(t, resp.Body) | ||||
| lastCommit := htmlDoc.GetInputValueByName("last_commit") | lastCommit := htmlDoc.GetInputValueByName("last_commit") | ||||
| @@ -146,13 +131,11 @@ func testEditFileToNewBranch(t *testing.T, session *TestSession, user, repo, bra | |||||
| "new_branch_name": targetBranch, | "new_branch_name": targetBranch, | ||||
| }, | }, | ||||
| ) | ) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusFound, resp.HeaderCode) | |||||
| resp = session.MakeRequest(t, req, http.StatusFound) | |||||
| // Verify the change | // Verify the change | ||||
| req = NewRequest(t, "GET", path.Join(user, repo, "raw", targetBranch, filePath)) | req = NewRequest(t, "GET", path.Join(user, repo, "raw", targetBranch, filePath)) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp = session.MakeRequest(t, req, http.StatusOK) | |||||
| assert.EqualValues(t, newContent, string(resp.Body)) | assert.EqualValues(t, newContent, string(resp.Body)) | ||||
| return resp | return resp | ||||
| @@ -140,13 +140,13 @@ func (s *TestSession) GetCookie(name string) *http.Cookie { | |||||
| return nil | return nil | ||||
| } | } | ||||
| func (s *TestSession) MakeRequest(t testing.TB, req *http.Request) *TestResponse { | |||||
| func (s *TestSession) MakeRequest(t testing.TB, req *http.Request, expectedStatus int) *TestResponse { | |||||
| baseURL, err := url.Parse(setting.AppURL) | baseURL, err := url.Parse(setting.AppURL) | ||||
| assert.NoError(t, err) | assert.NoError(t, err) | ||||
| for _, c := range s.jar.Cookies(baseURL) { | for _, c := range s.jar.Cookies(baseURL) { | ||||
| req.AddCookie(c) | req.AddCookie(c) | ||||
| } | } | ||||
| resp := MakeRequest(req) | |||||
| resp := MakeRequest(t, req, expectedStatus) | |||||
| ch := http.Header{} | ch := http.Header{} | ||||
| ch.Add("Cookie", strings.Join(resp.Headers["Set-Cookie"], ";")) | ch.Add("Cookie", strings.Join(resp.Headers["Set-Cookie"], ";")) | ||||
| @@ -164,8 +164,7 @@ func loginUser(t testing.TB, userName string) *TestSession { | |||||
| func loginUserWithPassword(t testing.TB, userName, password string) *TestSession { | func loginUserWithPassword(t testing.TB, userName, password string) *TestSession { | ||||
| req := NewRequest(t, "GET", "/user/login") | req := NewRequest(t, "GET", "/user/login") | ||||
| resp := MakeRequest(req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := MakeRequest(t, req, http.StatusOK) | |||||
| doc := NewHTMLParser(t, resp.Body) | doc := NewHTMLParser(t, resp.Body) | ||||
| req = NewRequestWithValues(t, "POST", "/user/login", map[string]string{ | req = NewRequestWithValues(t, "POST", "/user/login", map[string]string{ | ||||
| @@ -173,8 +172,7 @@ func loginUserWithPassword(t testing.TB, userName, password string) *TestSession | |||||
| "user_name": userName, | "user_name": userName, | ||||
| "password": password, | "password": password, | ||||
| }) | }) | ||||
| resp = MakeRequest(req) | |||||
| assert.EqualValues(t, http.StatusFound, resp.HeaderCode) | |||||
| resp = MakeRequest(t, req, http.StatusFound) | |||||
| ch := http.Header{} | ch := http.Header{} | ||||
| ch.Add("Cookie", strings.Join(resp.Headers["Set-Cookie"], ";")) | ch.Add("Cookie", strings.Join(resp.Headers["Set-Cookie"], ";")) | ||||
| @@ -246,13 +244,18 @@ func NewRequestWithBody(t testing.TB, method, urlStr string, body io.Reader) *ht | |||||
| return request | return request | ||||
| } | } | ||||
| func MakeRequest(req *http.Request) *TestResponse { | |||||
| const NoExpectedStatus = -1 | |||||
| func MakeRequest(t testing.TB, req *http.Request, expectedStatus int) *TestResponse { | |||||
| buffer := bytes.NewBuffer(nil) | buffer := bytes.NewBuffer(nil) | ||||
| respWriter := &TestResponseWriter{ | respWriter := &TestResponseWriter{ | ||||
| Writer: buffer, | Writer: buffer, | ||||
| Headers: make(map[string][]string), | Headers: make(map[string][]string), | ||||
| } | } | ||||
| mac.ServeHTTP(respWriter, req) | mac.ServeHTTP(respWriter, req) | ||||
| if expectedStatus != NoExpectedStatus { | |||||
| assert.EqualValues(t, expectedStatus, respWriter.HeaderCode) | |||||
| } | |||||
| return &TestResponse{ | return &TestResponse{ | ||||
| HeaderCode: respWriter.HeaderCode, | HeaderCode: respWriter.HeaderCode, | ||||
| Body: buffer.Bytes(), | Body: buffer.Bytes(), | ||||
| @@ -264,3 +267,16 @@ func DecodeJSON(t testing.TB, resp *TestResponse, v interface{}) { | |||||
| decoder := json.NewDecoder(bytes.NewBuffer(resp.Body)) | decoder := json.NewDecoder(bytes.NewBuffer(resp.Body)) | ||||
| assert.NoError(t, decoder.Decode(v)) | assert.NoError(t, decoder.Decode(v)) | ||||
| } | } | ||||
| func GetCSRF(t testing.TB, session *TestSession, urlStr string) string { | |||||
| req := NewRequest(t, "GET", urlStr) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| doc := NewHTMLParser(t, resp.Body) | |||||
| return doc.GetCSRF() | |||||
| } | |||||
| func RedirectURL(t testing.TB, resp *TestResponse) string { | |||||
| urlSlice := resp.Headers["Location"] | |||||
| assert.NotEmpty(t, urlSlice, "No redirect URL founds") | |||||
| return urlSlice[0] | |||||
| } | |||||
| @@ -23,9 +23,9 @@ func assertProtectedBranch(t *testing.T, repoID int64, branchName string, isErr, | |||||
| t.Log(reqURL) | t.Log(reqURL) | ||||
| req.Header.Add("Authorization", fmt.Sprintf("Bearer %s", setting.InternalToken)) | req.Header.Add("Authorization", fmt.Sprintf("Bearer %s", setting.InternalToken)) | ||||
| resp := MakeRequest(req) | |||||
| resp := MakeRequest(t, req, NoExpectedStatus) | |||||
| if isErr { | if isErr { | ||||
| assert.EqualValues(t, 500, resp.HeaderCode) | |||||
| assert.EqualValues(t, http.StatusInternalServerError, resp.HeaderCode) | |||||
| } else { | } else { | ||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | ||||
| var branch models.ProtectedBranch | var branch models.ProtectedBranch | ||||
| @@ -35,8 +35,7 @@ func TestNoLoginViewIssues(t *testing.T) { | |||||
| prepareTestEnv(t) | prepareTestEnv(t) | ||||
| req := NewRequest(t, "GET", "/user2/repo1/issues") | req := NewRequest(t, "GET", "/user2/repo1/issues") | ||||
| resp := MakeRequest(req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| MakeRequest(t, req, http.StatusOK) | |||||
| } | } | ||||
| func TestNoLoginViewIssuesSortByType(t *testing.T) { | func TestNoLoginViewIssuesSortByType(t *testing.T) { | ||||
| @@ -48,8 +47,7 @@ func TestNoLoginViewIssuesSortByType(t *testing.T) { | |||||
| session := loginUser(t, user.Name) | session := loginUser(t, user.Name) | ||||
| req := NewRequest(t, "GET", repo.RelLink()+"/issues?type=created_by") | req := NewRequest(t, "GET", repo.RelLink()+"/issues?type=created_by") | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| htmlDoc := NewHTMLParser(t, resp.Body) | htmlDoc := NewHTMLParser(t, resp.Body) | ||||
| issuesSelection := getIssuesSelection(htmlDoc) | issuesSelection := getIssuesSelection(htmlDoc) | ||||
| @@ -73,15 +71,13 @@ func TestNoLoginViewIssue(t *testing.T) { | |||||
| prepareTestEnv(t) | prepareTestEnv(t) | ||||
| req := NewRequest(t, "GET", "/user2/repo1/issues/1") | req := NewRequest(t, "GET", "/user2/repo1/issues/1") | ||||
| resp := MakeRequest(req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| MakeRequest(t, req, http.StatusOK) | |||||
| } | } | ||||
| func testNewIssue(t *testing.T, session *TestSession, user, repo, title string) { | func testNewIssue(t *testing.T, session *TestSession, user, repo, title string) { | ||||
| req := NewRequest(t, "GET", path.Join(user, repo, "issues", "new")) | req := NewRequest(t, "GET", path.Join(user, repo, "issues", "new")) | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| htmlDoc := NewHTMLParser(t, resp.Body) | htmlDoc := NewHTMLParser(t, resp.Body) | ||||
| link, exists := htmlDoc.doc.Find("form.ui.form").Attr("action") | link, exists := htmlDoc.doc.Find("form.ui.form").Attr("action") | ||||
| @@ -90,14 +86,10 @@ func testNewIssue(t *testing.T, session *TestSession, user, repo, title string) | |||||
| "_csrf": htmlDoc.GetCSRF(), | "_csrf": htmlDoc.GetCSRF(), | ||||
| "title": title, | "title": title, | ||||
| }) | }) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusFound, resp.HeaderCode) | |||||
| redirectedURL := resp.Headers["Location"] | |||||
| assert.NotEmpty(t, redirectedURL, "Redirected URL is not found") | |||||
| req = NewRequest(t, "GET", redirectedURL[0]) | |||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp = session.MakeRequest(t, req, http.StatusFound) | |||||
| req = NewRequest(t, "GET", RedirectURL(t, resp)) | |||||
| resp = session.MakeRequest(t, req, http.StatusOK) | |||||
| } | } | ||||
| func TestNewIssue(t *testing.T) { | func TestNewIssue(t *testing.T) { | ||||
| @@ -16,13 +16,12 @@ func TestPullCompare(t *testing.T) { | |||||
| session := loginUser(t, "user2") | session := loginUser(t, "user2") | ||||
| req := NewRequest(t, "GET", "/user2/repo1/pulls") | req := NewRequest(t, "GET", "/user2/repo1/pulls") | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| htmlDoc := NewHTMLParser(t, resp.Body) | htmlDoc := NewHTMLParser(t, resp.Body) | ||||
| link, exists := htmlDoc.doc.Find(".navbar").Find(".ui.green.button").Attr("href") | link, exists := htmlDoc.doc.Find(".navbar").Find(".ui.green.button").Attr("href") | ||||
| assert.True(t, exists, "The template has changed") | assert.True(t, exists, "The template has changed") | ||||
| req = NewRequest(t, "GET", link) | req = NewRequest(t, "GET", link) | ||||
| resp = session.MakeRequest(t, req) | |||||
| resp = session.MakeRequest(t, req, http.StatusOK) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | ||||
| } | } | ||||
| @@ -15,8 +15,7 @@ import ( | |||||
| func testPullCreate(t *testing.T, session *TestSession, user, repo, branch string) *TestResponse { | func testPullCreate(t *testing.T, session *TestSession, user, repo, branch string) *TestResponse { | ||||
| req := NewRequest(t, "GET", path.Join(user, repo)) | req := NewRequest(t, "GET", path.Join(user, repo)) | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| // Click the little green button to create a pull | // Click the little green button to create a pull | ||||
| htmlDoc := NewHTMLParser(t, resp.Body) | htmlDoc := NewHTMLParser(t, resp.Body) | ||||
| @@ -27,8 +26,7 @@ func testPullCreate(t *testing.T, session *TestSession, user, repo, branch strin | |||||
| } | } | ||||
| req = NewRequest(t, "GET", link) | req = NewRequest(t, "GET", link) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp = session.MakeRequest(t, req, http.StatusOK) | |||||
| // Submit the form for creating the pull | // Submit the form for creating the pull | ||||
| htmlDoc = NewHTMLParser(t, resp.Body) | htmlDoc = NewHTMLParser(t, resp.Body) | ||||
| @@ -38,8 +36,7 @@ func testPullCreate(t *testing.T, session *TestSession, user, repo, branch strin | |||||
| "_csrf": htmlDoc.GetCSRF(), | "_csrf": htmlDoc.GetCSRF(), | ||||
| "title": "This is a pull title", | "title": "This is a pull title", | ||||
| }) | }) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusFound, resp.HeaderCode) | |||||
| resp = session.MakeRequest(t, req, http.StatusFound) | |||||
| //TODO check the redirected URL | //TODO check the redirected URL | ||||
| @@ -15,36 +15,32 @@ import ( | |||||
| func testPullMerge(t *testing.T, session *TestSession, user, repo, pullnum string) *TestResponse { | func testPullMerge(t *testing.T, session *TestSession, user, repo, pullnum string) *TestResponse { | ||||
| req := NewRequest(t, "GET", path.Join(user, repo, "pulls", pullnum)) | req := NewRequest(t, "GET", path.Join(user, repo, "pulls", pullnum)) | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| // Click the little green button to craete a pull | |||||
| // Click the little green button to create a pull | |||||
| htmlDoc := NewHTMLParser(t, resp.Body) | htmlDoc := NewHTMLParser(t, resp.Body) | ||||
| link, exists := htmlDoc.doc.Find("form.ui.form>button.ui.green.button").Parent().Attr("action") | link, exists := htmlDoc.doc.Find("form.ui.form>button.ui.green.button").Parent().Attr("action") | ||||
| assert.True(t, exists, "The template has changed") | assert.True(t, exists, "The template has changed") | ||||
| req = NewRequestWithValues(t, "POST", link, map[string]string{ | req = NewRequestWithValues(t, "POST", link, map[string]string{ | ||||
| "_csrf": htmlDoc.GetCSRF(), | "_csrf": htmlDoc.GetCSRF(), | ||||
| }) | }) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusFound, resp.HeaderCode) | |||||
| resp = session.MakeRequest(t, req, http.StatusFound) | |||||
| return resp | return resp | ||||
| } | } | ||||
| func testPullCleanUp(t *testing.T, session *TestSession, user, repo, pullnum string) *TestResponse { | func testPullCleanUp(t *testing.T, session *TestSession, user, repo, pullnum string) *TestResponse { | ||||
| req := NewRequest(t, "GET", path.Join(user, repo, "pulls", pullnum)) | req := NewRequest(t, "GET", path.Join(user, repo, "pulls", pullnum)) | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| // Click the little green button to craete a pull | |||||
| // Click the little green button to create a pull | |||||
| htmlDoc := NewHTMLParser(t, resp.Body) | htmlDoc := NewHTMLParser(t, resp.Body) | ||||
| link, exists := htmlDoc.doc.Find(".comments .merge .delete-button").Attr("data-url") | link, exists := htmlDoc.doc.Find(".comments .merge .delete-button").Attr("data-url") | ||||
| assert.True(t, exists, "The template has changed") | assert.True(t, exists, "The template has changed") | ||||
| req = NewRequestWithValues(t, "POST", link, map[string]string{ | req = NewRequestWithValues(t, "POST", link, map[string]string{ | ||||
| "_csrf": htmlDoc.GetCSRF(), | "_csrf": htmlDoc.GetCSRF(), | ||||
| }) | }) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp = session.MakeRequest(t, req, http.StatusOK) | |||||
| return resp | return resp | ||||
| } | } | ||||
| @@ -56,10 +52,8 @@ func TestPullMerge(t *testing.T) { | |||||
| testEditFile(t, session, "user1", "repo1", "master", "README.md") | testEditFile(t, session, "user1", "repo1", "master", "README.md") | ||||
| resp := testPullCreate(t, session, "user1", "repo1", "master") | resp := testPullCreate(t, session, "user1", "repo1", "master") | ||||
| redirectedURL := resp.Headers["Location"] | |||||
| assert.NotEmpty(t, redirectedURL, "Redirected URL is not found") | |||||
| elem := strings.Split(redirectedURL[0], "/") | |||||
| elem := strings.Split(RedirectURL(t, resp), "/") | |||||
| assert.EqualValues(t, "pulls", elem[3]) | assert.EqualValues(t, "pulls", elem[3]) | ||||
| testPullMerge(t, session, elem[1], elem[2], elem[4]) | testPullMerge(t, session, elem[1], elem[2], elem[4]) | ||||
| } | } | ||||
| @@ -71,10 +65,8 @@ func TestPullCleanUpAfterMerge(t *testing.T) { | |||||
| testEditFileToNewBranch(t, session, "user1", "repo1", "master", "feature/test", "README.md") | testEditFileToNewBranch(t, session, "user1", "repo1", "master", "feature/test", "README.md") | ||||
| resp := testPullCreate(t, session, "user1", "repo1", "feature/test") | resp := testPullCreate(t, session, "user1", "repo1", "feature/test") | ||||
| redirectedURL := resp.Headers["Location"] | |||||
| assert.NotEmpty(t, redirectedURL, "Redirected URL is not found") | |||||
| elem := strings.Split(redirectedURL[0], "/") | |||||
| elem := strings.Split(RedirectURL(t, resp), "/") | |||||
| assert.EqualValues(t, "pulls", elem[3]) | assert.EqualValues(t, "pulls", elem[3]) | ||||
| testPullMerge(t, session, elem[1], elem[2], elem[4]) | testPullMerge(t, session, elem[1], elem[2], elem[4]) | ||||
| @@ -92,8 +84,7 @@ func TestPullCleanUpAfterMerge(t *testing.T) { | |||||
| // Check branch deletion result | // Check branch deletion result | ||||
| req := NewRequest(t, "GET", respJSON.Redirect) | req := NewRequest(t, "GET", respJSON.Redirect) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp = session.MakeRequest(t, req, http.StatusOK) | |||||
| htmlDoc := NewHTMLParser(t, resp.Body) | htmlDoc := NewHTMLParser(t, resp.Body) | ||||
| resultMsg := htmlDoc.doc.Find(".ui.message>p").Text() | resultMsg := htmlDoc.doc.Find(".ui.message>p").Text() | ||||
| @@ -15,8 +15,7 @@ import ( | |||||
| func createNewRelease(t *testing.T, session *TestSession, repoURL, tag, title string, preRelease, draft bool) { | func createNewRelease(t *testing.T, session *TestSession, repoURL, tag, title string, preRelease, draft bool) { | ||||
| req := NewRequest(t, "GET", repoURL+"/releases/new") | req := NewRequest(t, "GET", repoURL+"/releases/new") | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| htmlDoc := NewHTMLParser(t, resp.Body) | htmlDoc := NewHTMLParser(t, resp.Body) | ||||
| link, exists := htmlDoc.doc.Find("form").Attr("action") | link, exists := htmlDoc.doc.Find("form").Attr("action") | ||||
| @@ -37,17 +36,14 @@ func createNewRelease(t *testing.T, session *TestSession, repoURL, tag, title st | |||||
| } | } | ||||
| req = NewRequestWithValues(t, "POST", link, postData) | req = NewRequestWithValues(t, "POST", link, postData) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusFound, resp.HeaderCode) | |||||
| resp = session.MakeRequest(t, req, http.StatusFound) | |||||
| redirectedURL := resp.Headers["Location"] | |||||
| assert.NotEmpty(t, redirectedURL, "Redirected URL is not found") | |||||
| RedirectURL(t, resp) // check that redirect URL exists | |||||
| } | } | ||||
| func checkLatestReleaseAndCount(t *testing.T, session *TestSession, repoURL, version, label string, count int) { | func checkLatestReleaseAndCount(t *testing.T, session *TestSession, repoURL, version, label string, count int) { | ||||
| req := NewRequest(t, "GET", repoURL+"/releases") | req := NewRequest(t, "GET", repoURL+"/releases") | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| htmlDoc := NewHTMLParser(t, resp.Body) | htmlDoc := NewHTMLParser(t, resp.Body) | ||||
| labelText := htmlDoc.doc.Find("#release-list > li .meta .label").First().Text() | labelText := htmlDoc.doc.Find("#release-list > li .meta .label").First().Text() | ||||
| @@ -64,16 +60,14 @@ func TestViewReleases(t *testing.T) { | |||||
| session := loginUser(t, "user2") | session := loginUser(t, "user2") | ||||
| req := NewRequest(t, "GET", "/user2/repo1/releases") | req := NewRequest(t, "GET", "/user2/repo1/releases") | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| session.MakeRequest(t, req, http.StatusOK) | |||||
| } | } | ||||
| func TestViewReleasesNoLogin(t *testing.T) { | func TestViewReleasesNoLogin(t *testing.T) { | ||||
| prepareTestEnv(t) | prepareTestEnv(t) | ||||
| req := NewRequest(t, "GET", "/user2/repo1/releases") | req := NewRequest(t, "GET", "/user2/repo1/releases") | ||||
| resp := MakeRequest(req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| MakeRequest(t, req, http.StatusOK) | |||||
| } | } | ||||
| func TestCreateRelease(t *testing.T) { | func TestCreateRelease(t *testing.T) { | ||||
| @@ -21,8 +21,7 @@ func TestRepoCommits(t *testing.T) { | |||||
| // Request repository commits page | // Request repository commits page | ||||
| req := NewRequest(t, "GET", "/user2/repo1/commits/master") | req := NewRequest(t, "GET", "/user2/repo1/commits/master") | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| doc := NewHTMLParser(t, resp.Body) | doc := NewHTMLParser(t, resp.Body) | ||||
| commitURL, exists := doc.doc.Find("#commits-table tbody tr td.sha a").Attr("href") | commitURL, exists := doc.doc.Find("#commits-table tbody tr td.sha a").Attr("href") | ||||
| @@ -37,8 +36,7 @@ func doTestRepoCommitWithStatus(t *testing.T, state string, classes ...string) { | |||||
| // Request repository commits page | // Request repository commits page | ||||
| req := NewRequest(t, "GET", "/user2/repo1/commits/master") | req := NewRequest(t, "GET", "/user2/repo1/commits/master") | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| doc := NewHTMLParser(t, resp.Body) | doc := NewHTMLParser(t, resp.Body) | ||||
| // Get first commit URL | // Get first commit URL | ||||
| @@ -56,12 +54,10 @@ func doTestRepoCommitWithStatus(t *testing.T, state string, classes ...string) { | |||||
| }, | }, | ||||
| ) | ) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusCreated, resp.HeaderCode) | |||||
| resp = session.MakeRequest(t, req, http.StatusCreated) | |||||
| req = NewRequest(t, "GET", "/user2/repo1/commits/master") | req = NewRequest(t, "GET", "/user2/repo1/commits/master") | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp = session.MakeRequest(t, req, http.StatusOK) | |||||
| doc = NewHTMLParser(t, resp.Body) | doc = NewHTMLParser(t, resp.Body) | ||||
| // Check if commit status is displayed in message column | // Check if commit status is displayed in message column | ||||
| @@ -14,21 +14,18 @@ import ( | |||||
| func testRepoFork(t *testing.T, session *TestSession) *TestResponse { | func testRepoFork(t *testing.T, session *TestSession) *TestResponse { | ||||
| // Step0: check the existence of the to-fork repo | // Step0: check the existence of the to-fork repo | ||||
| req := NewRequest(t, "GET", "/user1/repo1") | req := NewRequest(t, "GET", "/user1/repo1") | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusNotFound, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusNotFound) | |||||
| // Step1: go to the main page of repo | // Step1: go to the main page of repo | ||||
| req = NewRequest(t, "GET", "/user2/repo1") | req = NewRequest(t, "GET", "/user2/repo1") | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp = session.MakeRequest(t, req, http.StatusOK) | |||||
| // Step2: click the fork button | // Step2: click the fork button | ||||
| htmlDoc := NewHTMLParser(t, resp.Body) | htmlDoc := NewHTMLParser(t, resp.Body) | ||||
| link, exists := htmlDoc.doc.Find("a.ui.button[href^=\"/repo/fork/\"]").Attr("href") | link, exists := htmlDoc.doc.Find("a.ui.button[href^=\"/repo/fork/\"]").Attr("href") | ||||
| assert.True(t, exists, "The template has changed") | assert.True(t, exists, "The template has changed") | ||||
| req = NewRequest(t, "GET", link) | req = NewRequest(t, "GET", link) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp = session.MakeRequest(t, req, http.StatusOK) | |||||
| // Step3: fill the form of the forking | // Step3: fill the form of the forking | ||||
| htmlDoc = NewHTMLParser(t, resp.Body) | htmlDoc = NewHTMLParser(t, resp.Body) | ||||
| @@ -39,13 +36,11 @@ func testRepoFork(t *testing.T, session *TestSession) *TestResponse { | |||||
| "uid": "1", | "uid": "1", | ||||
| "repo_name": "repo1", | "repo_name": "repo1", | ||||
| }) | }) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusFound, resp.HeaderCode) | |||||
| resp = session.MakeRequest(t, req, http.StatusFound) | |||||
| // Step4: check the existence of the forked repo | // Step4: check the existence of the forked repo | ||||
| req = NewRequest(t, "GET", "/user1/repo1") | req = NewRequest(t, "GET", "/user1/repo1") | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp = session.MakeRequest(t, req, http.StatusOK) | |||||
| return resp | return resp | ||||
| } | } | ||||
| @@ -13,8 +13,7 @@ import ( | |||||
| func testRepoMigrate(t testing.TB, session *TestSession, cloneAddr, repoName string) *TestResponse { | func testRepoMigrate(t testing.TB, session *TestSession, cloneAddr, repoName string) *TestResponse { | ||||
| req := NewRequest(t, "GET", "/repo/migrate") | req := NewRequest(t, "GET", "/repo/migrate") | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| htmlDoc := NewHTMLParser(t, resp.Body) | htmlDoc := NewHTMLParser(t, resp.Body) | ||||
| link, exists := htmlDoc.doc.Find("form.ui.form").Attr("action") | link, exists := htmlDoc.doc.Find("form.ui.form").Attr("action") | ||||
| @@ -30,8 +29,7 @@ func testRepoMigrate(t testing.TB, session *TestSession, cloneAddr, repoName str | |||||
| "repo_name": repoName, | "repo_name": repoName, | ||||
| }, | }, | ||||
| ) | ) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusFound, resp.HeaderCode) | |||||
| resp = session.MakeRequest(t, req, http.StatusFound) | |||||
| return resp | return resp | ||||
| } | } | ||||
| @@ -7,24 +7,19 @@ package integrations | |||||
| import ( | import ( | ||||
| "net/http" | "net/http" | ||||
| "testing" | "testing" | ||||
| "github.com/stretchr/testify/assert" | |||||
| ) | ) | ||||
| func TestViewRepo(t *testing.T) { | func TestViewRepo(t *testing.T) { | ||||
| prepareTestEnv(t) | prepareTestEnv(t) | ||||
| req := NewRequest(t, "GET", "/user2/repo1") | req := NewRequest(t, "GET", "/user2/repo1") | ||||
| resp := MakeRequest(req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| MakeRequest(t, req, http.StatusOK) | |||||
| req = NewRequest(t, "GET", "/user3/repo3") | req = NewRequest(t, "GET", "/user3/repo3") | ||||
| resp = MakeRequest(req) | |||||
| assert.EqualValues(t, http.StatusNotFound, resp.HeaderCode) | |||||
| MakeRequest(t, req, http.StatusNotFound) | |||||
| session := loginUser(t, "user1") | session := loginUser(t, "user1") | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusNotFound, resp.HeaderCode) | |||||
| session.MakeRequest(t, req, http.StatusNotFound) | |||||
| } | } | ||||
| func TestViewRepo2(t *testing.T) { | func TestViewRepo2(t *testing.T) { | ||||
| @@ -32,8 +27,7 @@ func TestViewRepo2(t *testing.T) { | |||||
| req := NewRequest(t, "GET", "/user3/repo3") | req := NewRequest(t, "GET", "/user3/repo3") | ||||
| session := loginUser(t, "user2") | session := loginUser(t, "user2") | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| session.MakeRequest(t, req, http.StatusOK) | |||||
| } | } | ||||
| func TestViewRepo3(t *testing.T) { | func TestViewRepo3(t *testing.T) { | ||||
| @@ -41,6 +35,5 @@ func TestViewRepo3(t *testing.T) { | |||||
| req := NewRequest(t, "GET", "/user3/repo3") | req := NewRequest(t, "GET", "/user3/repo3") | ||||
| session := loginUser(t, "user3") | session := loginUser(t, "user3") | ||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| session.MakeRequest(t, req, http.StatusOK) | |||||
| } | } | ||||
| @@ -9,8 +9,6 @@ import ( | |||||
| "testing" | "testing" | ||||
| "code.gitea.io/gitea/modules/setting" | "code.gitea.io/gitea/modules/setting" | ||||
| "github.com/stretchr/testify/assert" | |||||
| ) | ) | ||||
| func TestSignup(t *testing.T) { | func TestSignup(t *testing.T) { | ||||
| @@ -24,11 +22,9 @@ func TestSignup(t *testing.T) { | |||||
| "password": "examplePassword", | "password": "examplePassword", | ||||
| "retype": "examplePassword", | "retype": "examplePassword", | ||||
| }) | }) | ||||
| resp := MakeRequest(req) | |||||
| assert.EqualValues(t, http.StatusFound, resp.HeaderCode) | |||||
| MakeRequest(t, req, http.StatusFound) | |||||
| // should be able to view new user's page | // should be able to view new user's page | ||||
| req = NewRequest(t, "GET", "/exampleUser") | req = NewRequest(t, "GET", "/exampleUser") | ||||
| resp = MakeRequest(req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| MakeRequest(t, req, http.StatusOK) | |||||
| } | } | ||||
| @@ -18,27 +18,19 @@ func TestViewUser(t *testing.T) { | |||||
| prepareTestEnv(t) | prepareTestEnv(t) | ||||
| req := NewRequest(t, "GET", "/user2") | req := NewRequest(t, "GET", "/user2") | ||||
| resp := MakeRequest(req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| MakeRequest(t, req, http.StatusOK) | |||||
| } | } | ||||
| func TestRenameUsername(t *testing.T) { | func TestRenameUsername(t *testing.T) { | ||||
| prepareTestEnv(t) | prepareTestEnv(t) | ||||
| session := loginUser(t, "user2") | session := loginUser(t, "user2") | ||||
| req := NewRequest(t, "GET", "/user/settings") | |||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| htmlDoc := NewHTMLParser(t, resp.Body) | |||||
| req = NewRequestWithValues(t, "POST", "/user/settings", map[string]string{ | |||||
| "_csrf": htmlDoc.GetCSRF(), | |||||
| req := NewRequestWithValues(t, "POST", "/user/settings", map[string]string{ | |||||
| "_csrf": GetCSRF(t, session, "/user/settings"), | |||||
| "name": "newUsername", | "name": "newUsername", | ||||
| "email": "user2@example.com", | "email": "user2@example.com", | ||||
| }) | }) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusFound, resp.HeaderCode) | |||||
| session.MakeRequest(t, req, http.StatusFound) | |||||
| models.AssertExistsAndLoadBean(t, &models.User{Name: "newUsername"}) | models.AssertExistsAndLoadBean(t, &models.User{Name: "newUsername"}) | ||||
| models.AssertNotExistsBean(t, &models.User{Name: "user2"}) | models.AssertNotExistsBean(t, &models.User{Name: "user2"}) | ||||
| @@ -58,19 +50,14 @@ func TestRenameInvalidUsername(t *testing.T) { | |||||
| session := loginUser(t, "user2") | session := loginUser(t, "user2") | ||||
| for _, invalidUsername := range invalidUsernames { | for _, invalidUsername := range invalidUsernames { | ||||
| t.Logf("Testing username %s", invalidUsername) | t.Logf("Testing username %s", invalidUsername) | ||||
| req := NewRequest(t, "GET", "/user/settings") | |||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| htmlDoc := NewHTMLParser(t, resp.Body) | |||||
| req = NewRequestWithValues(t, "POST", "/user/settings", map[string]string{ | |||||
| "_csrf": htmlDoc.GetCSRF(), | |||||
| req := NewRequestWithValues(t, "POST", "/user/settings", map[string]string{ | |||||
| "_csrf": GetCSRF(t, session, "/user/settings"), | |||||
| "name": invalidUsername, | "name": invalidUsername, | ||||
| "email": "user2@example.com", | "email": "user2@example.com", | ||||
| }) | }) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| htmlDoc = NewHTMLParser(t, resp.Body) | |||||
| resp := session.MakeRequest(t, req, http.StatusOK) | |||||
| htmlDoc := NewHTMLParser(t, resp.Body) | |||||
| assert.Contains(t, | assert.Contains(t, | ||||
| htmlDoc.doc.Find(".ui.negative.message").Text(), | htmlDoc.doc.Find(".ui.negative.message").Text(), | ||||
| i18n.Tr("en", "form.alpha_dash_dot_error"), | i18n.Tr("en", "form.alpha_dash_dot_error"), | ||||
| @@ -92,23 +79,16 @@ func TestRenameReservedUsername(t *testing.T) { | |||||
| session := loginUser(t, "user2") | session := loginUser(t, "user2") | ||||
| for _, reservedUsername := range reservedUsernames { | for _, reservedUsername := range reservedUsernames { | ||||
| t.Logf("Testing username %s", reservedUsername) | t.Logf("Testing username %s", reservedUsername) | ||||
| req := NewRequest(t, "GET", "/user/settings") | |||||
| resp := session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| htmlDoc := NewHTMLParser(t, resp.Body) | |||||
| req = NewRequestWithValues(t, "POST", "/user/settings", map[string]string{ | |||||
| "_csrf": htmlDoc.GetCSRF(), | |||||
| req := NewRequestWithValues(t, "POST", "/user/settings", map[string]string{ | |||||
| "_csrf": GetCSRF(t, session, "/user/settings"), | |||||
| "name": reservedUsername, | "name": reservedUsername, | ||||
| "email": "user2@example.com", | "email": "user2@example.com", | ||||
| }) | }) | ||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusFound, resp.HeaderCode) | |||||
| resp := session.MakeRequest(t, req, http.StatusFound) | |||||
| req = NewRequest(t, "GET", "/user/settings") | |||||
| resp = session.MakeRequest(t, req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| htmlDoc = NewHTMLParser(t, resp.Body) | |||||
| req = NewRequest(t, "GET", RedirectURL(t, resp)) | |||||
| resp = session.MakeRequest(t, req, http.StatusOK) | |||||
| htmlDoc := NewHTMLParser(t, resp.Body) | |||||
| assert.Contains(t, | assert.Contains(t, | ||||
| htmlDoc.doc.Find(".ui.negative.message").Text(), | htmlDoc.doc.Find(".ui.negative.message").Text(), | ||||
| i18n.Tr("en", "user.newName_reserved"), | i18n.Tr("en", "user.newName_reserved"), | ||||
| @@ -19,8 +19,7 @@ func TestVersion(t *testing.T) { | |||||
| setting.AppVer = "1.1.0+dev" | setting.AppVer = "1.1.0+dev" | ||||
| req := NewRequest(t, "GET", "/api/v1/version") | req := NewRequest(t, "GET", "/api/v1/version") | ||||
| resp := MakeRequest(req) | |||||
| assert.EqualValues(t, http.StatusOK, resp.HeaderCode) | |||||
| resp := MakeRequest(t, req, http.StatusOK) | |||||
| var version gitea.ServerVersion | var version gitea.ServerVersion | ||||
| DecodeJSON(t, resp, &version) | DecodeJSON(t, resp, &version) | ||||