mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-31 11:35:03 +01:00 
			
		
		
		
	* Add initial playwright config * Simplify Makefile * Simplify Makefile * Use correct config files * Update playwright settings * Fix package-lock file * Don't use test logger for e2e tests * fix frontend lint * Allow passing TEST_LOGGER variable * Init postgres database * use standard gitea env variables * Update playwright * update drone * Move empty env var to commands * Cleanup * Move integrations to subfolder * tests integrations to tests integraton * Run e2e tests with go test * Fix linting * install CI deps * Add files to ESlint * Fix drone typo * Don't log to console in CI * Use go test http server * Add build step before tests * Move shared init function to common package * fix drone * Clean up tests * Fix linting * Better mocking for page + version string * Cleanup test generation * Remove dependency on gitea binary * Fix linting * add initial support for running specific tests * Add ACCEPT_VISUAL variable * don't require git-lfs * Add initial documentation * Review feedback * Add logged in session test * Attempt fixing drone race * Cleanup and bump version * Bump deps * Review feedback * simplify installation * Fix ci * Update install docs
		
			
				
	
	
		
			155 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			155 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2021 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 integration
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"net/url"
 | |
| 	"testing"
 | |
| 
 | |
| 	asymkey_model "code.gitea.io/gitea/models/asymkey"
 | |
| 	"code.gitea.io/gitea/models/perm"
 | |
| 	"code.gitea.io/gitea/modules/private"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| )
 | |
| 
 | |
| func TestAPIPrivateNoServ(t *testing.T) {
 | |
| 	onGiteaRun(t, func(*testing.T, *url.URL) {
 | |
| 		ctx, cancel := context.WithCancel(context.Background())
 | |
| 		defer cancel()
 | |
| 		key, user, err := private.ServNoCommand(ctx, 1)
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.Equal(t, int64(2), user.ID)
 | |
| 		assert.Equal(t, "user2", user.Name)
 | |
| 		assert.Equal(t, int64(1), key.ID)
 | |
| 		assert.Equal(t, "user2@localhost", key.Name)
 | |
| 
 | |
| 		deployKey, err := asymkey_model.AddDeployKey(1, "test-deploy", "sk-ecdsa-sha2-nistp256@openssh.com AAAAInNrLWVjZHNhLXNoYTItbmlzdHAyNTZAb3BlbnNzaC5jb20AAAAIbmlzdHAyNTYAAABBBGXEEzWmm1dxb+57RoK5KVCL0w2eNv9cqJX2AGGVlkFsVDhOXHzsadS3LTK4VlEbbrDMJdoti9yM8vclA8IeRacAAAAEc3NoOg== nocomment", false)
 | |
| 		assert.NoError(t, err)
 | |
| 
 | |
| 		key, user, err = private.ServNoCommand(ctx, deployKey.KeyID)
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.Empty(t, user)
 | |
| 		assert.Equal(t, deployKey.KeyID, key.ID)
 | |
| 		assert.Equal(t, "test-deploy", key.Name)
 | |
| 	})
 | |
| }
 | |
| 
 | |
| func TestAPIPrivateServ(t *testing.T) {
 | |
| 	onGiteaRun(t, func(*testing.T, *url.URL) {
 | |
| 		ctx, cancel := context.WithCancel(context.Background())
 | |
| 		defer cancel()
 | |
| 
 | |
| 		// Can push to a repo we own
 | |
| 		results, err := private.ServCommand(ctx, 1, "user2", "repo1", perm.AccessModeWrite, "git-upload-pack", "")
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.False(t, results.IsWiki)
 | |
| 		assert.Zero(t, results.DeployKeyID)
 | |
| 		assert.Equal(t, int64(1), results.KeyID)
 | |
| 		assert.Equal(t, "user2@localhost", results.KeyName)
 | |
| 		assert.Equal(t, "user2", results.UserName)
 | |
| 		assert.Equal(t, int64(2), results.UserID)
 | |
| 		assert.Equal(t, "user2", results.OwnerName)
 | |
| 		assert.Equal(t, "repo1", results.RepoName)
 | |
| 		assert.Equal(t, int64(1), results.RepoID)
 | |
| 
 | |
| 		// Cannot push to a private repo we're not associated with
 | |
| 		results, err = private.ServCommand(ctx, 1, "user15", "big_test_private_1", perm.AccessModeWrite, "git-upload-pack", "")
 | |
| 		assert.Error(t, err)
 | |
| 		assert.Empty(t, results)
 | |
| 
 | |
| 		// Cannot pull from a private repo we're not associated with
 | |
| 		results, err = private.ServCommand(ctx, 1, "user15", "big_test_private_1", perm.AccessModeRead, "git-upload-pack", "")
 | |
| 		assert.Error(t, err)
 | |
| 		assert.Empty(t, results)
 | |
| 
 | |
| 		// Can pull from a public repo we're not associated with
 | |
| 		results, err = private.ServCommand(ctx, 1, "user15", "big_test_public_1", perm.AccessModeRead, "git-upload-pack", "")
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.False(t, results.IsWiki)
 | |
| 		assert.Zero(t, results.DeployKeyID)
 | |
| 		assert.Equal(t, int64(1), results.KeyID)
 | |
| 		assert.Equal(t, "user2@localhost", results.KeyName)
 | |
| 		assert.Equal(t, "user2", results.UserName)
 | |
| 		assert.Equal(t, int64(2), results.UserID)
 | |
| 		assert.Equal(t, "user15", results.OwnerName)
 | |
| 		assert.Equal(t, "big_test_public_1", results.RepoName)
 | |
| 		assert.Equal(t, int64(17), results.RepoID)
 | |
| 
 | |
| 		// Cannot push to a public repo we're not associated with
 | |
| 		results, err = private.ServCommand(ctx, 1, "user15", "big_test_public_1", perm.AccessModeWrite, "git-upload-pack", "")
 | |
| 		assert.Error(t, err)
 | |
| 		assert.Empty(t, results)
 | |
| 
 | |
| 		// Add reading deploy key
 | |
| 		deployKey, err := asymkey_model.AddDeployKey(19, "test-deploy", "sk-ecdsa-sha2-nistp256@openssh.com AAAAInNrLWVjZHNhLXNoYTItbmlzdHAyNTZAb3BlbnNzaC5jb20AAAAIbmlzdHAyNTYAAABBBGXEEzWmm1dxb+57RoK5KVCL0w2eNv9cqJX2AGGVlkFsVDhOXHzsadS3LTK4VlEbbrDMJdoti9yM8vclA8IeRacAAAAEc3NoOg== nocomment", true)
 | |
| 		assert.NoError(t, err)
 | |
| 
 | |
| 		// Can pull from repo we're a deploy key for
 | |
| 		results, err = private.ServCommand(ctx, deployKey.KeyID, "user15", "big_test_private_1", perm.AccessModeRead, "git-upload-pack", "")
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.False(t, results.IsWiki)
 | |
| 		assert.NotZero(t, results.DeployKeyID)
 | |
| 		assert.Equal(t, deployKey.KeyID, results.KeyID)
 | |
| 		assert.Equal(t, "test-deploy", results.KeyName)
 | |
| 		assert.Equal(t, "user15", results.UserName)
 | |
| 		assert.Equal(t, int64(15), results.UserID)
 | |
| 		assert.Equal(t, "user15", results.OwnerName)
 | |
| 		assert.Equal(t, "big_test_private_1", results.RepoName)
 | |
| 		assert.Equal(t, int64(19), results.RepoID)
 | |
| 
 | |
| 		// Cannot push to a private repo with reading key
 | |
| 		results, err = private.ServCommand(ctx, deployKey.KeyID, "user15", "big_test_private_1", perm.AccessModeWrite, "git-upload-pack", "")
 | |
| 		assert.Error(t, err)
 | |
| 		assert.Empty(t, results)
 | |
| 
 | |
| 		// Cannot pull from a private repo we're not associated with
 | |
| 		results, err = private.ServCommand(ctx, deployKey.ID, "user15", "big_test_private_2", perm.AccessModeRead, "git-upload-pack", "")
 | |
| 		assert.Error(t, err)
 | |
| 		assert.Empty(t, results)
 | |
| 
 | |
| 		// Cannot pull from a public repo we're not associated with
 | |
| 		results, err = private.ServCommand(ctx, deployKey.ID, "user15", "big_test_public_1", perm.AccessModeRead, "git-upload-pack", "")
 | |
| 		assert.Error(t, err)
 | |
| 		assert.Empty(t, results)
 | |
| 
 | |
| 		// Add writing deploy key
 | |
| 		deployKey, err = asymkey_model.AddDeployKey(20, "test-deploy", "sk-ecdsa-sha2-nistp256@openssh.com AAAAInNrLWVjZHNhLXNoYTItbmlzdHAyNTZAb3BlbnNzaC5jb20AAAAIbmlzdHAyNTYAAABBBGXEEzWmm1dxb+57RoK5KVCL0w2eNv9cqJX2AGGVlkFsVDhOXHzsadS3LTK4VlEbbrDMJdoti9yM8vclA8IeRacAAAAEc3NoOg== nocomment", false)
 | |
| 		assert.NoError(t, err)
 | |
| 
 | |
| 		// Cannot push to a private repo with reading key
 | |
| 		results, err = private.ServCommand(ctx, deployKey.KeyID, "user15", "big_test_private_1", perm.AccessModeWrite, "git-upload-pack", "")
 | |
| 		assert.Error(t, err)
 | |
| 		assert.Empty(t, results)
 | |
| 
 | |
| 		// Can pull from repo we're a writing deploy key for
 | |
| 		results, err = private.ServCommand(ctx, deployKey.KeyID, "user15", "big_test_private_2", perm.AccessModeRead, "git-upload-pack", "")
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.False(t, results.IsWiki)
 | |
| 		assert.NotZero(t, results.DeployKeyID)
 | |
| 		assert.Equal(t, deployKey.KeyID, results.KeyID)
 | |
| 		assert.Equal(t, "test-deploy", results.KeyName)
 | |
| 		assert.Equal(t, "user15", results.UserName)
 | |
| 		assert.Equal(t, int64(15), results.UserID)
 | |
| 		assert.Equal(t, "user15", results.OwnerName)
 | |
| 		assert.Equal(t, "big_test_private_2", results.RepoName)
 | |
| 		assert.Equal(t, int64(20), results.RepoID)
 | |
| 
 | |
| 		// Can push to repo we're a writing deploy key for
 | |
| 		results, err = private.ServCommand(ctx, deployKey.KeyID, "user15", "big_test_private_2", perm.AccessModeWrite, "git-upload-pack", "")
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.False(t, results.IsWiki)
 | |
| 		assert.NotZero(t, results.DeployKeyID)
 | |
| 		assert.Equal(t, deployKey.KeyID, results.KeyID)
 | |
| 		assert.Equal(t, "test-deploy", results.KeyName)
 | |
| 		assert.Equal(t, "user15", results.UserName)
 | |
| 		assert.Equal(t, int64(15), results.UserID)
 | |
| 		assert.Equal(t, "user15", results.OwnerName)
 | |
| 		assert.Equal(t, "big_test_private_2", results.RepoName)
 | |
| 		assert.Equal(t, int64(20), results.RepoID)
 | |
| 	})
 | |
| }
 |