loading up the forgejo repo on tangled to test page performance
1// Copyright 2019 The Gitea Authors. All rights reserved.
2// SPDX-License-Identifier: MIT
3
4package integration
5
6import (
7 "net/http"
8 "testing"
9
10 "forgejo.org/tests"
11
12 "github.com/PuerkitoBio/goquery"
13 "github.com/stretchr/testify/assert"
14)
15
16func TestPullDiff_CompletePRDiff(t *testing.T) {
17 doTestPRDiff(t, "/user2/commitsonpr/pulls/1/files", false, []string{"test1.txt", "test10.txt", "test2.txt", "test3.txt", "test4.txt", "test5.txt", "test6.txt", "test7.txt", "test8.txt", "test9.txt"})
18}
19
20func TestPullDiff_SingleCommitPRDiff(t *testing.T) {
21 doTestPRDiff(t, "/user2/commitsonpr/pulls/1/commits/c5626fc9eff57eb1bb7b796b01d4d0f2f3f792a2", true, []string{"test3.txt"})
22}
23
24func TestPullDiff_CommitRangePRDiff(t *testing.T) {
25 doTestPRDiff(t, "/user2/commitsonpr/pulls/1/files/4ca8bcaf27e28504df7bf996819665986b01c847..23576dd018294e476c06e569b6b0f170d0558705", true, []string{"test2.txt", "test3.txt", "test4.txt"})
26}
27
28func TestPullDiff_StartingFromBaseToCommitPRDiff(t *testing.T) {
29 doTestPRDiff(t, "/user2/commitsonpr/pulls/1/files/c5626fc9eff57eb1bb7b796b01d4d0f2f3f792a2", true, []string{"test1.txt", "test2.txt", "test3.txt"})
30}
31
32func doTestPRDiff(t *testing.T, prDiffURL string, reviewBtnDisabled bool, expectedFilenames []string) {
33 defer tests.PrepareTestEnv(t)()
34
35 session := loginUser(t, "user2")
36
37 req := NewRequest(t, "GET", "/user2/commitsonpr/pulls")
38 session.MakeRequest(t, req, http.StatusOK)
39
40 // Get the given PR diff url
41 req = NewRequest(t, "GET", prDiffURL)
42 resp := session.MakeRequest(t, req, http.StatusOK)
43 doc := NewHTMLParser(t, resp.Body)
44
45 // Assert all files are visible.
46 fileContents := doc.doc.Find(".file-content")
47 numberOfFiles := fileContents.Length()
48
49 assert.Equal(t, len(expectedFilenames), numberOfFiles)
50
51 fileContents.Each(func(i int, s *goquery.Selection) {
52 filename, _ := s.Attr("data-old-filename")
53 assert.Equal(t, expectedFilenames[i], filename)
54 })
55
56 // Ensure the review button is enabled for full PR reviews
57 assert.Equal(t, reviewBtnDisabled, doc.doc.Find(".js-btn-review").HasClass("disabled"))
58}