From 033aaf4b38931d08926b9c779937577913192aa1 Mon Sep 17 00:00:00 2001 From: Mura Li Date: Thu, 15 Jun 2017 15:01:51 +0800 Subject: [PATCH] Add pull-create integration test (#1972) --- integrations/pull_create_test.go | 56 ++++++++++++++++++++++++++++++++ 1 file changed, 56 insertions(+) create mode 100644 integrations/pull_create_test.go diff --git a/integrations/pull_create_test.go b/integrations/pull_create_test.go new file mode 100644 index 0000000000..953469e605 --- /dev/null +++ b/integrations/pull_create_test.go @@ -0,0 +1,56 @@ +// 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" + "testing" + + "github.com/stretchr/testify/assert" +) + +func testPullCreate(t *testing.T, session *TestSession, user, repo, branch string) { + req := NewRequest(t, "GET", path.Join(user, repo)) + 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("button.ui.green.small.button").Parent().Attr("href") + assert.True(t, exists, "The template has changed") + + req = NewRequest(t, "GET", link) + resp = session.MakeRequest(t, req) + assert.EqualValues(t, http.StatusOK, resp.HeaderCode) + + // Submit the form for creating the pull + htmlDoc, err = NewHtmlParser(resp.Body) + assert.NoError(t, err) + link, exists = htmlDoc.doc.Find("form.ui.form").Attr("action") + assert.True(t, exists, "The template has changed") + req = NewRequestBody(t, "POST", link, + bytes.NewBufferString(url.Values{ + "_csrf": []string{htmlDoc.GetInputValueByName("_csrf")}, + "title": []string{"This is a pull title"}, + }.Encode()), + ) + req.Header.Add("Content-Type", "application/x-www-form-urlencoded") + resp = session.MakeRequest(t, req) + assert.EqualValues(t, http.StatusFound, resp.HeaderCode) + + //TODO check the redirected URL +} + +func TestPullCreate(t *testing.T) { + prepareTestEnv(t) + session := loginUser(t, "user1", "password") + testRepoFork(t, session) + testEditFile(t, session, "user1", "repo1", "master", "README.md") + testPullCreate(t, session, "user1", "repo1", "master") +}