Unit tests for models/repo_collaboration (#1032)
This commit is contained in:
		
							parent
							
								
									8de8e11487
								
							
						
					
					
						commit
						f1ab906c51
					
				
					 2 changed files with 106 additions and 1 deletions
				
			
		|  | @ -6,6 +6,6 @@ | |||
| 
 | ||||
| - | ||||
|   id: 2 | ||||
|   repo_id: 4 | ||||
|   user_id: 4 | ||||
|   repo_id: 4 | ||||
|   mode: 2 # write | ||||
|  |  | |||
							
								
								
									
										105
									
								
								models/repo_collaboration_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										105
									
								
								models/repo_collaboration_test.go
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,105 @@ | |||
| // 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 models | ||||
| 
 | ||||
| import ( | ||||
| 	"testing" | ||||
| 
 | ||||
| 	"github.com/stretchr/testify/assert" | ||||
| ) | ||||
| 
 | ||||
| func TestCollaboration_ModeI18nKey(t *testing.T) { | ||||
| 	assert.Equal(t, "repo.settings.collaboration.read", | ||||
| 		(&Collaboration{Mode: AccessModeRead}).ModeI18nKey()) | ||||
| 	assert.Equal(t, "repo.settings.collaboration.write", | ||||
| 		(&Collaboration{Mode: AccessModeWrite}).ModeI18nKey()) | ||||
| 	assert.Equal(t, "repo.settings.collaboration.admin", | ||||
| 		(&Collaboration{Mode: AccessModeAdmin}).ModeI18nKey()) | ||||
| 	assert.Equal(t, "repo.settings.collaboration.undefined", | ||||
| 		(&Collaboration{Mode: AccessModeNone}).ModeI18nKey()) | ||||
| } | ||||
| 
 | ||||
| func TestRepository_AddCollaborator(t *testing.T) { | ||||
| 	assert.NoError(t, PrepareTestDatabase()) | ||||
| 
 | ||||
| 	testSuccess := func(repoID, userID int64) { | ||||
| 		repo := AssertExistsAndLoadBean(t, &Repository{ID: repoID}).(*Repository) | ||||
| 		assert.NoError(t, repo.GetOwner()) | ||||
| 		user := AssertExistsAndLoadBean(t, &User{ID: userID}).(*User) | ||||
| 		assert.NoError(t, repo.AddCollaborator(user)) | ||||
| 		CheckConsistencyFor(t, &Repository{ID: repoID}, &User{ID: userID}) | ||||
| 	} | ||||
| 	testSuccess(1, 4) | ||||
| 	testSuccess(1, 4) | ||||
| 	testSuccess(3, 4) | ||||
| } | ||||
| 
 | ||||
| func TestRepository_GetCollaborators(t *testing.T) { | ||||
| 	assert.NoError(t, PrepareTestDatabase()) | ||||
| 	test := func(repoID int64) { | ||||
| 		repo := AssertExistsAndLoadBean(t, &Repository{ID: repoID}).(*Repository) | ||||
| 		collaborators, err := repo.GetCollaborators() | ||||
| 		assert.NoError(t, err) | ||||
| 		expectedLen, err := x.Count(&Collaboration{RepoID: repoID}) | ||||
| 		assert.NoError(t, err) | ||||
| 		assert.Len(t, collaborators, int(expectedLen)) | ||||
| 		for _, collaborator := range collaborators { | ||||
| 			assert.EqualValues(t, collaborator.User.ID, collaborator.Collaboration.UserID) | ||||
| 			assert.EqualValues(t, repoID, collaborator.Collaboration.RepoID) | ||||
| 		} | ||||
| 	} | ||||
| 	test(1) | ||||
| 	test(2) | ||||
| 	test(3) | ||||
| 	test(4) | ||||
| } | ||||
| 
 | ||||
| func TestRepository_IsCollaborator(t *testing.T) { | ||||
| 	assert.NoError(t, PrepareTestDatabase()) | ||||
| 
 | ||||
| 	test := func(repoID, userID int64, expected bool) { | ||||
| 		repo := AssertExistsAndLoadBean(t, &Repository{ID: repoID}).(*Repository) | ||||
| 		actual, err := repo.IsCollaborator(userID) | ||||
| 		assert.NoError(t, err) | ||||
| 		assert.Equal(t, expected, actual) | ||||
| 	} | ||||
| 	test(3, 2, true) | ||||
| 	test(3, NonexistentID, false) | ||||
| 	test(4, 2, false) | ||||
| 	test(4, 4, true) | ||||
| } | ||||
| 
 | ||||
| func TestRepository_ChangeCollaborationAccessMode(t *testing.T) { | ||||
| 	assert.NoError(t, PrepareTestDatabase()) | ||||
| 
 | ||||
| 	repo := AssertExistsAndLoadBean(t, &Repository{ID: 4}).(*Repository) | ||||
| 	assert.NoError(t, repo.ChangeCollaborationAccessMode(4, AccessModeAdmin)) | ||||
| 
 | ||||
| 	collaboration := AssertExistsAndLoadBean(t, &Collaboration{RepoID: repo.ID, UserID: 4}).(*Collaboration) | ||||
| 	assert.EqualValues(t, AccessModeAdmin, collaboration.Mode) | ||||
| 
 | ||||
| 	access := AssertExistsAndLoadBean(t, &Access{UserID: 4, RepoID: repo.ID}).(*Access) | ||||
| 	assert.EqualValues(t, AccessModeAdmin, access.Mode) | ||||
| 
 | ||||
| 	assert.NoError(t, repo.ChangeCollaborationAccessMode(4, AccessModeAdmin)) | ||||
| 
 | ||||
| 	assert.NoError(t, repo.ChangeCollaborationAccessMode(NonexistentID, AccessModeAdmin)) | ||||
| 
 | ||||
| 	CheckConsistencyFor(t, &Repository{ID: repo.ID}) | ||||
| } | ||||
| 
 | ||||
| func TestRepository_DeleteCollaboration(t *testing.T) { | ||||
| 	assert.NoError(t, PrepareTestDatabase()) | ||||
| 
 | ||||
| 	repo := AssertExistsAndLoadBean(t, &Repository{ID: 4}).(*Repository) | ||||
| 	assert.NoError(t, repo.GetOwner()) | ||||
| 	assert.NoError(t, repo.DeleteCollaboration(4)) | ||||
| 	AssertNotExistsBean(t, &Collaboration{RepoID: repo.ID, UserID: 4}) | ||||
| 
 | ||||
| 	assert.NoError(t, repo.DeleteCollaboration(4)) | ||||
| 	AssertNotExistsBean(t, &Collaboration{RepoID: repo.ID, UserID: 4}) | ||||
| 
 | ||||
| 	CheckConsistencyFor(t, &Repository{ID: repo.ID}) | ||||
| } | ||||
		Loading…
	
		Reference in a new issue