mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-26 17:11:28 +01:00 
			
		
		
		
	Fix #24623 Major changes: 1. Redirect `/owner/repo/blob/*` requests to `/owner/repo/src/commit/*` (like GitHub) 2. Add a "view file diff" link (see screenshot below) 3. Refactor "AssertHTMLElement" to generic, now we can accurately assert existence or number. 4. Add more tests --------- Co-authored-by: silverwind <me@silverwind.io> Co-authored-by: delvh <dev.lh@web.de>
		
			
				
	
	
		
			68 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2020 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package integration
 | |
| 
 | |
| import (
 | |
| 	"net/http"
 | |
| 	"testing"
 | |
| 
 | |
| 	"code.gitea.io/gitea/tests"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| )
 | |
| 
 | |
| func TestRenderFileSVGIsInImgTag(t *testing.T) {
 | |
| 	defer tests.PrepareTestEnv(t)()
 | |
| 
 | |
| 	session := loginUser(t, "user2")
 | |
| 
 | |
| 	req := NewRequest(t, "GET", "/user2/repo2/src/branch/master/line.svg")
 | |
| 	resp := session.MakeRequest(t, req, http.StatusOK)
 | |
| 
 | |
| 	doc := NewHTMLParser(t, resp.Body)
 | |
| 	src, exists := doc.doc.Find(".file-view img").Attr("src")
 | |
| 	assert.True(t, exists, "The SVG image should be in an <img> tag so that scripts in the SVG are not run")
 | |
| 	assert.Equal(t, "/user2/repo2/raw/branch/master/line.svg", src)
 | |
| }
 | |
| 
 | |
| func TestCommitListActions(t *testing.T) {
 | |
| 	defer tests.PrepareTestEnv(t)()
 | |
| 	session := loginUser(t, "user2")
 | |
| 
 | |
| 	t.Run("WikiRevisionList", func(t *testing.T) {
 | |
| 		defer tests.PrintCurrentTest(t)()
 | |
| 
 | |
| 		req := NewRequest(t, "GET", "/user2/repo1/wiki/Home?action=_revision")
 | |
| 		resp := session.MakeRequest(t, req, http.StatusOK)
 | |
| 		htmlDoc := NewHTMLParser(t, resp.Body)
 | |
| 		AssertHTMLElement(t, htmlDoc, ".commit-list .copy-commit-id", true)
 | |
| 		AssertHTMLElement(t, htmlDoc, `.commit-list .view-single-diff`, false)
 | |
| 		AssertHTMLElement(t, htmlDoc, `.commit-list .view-commit-path`, false)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("RepoCommitList", func(t *testing.T) {
 | |
| 		defer tests.PrintCurrentTest(t)()
 | |
| 
 | |
| 		req := NewRequest(t, "GET", "/user2/repo1/commits/branch/master")
 | |
| 		resp := session.MakeRequest(t, req, http.StatusOK)
 | |
| 		htmlDoc := NewHTMLParser(t, resp.Body)
 | |
| 
 | |
| 		AssertHTMLElement(t, htmlDoc, `.commit-list .copy-commit-id`, true)
 | |
| 		AssertHTMLElement(t, htmlDoc, `.commit-list .view-single-diff`, false)
 | |
| 		AssertHTMLElement(t, htmlDoc, `.commit-list .view-commit-path`, true)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("RepoFileHistory", func(t *testing.T) {
 | |
| 		defer tests.PrintCurrentTest(t)()
 | |
| 
 | |
| 		req := NewRequest(t, "GET", "/user2/repo1/commits/branch/master/README.md")
 | |
| 		resp := session.MakeRequest(t, req, http.StatusOK)
 | |
| 		htmlDoc := NewHTMLParser(t, resp.Body)
 | |
| 
 | |
| 		AssertHTMLElement(t, htmlDoc, `.commit-list .copy-commit-id`, true)
 | |
| 		AssertHTMLElement(t, htmlDoc, `.commit-list .view-single-diff`, true)
 | |
| 		AssertHTMLElement(t, htmlDoc, `.commit-list .view-commit-path`, true)
 | |
| 	})
 | |
| }
 |