mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-25 19:42:38 +00:00 
			
		
		
		
	Merge pull request '[v7.0/forgejo] Fix panic on too high page number' (#4623) from gusted/forgejo-commit-panic-bp-bp into v7.0/forgejo
Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/4623 Reviewed-by: twenty-panda <twenty-panda@noreply.codeberg.org>
This commit is contained in:
		
				commit
				
					
						8d8cd3aad8
					
				
			
		
					 2 changed files with 24 additions and 0 deletions
				
			
		|  | @ -244,6 +244,12 @@ func FileHistory(ctx *context.Context) { | ||||||
| 		ctx.ServerError("CommitsByFileAndRange", err) | 		ctx.ServerError("CommitsByFileAndRange", err) | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
|  | 	if len(commits) == 0 { | ||||||
|  | 		ctx.NotFound("CommitsByFileAndRange", nil) | ||||||
|  | 		return | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	oldestCommit := commits[len(commits)-1] | 	oldestCommit := commits[len(commits)-1] | ||||||
| 
 | 
 | ||||||
| 	renamedFiles, err := git.GetCommitFileRenames(ctx, ctx.Repo.GitRepo.Path, oldestCommit.ID.String()) | 	renamedFiles, err := git.GetCommitFileRenames(ctx, ctx.Repo.GitRepo.Path, oldestCommit.ID.String()) | ||||||
|  |  | ||||||
|  | @ -995,3 +995,21 @@ func TestViewRepoOpenWith(t *testing.T) { | ||||||
| 		testOpenWith([]string{"test://"}) | 		testOpenWith([]string{"test://"}) | ||||||
| 	}) | 	}) | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | func TestFileHistoryPager(t *testing.T) { | ||||||
|  | 	defer tests.PrepareTestEnv(t)() | ||||||
|  | 
 | ||||||
|  | 	t.Run("Normal page number", func(t *testing.T) { | ||||||
|  | 		defer tests.PrintCurrentTest(t)() | ||||||
|  | 
 | ||||||
|  | 		req := NewRequest(t, "GET", "/user2/repo1/commits/branch/master/README.md?page=1") | ||||||
|  | 		MakeRequest(t, req, http.StatusOK) | ||||||
|  | 	}) | ||||||
|  | 
 | ||||||
|  | 	t.Run("Too high page number", func(t *testing.T) { | ||||||
|  | 		defer tests.PrintCurrentTest(t)() | ||||||
|  | 
 | ||||||
|  | 		req := NewRequest(t, "GET", "/user2/repo1/commits/branch/master/README.md?page=9999") | ||||||
|  | 		MakeRequest(t, req, http.StatusNotFound) | ||||||
|  | 	}) | ||||||
|  | } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue