diff options
author | Mura Li <typeless@users.noreply.github.com> | 2017-06-15 19:20:39 +0800 |
---|---|---|
committer | Lunny Xiao <xiaolunwen@gmail.com> | 2017-06-15 19:20:39 +0800 |
commit | 01322af2e8e213209cddff5356b317ce4875fca3 (patch) | |
tree | ed80f658b6bcabdfa341ae529e5491545b586227 /integrations/pull_merge_test.go | |
parent | 13f0e1255af5eeb3d6d24ee2c3a169dab427a2dc (diff) | |
download | gitea-01322af2e8e213209cddff5356b317ce4875fca3.tar.gz gitea-01322af2e8e213209cddff5356b317ce4875fca3.zip |
Add integration test for pull-request merge (#1912)
Diffstat (limited to 'integrations/pull_merge_test.go')
-rw-r--r-- | integrations/pull_merge_test.go | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/integrations/pull_merge_test.go b/integrations/pull_merge_test.go new file mode 100644 index 0000000000..1b9337a673 --- /dev/null +++ b/integrations/pull_merge_test.go @@ -0,0 +1,53 @@ +// Copyright 2017 The Gitea Authors. All rights reserved. +// Use of this source code is governed by a MIT-style +// license that can be found in the LICENSE file. + +package integrations + +import ( + "bytes" + "net/http" + "net/url" + "path" + "strings" + "testing" + + "github.com/stretchr/testify/assert" +) + +func testPullMerge(t *testing.T, session *TestSession, user, repo, pullnum string) *TestResponse { + req := NewRequest(t, "GET", path.Join(user, repo, "pulls", pullnum)) + resp := session.MakeRequest(t, req) + assert.EqualValues(t, http.StatusOK, resp.HeaderCode) + + // Click the little green button to craete a pull + htmlDoc, err := NewHtmlParser(resp.Body) + assert.NoError(t, err) + link, exists := htmlDoc.doc.Find("form.ui.form>button.ui.green.button").Parent().Attr("action") + assert.True(t, exists, "The template has changed") + req = NewRequestBody(t, "POST", link, + bytes.NewBufferString(url.Values{ + "_csrf": []string{htmlDoc.GetInputValueByName("_csrf")}, + }.Encode()), + ) + req.Header.Add("Content-Type", "application/x-www-form-urlencoded") + resp = session.MakeRequest(t, req) + assert.EqualValues(t, http.StatusFound, resp.HeaderCode) + + return resp +} + +func TestPullMerge(t *testing.T) { + prepareTestEnv(t) + session := loginUser(t, "user1", "password") + testRepoFork(t, session) + testEditFile(t, session, "user1", "repo1", "master", "README.md") + + 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], "/") + assert.EqualValues(t, "pulls", elem[3]) + testPullMerge(t, session, elem[1], elem[2], elem[4]) +} |