|
|
|
@ -21,12 +21,12 @@ import (
|
|
|
|
|
func TestIncludesAllRepositoriesTeams(t *testing.T) {
|
|
|
|
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
|
|
|
|
|
|
|
|
|
testTeamRepositories := func(teamID int64, repoIds []int64) {
|
|
|
|
|
testTeamRepositories := func(teamID int64, repoIDs []int64) {
|
|
|
|
|
team := unittest.AssertExistsAndLoadBean(t, &organization.Team{ID: teamID})
|
|
|
|
|
assert.NoError(t, team.LoadRepositories(db.DefaultContext), "%s: GetRepositories", team.Name)
|
|
|
|
|
assert.Len(t, team.Repos, team.NumRepos, "%s: len repo", team.Name)
|
|
|
|
|
assert.Len(t, team.Repos, len(repoIds), "%s: repo count", team.Name)
|
|
|
|
|
for i, rid := range repoIds {
|
|
|
|
|
assert.Len(t, team.Repos, len(repoIDs), "%s: repo count", team.Name)
|
|
|
|
|
for i, rid := range repoIDs {
|
|
|
|
|
if rid > 0 {
|
|
|
|
|
assert.True(t, HasRepository(db.DefaultContext, team, rid), "%s: HasRepository(%d) %d", rid, i)
|
|
|
|
|
}
|
|
|
|
@ -52,12 +52,12 @@ func TestIncludesAllRepositoriesTeams(t *testing.T) {
|
|
|
|
|
assert.True(t, ownerTeam.IncludesAllRepositories, "Owner team includes all repositories")
|
|
|
|
|
|
|
|
|
|
// Create repos.
|
|
|
|
|
repoIds := make([]int64, 0)
|
|
|
|
|
repoIDs := make([]int64, 0)
|
|
|
|
|
for i := 0; i < 3; i++ {
|
|
|
|
|
r, err := CreateRepositoryDirectly(db.DefaultContext, user, org.AsUser(), CreateRepoOptions{Name: fmt.Sprintf("repo-%d", i)})
|
|
|
|
|
assert.NoError(t, err, "CreateRepository %d", i)
|
|
|
|
|
if r != nil {
|
|
|
|
|
repoIds = append(repoIds, r.ID)
|
|
|
|
|
repoIDs = append(repoIDs, r.ID)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
// Get fresh copy of Owner team after creating repos.
|
|
|
|
@ -93,10 +93,10 @@ func TestIncludesAllRepositoriesTeams(t *testing.T) {
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
teamRepos := [][]int64{
|
|
|
|
|
repoIds,
|
|
|
|
|
repoIds,
|
|
|
|
|
repoIDs,
|
|
|
|
|
repoIDs,
|
|
|
|
|
{},
|
|
|
|
|
repoIds,
|
|
|
|
|
repoIDs,
|
|
|
|
|
{},
|
|
|
|
|
}
|
|
|
|
|
for i, team := range teams {
|
|
|
|
@ -109,7 +109,7 @@ func TestIncludesAllRepositoriesTeams(t *testing.T) {
|
|
|
|
|
// Update teams and check repositories.
|
|
|
|
|
teams[3].IncludesAllRepositories = false
|
|
|
|
|
teams[4].IncludesAllRepositories = true
|
|
|
|
|
teamRepos[4] = repoIds
|
|
|
|
|
teamRepos[4] = repoIDs
|
|
|
|
|
for i, team := range teams {
|
|
|
|
|
assert.NoError(t, models.UpdateTeam(db.DefaultContext, team, false, true), "%s: UpdateTeam", team.Name)
|
|
|
|
|
testTeamRepositories(team.ID, teamRepos[i])
|
|
|
|
@ -119,27 +119,27 @@ func TestIncludesAllRepositoriesTeams(t *testing.T) {
|
|
|
|
|
r, err := CreateRepositoryDirectly(db.DefaultContext, user, org.AsUser(), CreateRepoOptions{Name: "repo-last"})
|
|
|
|
|
assert.NoError(t, err, "CreateRepository last")
|
|
|
|
|
if r != nil {
|
|
|
|
|
repoIds = append(repoIds, r.ID)
|
|
|
|
|
repoIDs = append(repoIDs, r.ID)
|
|
|
|
|
}
|
|
|
|
|
teamRepos[0] = repoIds
|
|
|
|
|
teamRepos[1] = repoIds
|
|
|
|
|
teamRepos[4] = repoIds
|
|
|
|
|
teamRepos[0] = repoIDs
|
|
|
|
|
teamRepos[1] = repoIDs
|
|
|
|
|
teamRepos[4] = repoIDs
|
|
|
|
|
for i, team := range teams {
|
|
|
|
|
testTeamRepositories(team.ID, teamRepos[i])
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Remove repo and check teams repositories.
|
|
|
|
|
assert.NoError(t, DeleteRepositoryDirectly(db.DefaultContext, user, repoIds[0]), "DeleteRepository")
|
|
|
|
|
teamRepos[0] = repoIds[1:]
|
|
|
|
|
teamRepos[1] = repoIds[1:]
|
|
|
|
|
teamRepos[3] = repoIds[1:3]
|
|
|
|
|
teamRepos[4] = repoIds[1:]
|
|
|
|
|
assert.NoError(t, DeleteRepositoryDirectly(db.DefaultContext, user, repoIDs[0]), "DeleteRepository")
|
|
|
|
|
teamRepos[0] = repoIDs[1:]
|
|
|
|
|
teamRepos[1] = repoIDs[1:]
|
|
|
|
|
teamRepos[3] = repoIDs[1:3]
|
|
|
|
|
teamRepos[4] = repoIDs[1:]
|
|
|
|
|
for i, team := range teams {
|
|
|
|
|
testTeamRepositories(team.ID, teamRepos[i])
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Wipe created items.
|
|
|
|
|
for i, rid := range repoIds {
|
|
|
|
|
for i, rid := range repoIDs {
|
|
|
|
|
if i > 0 { // first repo already deleted.
|
|
|
|
|
assert.NoError(t, DeleteRepositoryDirectly(db.DefaultContext, user, rid), "DeleteRepository %d", i)
|
|
|
|
|
}
|
|
|
|
|