mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-25 11:33:11 +00:00 
			
		
		
		
	Fixes #19555 Test-Instructions: https://github.com/go-gitea/gitea/pull/21441#issuecomment-1419438000 This PR implements the mapping of user groups provided by OIDC providers to orgs teams in Gitea. The main part is a refactoring of the existing LDAP code to make it usable from different providers. Refactorings: - Moved the router auth code from module to service because of import cycles - Changed some model methods to take a `Context` parameter - Moved the mapping code from LDAP to a common location I've tested it with Keycloak but other providers should work too. The JSON mapping format is the same as for LDAP.  --------- Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
		
			
				
	
	
		
			537 lines
		
	
	
	
		
			19 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			537 lines
		
	
	
	
		
			19 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2017 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package organization_test
 | |
| 
 | |
| import (
 | |
| 	"testing"
 | |
| 
 | |
| 	"code.gitea.io/gitea/models/db"
 | |
| 	"code.gitea.io/gitea/models/organization"
 | |
| 	repo_model "code.gitea.io/gitea/models/repo"
 | |
| 	"code.gitea.io/gitea/models/unittest"
 | |
| 	user_model "code.gitea.io/gitea/models/user"
 | |
| 	"code.gitea.io/gitea/modules/structs"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| )
 | |
| 
 | |
| func TestUser_IsOwnedBy(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	for _, testCase := range []struct {
 | |
| 		OrgID         int64
 | |
| 		UserID        int64
 | |
| 		ExpectedOwner bool
 | |
| 	}{
 | |
| 		{3, 2, true},
 | |
| 		{3, 1, false},
 | |
| 		{3, 3, false},
 | |
| 		{3, 4, false},
 | |
| 		{2, 2, false}, // user2 is not an organization
 | |
| 		{2, 3, false},
 | |
| 	} {
 | |
| 		org := unittest.AssertExistsAndLoadBean(t, &organization.Organization{ID: testCase.OrgID})
 | |
| 		isOwner, err := org.IsOwnedBy(testCase.UserID)
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.Equal(t, testCase.ExpectedOwner, isOwner)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestUser_IsOrgMember(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	for _, testCase := range []struct {
 | |
| 		OrgID          int64
 | |
| 		UserID         int64
 | |
| 		ExpectedMember bool
 | |
| 	}{
 | |
| 		{3, 2, true},
 | |
| 		{3, 4, true},
 | |
| 		{3, 1, false},
 | |
| 		{3, 3, false},
 | |
| 		{2, 2, false}, // user2 is not an organization
 | |
| 		{2, 3, false},
 | |
| 	} {
 | |
| 		org := unittest.AssertExistsAndLoadBean(t, &organization.Organization{ID: testCase.OrgID})
 | |
| 		isMember, err := org.IsOrgMember(testCase.UserID)
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.Equal(t, testCase.ExpectedMember, isMember)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestUser_GetTeam(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	org := unittest.AssertExistsAndLoadBean(t, &organization.Organization{ID: 3})
 | |
| 	team, err := org.GetTeam(db.DefaultContext, "team1")
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.Equal(t, org.ID, team.OrgID)
 | |
| 	assert.Equal(t, "team1", team.LowerName)
 | |
| 
 | |
| 	_, err = org.GetTeam(db.DefaultContext, "does not exist")
 | |
| 	assert.True(t, organization.IsErrTeamNotExist(err))
 | |
| 
 | |
| 	nonOrg := unittest.AssertExistsAndLoadBean(t, &organization.Organization{ID: 2})
 | |
| 	_, err = nonOrg.GetTeam(db.DefaultContext, "team")
 | |
| 	assert.True(t, organization.IsErrTeamNotExist(err))
 | |
| }
 | |
| 
 | |
| func TestUser_GetOwnerTeam(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	org := unittest.AssertExistsAndLoadBean(t, &organization.Organization{ID: 3})
 | |
| 	team, err := org.GetOwnerTeam(db.DefaultContext)
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.Equal(t, org.ID, team.OrgID)
 | |
| 
 | |
| 	nonOrg := unittest.AssertExistsAndLoadBean(t, &organization.Organization{ID: 2})
 | |
| 	_, err = nonOrg.GetOwnerTeam(db.DefaultContext)
 | |
| 	assert.True(t, organization.IsErrTeamNotExist(err))
 | |
| }
 | |
| 
 | |
| func TestUser_GetTeams(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	org := unittest.AssertExistsAndLoadBean(t, &organization.Organization{ID: 3})
 | |
| 	teams, err := org.LoadTeams()
 | |
| 	assert.NoError(t, err)
 | |
| 	if assert.Len(t, teams, 5) {
 | |
| 		assert.Equal(t, int64(1), teams[0].ID)
 | |
| 		assert.Equal(t, int64(2), teams[1].ID)
 | |
| 		assert.Equal(t, int64(12), teams[2].ID)
 | |
| 		assert.Equal(t, int64(14), teams[3].ID)
 | |
| 		assert.Equal(t, int64(7), teams[4].ID)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestUser_GetMembers(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	org := unittest.AssertExistsAndLoadBean(t, &organization.Organization{ID: 3})
 | |
| 	members, _, err := org.GetMembers()
 | |
| 	assert.NoError(t, err)
 | |
| 	if assert.Len(t, members, 3) {
 | |
| 		assert.Equal(t, int64(2), members[0].ID)
 | |
| 		assert.Equal(t, int64(28), members[1].ID)
 | |
| 		assert.Equal(t, int64(4), members[2].ID)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestGetOrgByName(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 
 | |
| 	org, err := organization.GetOrgByName(db.DefaultContext, "user3")
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.EqualValues(t, 3, org.ID)
 | |
| 	assert.Equal(t, "user3", org.Name)
 | |
| 
 | |
| 	_, err = organization.GetOrgByName(db.DefaultContext, "user2") // user2 is an individual
 | |
| 	assert.True(t, organization.IsErrOrgNotExist(err))
 | |
| 
 | |
| 	_, err = organization.GetOrgByName(db.DefaultContext, "") // corner case
 | |
| 	assert.True(t, organization.IsErrOrgNotExist(err))
 | |
| }
 | |
| 
 | |
| func TestCountOrganizations(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	expected, err := db.GetEngine(db.DefaultContext).Where("type=?", user_model.UserTypeOrganization).Count(&organization.Organization{})
 | |
| 	assert.NoError(t, err)
 | |
| 	cnt, err := organization.CountOrgs(organization.FindOrgOptions{IncludePrivate: true})
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.Equal(t, expected, cnt)
 | |
| }
 | |
| 
 | |
| func TestIsOrganizationOwner(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	test := func(orgID, userID int64, expected bool) {
 | |
| 		isOwner, err := organization.IsOrganizationOwner(db.DefaultContext, orgID, userID)
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.EqualValues(t, expected, isOwner)
 | |
| 	}
 | |
| 	test(3, 2, true)
 | |
| 	test(3, 3, false)
 | |
| 	test(6, 5, true)
 | |
| 	test(6, 4, false)
 | |
| 	test(unittest.NonexistentID, unittest.NonexistentID, false)
 | |
| }
 | |
| 
 | |
| func TestIsOrganizationMember(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	test := func(orgID, userID int64, expected bool) {
 | |
| 		isMember, err := organization.IsOrganizationMember(db.DefaultContext, orgID, userID)
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.EqualValues(t, expected, isMember)
 | |
| 	}
 | |
| 	test(3, 2, true)
 | |
| 	test(3, 3, false)
 | |
| 	test(3, 4, true)
 | |
| 	test(6, 5, true)
 | |
| 	test(6, 4, false)
 | |
| 	test(unittest.NonexistentID, unittest.NonexistentID, false)
 | |
| }
 | |
| 
 | |
| func TestIsPublicMembership(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	test := func(orgID, userID int64, expected bool) {
 | |
| 		isMember, err := organization.IsPublicMembership(orgID, userID)
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.EqualValues(t, expected, isMember)
 | |
| 	}
 | |
| 	test(3, 2, true)
 | |
| 	test(3, 3, false)
 | |
| 	test(3, 4, false)
 | |
| 	test(6, 5, true)
 | |
| 	test(6, 4, false)
 | |
| 	test(unittest.NonexistentID, unittest.NonexistentID, false)
 | |
| }
 | |
| 
 | |
| func TestFindOrgs(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 
 | |
| 	orgs, err := organization.FindOrgs(organization.FindOrgOptions{
 | |
| 		UserID:         4,
 | |
| 		IncludePrivate: true,
 | |
| 	})
 | |
| 	assert.NoError(t, err)
 | |
| 	if assert.Len(t, orgs, 1) {
 | |
| 		assert.EqualValues(t, 3, orgs[0].ID)
 | |
| 	}
 | |
| 
 | |
| 	orgs, err = organization.FindOrgs(organization.FindOrgOptions{
 | |
| 		UserID:         4,
 | |
| 		IncludePrivate: false,
 | |
| 	})
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.Len(t, orgs, 0)
 | |
| 
 | |
| 	total, err := organization.CountOrgs(organization.FindOrgOptions{
 | |
| 		UserID:         4,
 | |
| 		IncludePrivate: true,
 | |
| 	})
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.EqualValues(t, 1, total)
 | |
| }
 | |
| 
 | |
| func TestGetOrgUsersByUserID(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 
 | |
| 	orgUsers, err := organization.GetOrgUsersByUserID(5, &organization.SearchOrganizationsOptions{All: true})
 | |
| 	assert.NoError(t, err)
 | |
| 	if assert.Len(t, orgUsers, 2) {
 | |
| 		assert.Equal(t, organization.OrgUser{
 | |
| 			ID:       orgUsers[0].ID,
 | |
| 			OrgID:    6,
 | |
| 			UID:      5,
 | |
| 			IsPublic: true,
 | |
| 		}, *orgUsers[0])
 | |
| 		assert.Equal(t, organization.OrgUser{
 | |
| 			ID:       orgUsers[1].ID,
 | |
| 			OrgID:    7,
 | |
| 			UID:      5,
 | |
| 			IsPublic: false,
 | |
| 		}, *orgUsers[1])
 | |
| 	}
 | |
| 
 | |
| 	publicOrgUsers, err := organization.GetOrgUsersByUserID(5, &organization.SearchOrganizationsOptions{All: false})
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.Len(t, publicOrgUsers, 1)
 | |
| 	assert.Equal(t, *orgUsers[0], *publicOrgUsers[0])
 | |
| 
 | |
| 	orgUsers, err = organization.GetOrgUsersByUserID(1, &organization.SearchOrganizationsOptions{All: true})
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.Len(t, orgUsers, 0)
 | |
| }
 | |
| 
 | |
| func TestGetOrgUsersByOrgID(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 
 | |
| 	orgUsers, err := organization.GetOrgUsersByOrgID(db.DefaultContext, &organization.FindOrgMembersOpts{
 | |
| 		ListOptions: db.ListOptions{},
 | |
| 		OrgID:       3,
 | |
| 		PublicOnly:  false,
 | |
| 	})
 | |
| 	assert.NoError(t, err)
 | |
| 	if assert.Len(t, orgUsers, 3) {
 | |
| 		assert.Equal(t, organization.OrgUser{
 | |
| 			ID:       orgUsers[0].ID,
 | |
| 			OrgID:    3,
 | |
| 			UID:      2,
 | |
| 			IsPublic: true,
 | |
| 		}, *orgUsers[0])
 | |
| 		assert.Equal(t, organization.OrgUser{
 | |
| 			ID:       orgUsers[1].ID,
 | |
| 			OrgID:    3,
 | |
| 			UID:      4,
 | |
| 			IsPublic: false,
 | |
| 		}, *orgUsers[1])
 | |
| 	}
 | |
| 
 | |
| 	orgUsers, err = organization.GetOrgUsersByOrgID(db.DefaultContext, &organization.FindOrgMembersOpts{
 | |
| 		ListOptions: db.ListOptions{},
 | |
| 		OrgID:       unittest.NonexistentID,
 | |
| 		PublicOnly:  false,
 | |
| 	})
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.Len(t, orgUsers, 0)
 | |
| }
 | |
| 
 | |
| func TestChangeOrgUserStatus(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 
 | |
| 	testSuccess := func(orgID, userID int64, public bool) {
 | |
| 		assert.NoError(t, organization.ChangeOrgUserStatus(orgID, userID, public))
 | |
| 		orgUser := unittest.AssertExistsAndLoadBean(t, &organization.OrgUser{OrgID: orgID, UID: userID})
 | |
| 		assert.Equal(t, public, orgUser.IsPublic)
 | |
| 	}
 | |
| 
 | |
| 	testSuccess(3, 2, false)
 | |
| 	testSuccess(3, 2, false)
 | |
| 	testSuccess(3, 4, true)
 | |
| 	assert.NoError(t, organization.ChangeOrgUserStatus(unittest.NonexistentID, unittest.NonexistentID, true))
 | |
| }
 | |
| 
 | |
| func TestUser_GetUserTeamIDs(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	org := unittest.AssertExistsAndLoadBean(t, &organization.Organization{ID: 3})
 | |
| 	testSuccess := func(userID int64, expected []int64) {
 | |
| 		teamIDs, err := org.GetUserTeamIDs(userID)
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.Equal(t, expected, teamIDs)
 | |
| 	}
 | |
| 	testSuccess(2, []int64{1, 2, 14})
 | |
| 	testSuccess(4, []int64{2})
 | |
| 	testSuccess(unittest.NonexistentID, []int64{})
 | |
| }
 | |
| 
 | |
| func TestAccessibleReposEnv_CountRepos(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	org := unittest.AssertExistsAndLoadBean(t, &organization.Organization{ID: 3})
 | |
| 	testSuccess := func(userID, expectedCount int64) {
 | |
| 		env, err := organization.AccessibleReposEnv(db.DefaultContext, org, userID)
 | |
| 		assert.NoError(t, err)
 | |
| 		count, err := env.CountRepos()
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.EqualValues(t, expectedCount, count)
 | |
| 	}
 | |
| 	testSuccess(2, 3)
 | |
| 	testSuccess(4, 2)
 | |
| }
 | |
| 
 | |
| func TestAccessibleReposEnv_RepoIDs(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	org := unittest.AssertExistsAndLoadBean(t, &organization.Organization{ID: 3})
 | |
| 	testSuccess := func(userID, _, pageSize int64, expectedRepoIDs []int64) {
 | |
| 		env, err := organization.AccessibleReposEnv(db.DefaultContext, org, userID)
 | |
| 		assert.NoError(t, err)
 | |
| 		repoIDs, err := env.RepoIDs(1, 100)
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.Equal(t, expectedRepoIDs, repoIDs)
 | |
| 	}
 | |
| 	testSuccess(2, 1, 100, []int64{3, 5, 32})
 | |
| 	testSuccess(4, 0, 100, []int64{3, 32})
 | |
| }
 | |
| 
 | |
| func TestAccessibleReposEnv_Repos(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	org := unittest.AssertExistsAndLoadBean(t, &organization.Organization{ID: 3})
 | |
| 	testSuccess := func(userID int64, expectedRepoIDs []int64) {
 | |
| 		env, err := organization.AccessibleReposEnv(db.DefaultContext, org, userID)
 | |
| 		assert.NoError(t, err)
 | |
| 		repos, err := env.Repos(1, 100)
 | |
| 		assert.NoError(t, err)
 | |
| 		expectedRepos := make([]*repo_model.Repository, len(expectedRepoIDs))
 | |
| 		for i, repoID := range expectedRepoIDs {
 | |
| 			expectedRepos[i] = unittest.AssertExistsAndLoadBean(t,
 | |
| 				&repo_model.Repository{ID: repoID})
 | |
| 		}
 | |
| 		assert.Equal(t, expectedRepos, repos)
 | |
| 	}
 | |
| 	testSuccess(2, []int64{3, 5, 32})
 | |
| 	testSuccess(4, []int64{3, 32})
 | |
| }
 | |
| 
 | |
| func TestAccessibleReposEnv_MirrorRepos(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	org := unittest.AssertExistsAndLoadBean(t, &organization.Organization{ID: 3})
 | |
| 	testSuccess := func(userID int64, expectedRepoIDs []int64) {
 | |
| 		env, err := organization.AccessibleReposEnv(db.DefaultContext, org, userID)
 | |
| 		assert.NoError(t, err)
 | |
| 		repos, err := env.MirrorRepos()
 | |
| 		assert.NoError(t, err)
 | |
| 		expectedRepos := make([]*repo_model.Repository, len(expectedRepoIDs))
 | |
| 		for i, repoID := range expectedRepoIDs {
 | |
| 			expectedRepos[i] = unittest.AssertExistsAndLoadBean(t,
 | |
| 				&repo_model.Repository{ID: repoID})
 | |
| 		}
 | |
| 		assert.Equal(t, expectedRepos, repos)
 | |
| 	}
 | |
| 	testSuccess(2, []int64{5})
 | |
| 	testSuccess(4, []int64{})
 | |
| }
 | |
| 
 | |
| func TestHasOrgVisibleTypePublic(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	owner := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
 | |
| 	user3 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 3})
 | |
| 
 | |
| 	const newOrgName = "test-org-public"
 | |
| 	org := &organization.Organization{
 | |
| 		Name:       newOrgName,
 | |
| 		Visibility: structs.VisibleTypePublic,
 | |
| 	}
 | |
| 
 | |
| 	unittest.AssertNotExistsBean(t, &user_model.User{Name: org.Name, Type: user_model.UserTypeOrganization})
 | |
| 	assert.NoError(t, organization.CreateOrganization(org, owner))
 | |
| 	org = unittest.AssertExistsAndLoadBean(t,
 | |
| 		&organization.Organization{Name: org.Name, Type: user_model.UserTypeOrganization})
 | |
| 	test1 := organization.HasOrgOrUserVisible(db.DefaultContext, org.AsUser(), owner)
 | |
| 	test2 := organization.HasOrgOrUserVisible(db.DefaultContext, org.AsUser(), user3)
 | |
| 	test3 := organization.HasOrgOrUserVisible(db.DefaultContext, org.AsUser(), nil)
 | |
| 	assert.True(t, test1) // owner of org
 | |
| 	assert.True(t, test2) // user not a part of org
 | |
| 	assert.True(t, test3) // logged out user
 | |
| }
 | |
| 
 | |
| func TestHasOrgVisibleTypeLimited(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	owner := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
 | |
| 	user3 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 3})
 | |
| 
 | |
| 	const newOrgName = "test-org-limited"
 | |
| 	org := &organization.Organization{
 | |
| 		Name:       newOrgName,
 | |
| 		Visibility: structs.VisibleTypeLimited,
 | |
| 	}
 | |
| 
 | |
| 	unittest.AssertNotExistsBean(t, &user_model.User{Name: org.Name, Type: user_model.UserTypeOrganization})
 | |
| 	assert.NoError(t, organization.CreateOrganization(org, owner))
 | |
| 	org = unittest.AssertExistsAndLoadBean(t,
 | |
| 		&organization.Organization{Name: org.Name, Type: user_model.UserTypeOrganization})
 | |
| 	test1 := organization.HasOrgOrUserVisible(db.DefaultContext, org.AsUser(), owner)
 | |
| 	test2 := organization.HasOrgOrUserVisible(db.DefaultContext, org.AsUser(), user3)
 | |
| 	test3 := organization.HasOrgOrUserVisible(db.DefaultContext, org.AsUser(), nil)
 | |
| 	assert.True(t, test1)  // owner of org
 | |
| 	assert.True(t, test2)  // user not a part of org
 | |
| 	assert.False(t, test3) // logged out user
 | |
| }
 | |
| 
 | |
| func TestHasOrgVisibleTypePrivate(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	owner := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
 | |
| 	user3 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 3})
 | |
| 
 | |
| 	const newOrgName = "test-org-private"
 | |
| 	org := &organization.Organization{
 | |
| 		Name:       newOrgName,
 | |
| 		Visibility: structs.VisibleTypePrivate,
 | |
| 	}
 | |
| 
 | |
| 	unittest.AssertNotExistsBean(t, &user_model.User{Name: org.Name, Type: user_model.UserTypeOrganization})
 | |
| 	assert.NoError(t, organization.CreateOrganization(org, owner))
 | |
| 	org = unittest.AssertExistsAndLoadBean(t,
 | |
| 		&organization.Organization{Name: org.Name, Type: user_model.UserTypeOrganization})
 | |
| 	test1 := organization.HasOrgOrUserVisible(db.DefaultContext, org.AsUser(), owner)
 | |
| 	test2 := organization.HasOrgOrUserVisible(db.DefaultContext, org.AsUser(), user3)
 | |
| 	test3 := organization.HasOrgOrUserVisible(db.DefaultContext, org.AsUser(), nil)
 | |
| 	assert.True(t, test1)  // owner of org
 | |
| 	assert.False(t, test2) // user not a part of org
 | |
| 	assert.False(t, test3) // logged out user
 | |
| }
 | |
| 
 | |
| func TestGetUsersWhoCanCreateOrgRepo(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 
 | |
| 	users, err := organization.GetUsersWhoCanCreateOrgRepo(db.DefaultContext, 3)
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.Len(t, users, 2)
 | |
| 	var ids []int64
 | |
| 	for i := range users {
 | |
| 		ids = append(ids, users[i].ID)
 | |
| 	}
 | |
| 	assert.ElementsMatch(t, ids, []int64{2, 28})
 | |
| 
 | |
| 	users, err = organization.GetUsersWhoCanCreateOrgRepo(db.DefaultContext, 7)
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.Len(t, users, 1)
 | |
| 	assert.NotNil(t, users[5])
 | |
| }
 | |
| 
 | |
| func TestUser_RemoveOrgRepo(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	org := unittest.AssertExistsAndLoadBean(t, &organization.Organization{ID: 3})
 | |
| 	repo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{OwnerID: org.ID})
 | |
| 
 | |
| 	// remove a repo that does belong to org
 | |
| 	unittest.AssertExistsAndLoadBean(t, &organization.TeamRepo{RepoID: repo.ID, OrgID: org.ID})
 | |
| 	assert.NoError(t, organization.RemoveOrgRepo(db.DefaultContext, org.ID, repo.ID))
 | |
| 	unittest.AssertNotExistsBean(t, &organization.TeamRepo{RepoID: repo.ID, OrgID: org.ID})
 | |
| 	unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: repo.ID}) // repo should still exist
 | |
| 
 | |
| 	// remove a repo that does not belong to org
 | |
| 	assert.NoError(t, organization.RemoveOrgRepo(db.DefaultContext, org.ID, repo.ID))
 | |
| 	unittest.AssertNotExistsBean(t, &organization.TeamRepo{RepoID: repo.ID, OrgID: org.ID})
 | |
| 
 | |
| 	assert.NoError(t, organization.RemoveOrgRepo(db.DefaultContext, org.ID, unittest.NonexistentID))
 | |
| 
 | |
| 	unittest.CheckConsistencyFor(t,
 | |
| 		&user_model.User{ID: org.ID},
 | |
| 		&organization.Team{OrgID: org.ID},
 | |
| 		&repo_model.Repository{ID: repo.ID})
 | |
| }
 | |
| 
 | |
| func TestCreateOrganization(t *testing.T) {
 | |
| 	// successful creation of org
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 
 | |
| 	owner := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
 | |
| 	const newOrgName = "neworg"
 | |
| 	org := &organization.Organization{
 | |
| 		Name: newOrgName,
 | |
| 	}
 | |
| 
 | |
| 	unittest.AssertNotExistsBean(t, &user_model.User{Name: newOrgName, Type: user_model.UserTypeOrganization})
 | |
| 	assert.NoError(t, organization.CreateOrganization(org, owner))
 | |
| 	org = unittest.AssertExistsAndLoadBean(t,
 | |
| 		&organization.Organization{Name: newOrgName, Type: user_model.UserTypeOrganization})
 | |
| 	ownerTeam := unittest.AssertExistsAndLoadBean(t,
 | |
| 		&organization.Team{Name: organization.OwnerTeamName, OrgID: org.ID})
 | |
| 	unittest.AssertExistsAndLoadBean(t, &organization.TeamUser{UID: owner.ID, TeamID: ownerTeam.ID})
 | |
| 	unittest.CheckConsistencyFor(t, &user_model.User{}, &organization.Team{})
 | |
| }
 | |
| 
 | |
| func TestCreateOrganization2(t *testing.T) {
 | |
| 	// unauthorized creation of org
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 
 | |
| 	owner := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 5})
 | |
| 	const newOrgName = "neworg"
 | |
| 	org := &organization.Organization{
 | |
| 		Name: newOrgName,
 | |
| 	}
 | |
| 
 | |
| 	unittest.AssertNotExistsBean(t, &organization.Organization{Name: newOrgName, Type: user_model.UserTypeOrganization})
 | |
| 	err := organization.CreateOrganization(org, owner)
 | |
| 	assert.Error(t, err)
 | |
| 	assert.True(t, organization.IsErrUserNotAllowedCreateOrg(err))
 | |
| 	unittest.AssertNotExistsBean(t, &organization.Organization{Name: newOrgName, Type: user_model.UserTypeOrganization})
 | |
| 	unittest.CheckConsistencyFor(t, &organization.Organization{}, &organization.Team{})
 | |
| }
 | |
| 
 | |
| func TestCreateOrganization3(t *testing.T) {
 | |
| 	// create org with same name as existent org
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 
 | |
| 	owner := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
 | |
| 	org := &organization.Organization{Name: "user3"}                      // should already exist
 | |
| 	unittest.AssertExistsAndLoadBean(t, &user_model.User{Name: org.Name}) // sanity check
 | |
| 	err := organization.CreateOrganization(org, owner)
 | |
| 	assert.Error(t, err)
 | |
| 	assert.True(t, user_model.IsErrUserAlreadyExist(err))
 | |
| 	unittest.CheckConsistencyFor(t, &user_model.User{}, &organization.Team{})
 | |
| }
 | |
| 
 | |
| func TestCreateOrganization4(t *testing.T) {
 | |
| 	// create org with unusable name
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 
 | |
| 	owner := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
 | |
| 	err := organization.CreateOrganization(&organization.Organization{Name: "assets"}, owner)
 | |
| 	assert.Error(t, err)
 | |
| 	assert.True(t, db.IsErrNameReserved(err))
 | |
| 	unittest.CheckConsistencyFor(t, &organization.Organization{}, &organization.Team{})
 | |
| }
 |