summaryrefslogtreecommitdiffstats
path: root/integrations/api_team_test.go
diff options
context:
space:
mode:
authorKyle D <kdumontnu@gmail.com>2022-09-02 21:18:23 +0200
committerGitHub <noreply@github.com>2022-09-02 21:18:23 +0200
commitc8ded77680db7344c8dc1ccee76bce0b4e02e103 (patch)
treebc63678ef62dc71ce68b29eeaf019c45cdb12034 /integrations/api_team_test.go
parentchore: add myself to maintainers (#21028) (diff)
downloadforgejo-c8ded77680db7344c8dc1ccee76bce0b4e02e103.tar.xz
forgejo-c8ded77680db7344c8dc1ccee76bce0b4e02e103.zip
Kd/ci playwright go test (#20123)
* 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
Diffstat (limited to 'integrations/api_team_test.go')
-rw-r--r--integrations/api_team_test.go267
1 files changed, 0 insertions, 267 deletions
diff --git a/integrations/api_team_test.go b/integrations/api_team_test.go
deleted file mode 100644
index 9ea7a6f787..0000000000
--- a/integrations/api_team_test.go
+++ /dev/null
@@ -1,267 +0,0 @@
-// 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 integrations
-
-import (
- "fmt"
- "net/http"
- "sort"
- "testing"
-
- "code.gitea.io/gitea/models/organization"
- "code.gitea.io/gitea/models/repo"
- "code.gitea.io/gitea/models/unit"
- "code.gitea.io/gitea/models/unittest"
- user_model "code.gitea.io/gitea/models/user"
- "code.gitea.io/gitea/modules/convert"
- api "code.gitea.io/gitea/modules/structs"
-
- "github.com/stretchr/testify/assert"
-)
-
-func TestAPITeam(t *testing.T) {
- defer prepareTestEnv(t)()
-
- teamUser := unittest.AssertExistsAndLoadBean(t, &organization.TeamUser{})
- team := unittest.AssertExistsAndLoadBean(t, &organization.Team{ID: teamUser.TeamID})
- user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: teamUser.UID})
-
- session := loginUser(t, user.Name)
- token := getTokenForLoggedInUser(t, session)
- req := NewRequestf(t, "GET", "/api/v1/teams/%d?token="+token, teamUser.TeamID)
- resp := session.MakeRequest(t, req, http.StatusOK)
-
- var apiTeam api.Team
- DecodeJSON(t, resp, &apiTeam)
- assert.EqualValues(t, team.ID, apiTeam.ID)
- assert.Equal(t, team.Name, apiTeam.Name)
-
- // non team member user will not access the teams details
- teamUser2 := unittest.AssertExistsAndLoadBean(t, &organization.TeamUser{ID: 3})
- user2 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: teamUser2.UID})
-
- session = loginUser(t, user2.Name)
- token = getTokenForLoggedInUser(t, session)
- req = NewRequestf(t, "GET", "/api/v1/teams/%d?token="+token, teamUser.TeamID)
- _ = session.MakeRequest(t, req, http.StatusForbidden)
-
- req = NewRequestf(t, "GET", "/api/v1/teams/%d", teamUser.TeamID)
- _ = session.MakeRequest(t, req, http.StatusUnauthorized)
-
- // Get an admin user able to create, update and delete teams.
- user = unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 1})
- session = loginUser(t, user.Name)
- token = getTokenForLoggedInUser(t, session)
-
- org := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 6})
-
- // Create team.
- teamToCreate := &api.CreateTeamOption{
- Name: "team1",
- Description: "team one",
- IncludesAllRepositories: true,
- Permission: "write",
- Units: []string{"repo.code", "repo.issues"},
- }
- req = NewRequestWithJSON(t, "POST", fmt.Sprintf("/api/v1/orgs/%s/teams?token=%s", org.Name, token), teamToCreate)
- resp = session.MakeRequest(t, req, http.StatusCreated)
- apiTeam = api.Team{}
- DecodeJSON(t, resp, &apiTeam)
- checkTeamResponse(t, "CreateTeam1", &apiTeam, teamToCreate.Name, teamToCreate.Description, teamToCreate.IncludesAllRepositories,
- teamToCreate.Permission, teamToCreate.Units, nil)
- checkTeamBean(t, apiTeam.ID, teamToCreate.Name, teamToCreate.Description, teamToCreate.IncludesAllRepositories,
- teamToCreate.Permission, teamToCreate.Units, nil)
- teamID := apiTeam.ID
-
- // Edit team.
- editDescription := "team 1"
- editFalse := false
- teamToEdit := &api.EditTeamOption{
- Name: "teamone",
- Description: &editDescription,
- Permission: "admin",
- IncludesAllRepositories: &editFalse,
- Units: []string{"repo.code", "repo.pulls", "repo.releases"},
- }
-
- req = NewRequestWithJSON(t, "PATCH", fmt.Sprintf("/api/v1/teams/%d?token=%s", teamID, token), teamToEdit)
- resp = session.MakeRequest(t, req, http.StatusOK)
- apiTeam = api.Team{}
- DecodeJSON(t, resp, &apiTeam)
- checkTeamResponse(t, "EditTeam1", &apiTeam, teamToEdit.Name, *teamToEdit.Description, *teamToEdit.IncludesAllRepositories,
- teamToEdit.Permission, unit.AllUnitKeyNames(), nil)
- checkTeamBean(t, apiTeam.ID, teamToEdit.Name, *teamToEdit.Description, *teamToEdit.IncludesAllRepositories,
- teamToEdit.Permission, unit.AllUnitKeyNames(), nil)
-
- // Edit team Description only
- editDescription = "first team"
- teamToEditDesc := api.EditTeamOption{Description: &editDescription}
- req = NewRequestWithJSON(t, "PATCH", fmt.Sprintf("/api/v1/teams/%d?token=%s", teamID, token), teamToEditDesc)
- resp = session.MakeRequest(t, req, http.StatusOK)
- apiTeam = api.Team{}
- DecodeJSON(t, resp, &apiTeam)
- checkTeamResponse(t, "EditTeam1_DescOnly", &apiTeam, teamToEdit.Name, *teamToEditDesc.Description, *teamToEdit.IncludesAllRepositories,
- teamToEdit.Permission, unit.AllUnitKeyNames(), nil)
- checkTeamBean(t, apiTeam.ID, teamToEdit.Name, *teamToEditDesc.Description, *teamToEdit.IncludesAllRepositories,
- teamToEdit.Permission, unit.AllUnitKeyNames(), nil)
-
- // Read team.
- teamRead := unittest.AssertExistsAndLoadBean(t, &organization.Team{ID: teamID})
- assert.NoError(t, teamRead.GetUnits())
- req = NewRequestf(t, "GET", "/api/v1/teams/%d?token="+token, teamID)
- resp = session.MakeRequest(t, req, http.StatusOK)
- apiTeam = api.Team{}
- DecodeJSON(t, resp, &apiTeam)
- checkTeamResponse(t, "ReadTeam1", &apiTeam, teamRead.Name, *teamToEditDesc.Description, teamRead.IncludesAllRepositories,
- teamRead.AccessMode.String(), teamRead.GetUnitNames(), teamRead.GetUnitsMap())
-
- // Delete team.
- req = NewRequestf(t, "DELETE", "/api/v1/teams/%d?token="+token, teamID)
- session.MakeRequest(t, req, http.StatusNoContent)
- unittest.AssertNotExistsBean(t, &organization.Team{ID: teamID})
-
- // create team again via UnitsMap
- // Create team.
- teamToCreate = &api.CreateTeamOption{
- Name: "team2",
- Description: "team two",
- IncludesAllRepositories: true,
- Permission: "write",
- UnitsMap: map[string]string{"repo.code": "read", "repo.issues": "write", "repo.wiki": "none"},
- }
- req = NewRequestWithJSON(t, "POST", fmt.Sprintf("/api/v1/orgs/%s/teams?token=%s", org.Name, token), teamToCreate)
- resp = session.MakeRequest(t, req, http.StatusCreated)
- apiTeam = api.Team{}
- DecodeJSON(t, resp, &apiTeam)
- checkTeamResponse(t, "CreateTeam2", &apiTeam, teamToCreate.Name, teamToCreate.Description, teamToCreate.IncludesAllRepositories,
- "read", nil, teamToCreate.UnitsMap)
- checkTeamBean(t, apiTeam.ID, teamToCreate.Name, teamToCreate.Description, teamToCreate.IncludesAllRepositories,
- "read", nil, teamToCreate.UnitsMap)
- teamID = apiTeam.ID
-
- // Edit team.
- editDescription = "team 1"
- editFalse = false
- teamToEdit = &api.EditTeamOption{
- Name: "teamtwo",
- Description: &editDescription,
- Permission: "write",
- IncludesAllRepositories: &editFalse,
- UnitsMap: map[string]string{"repo.code": "read", "repo.pulls": "read", "repo.releases": "write"},
- }
-
- req = NewRequestWithJSON(t, "PATCH", fmt.Sprintf("/api/v1/teams/%d?token=%s", teamID, token), teamToEdit)
- resp = session.MakeRequest(t, req, http.StatusOK)
- apiTeam = api.Team{}
- DecodeJSON(t, resp, &apiTeam)
- checkTeamResponse(t, "EditTeam2", &apiTeam, teamToEdit.Name, *teamToEdit.Description, *teamToEdit.IncludesAllRepositories,
- "read", nil, teamToEdit.UnitsMap)
- checkTeamBean(t, apiTeam.ID, teamToEdit.Name, *teamToEdit.Description, *teamToEdit.IncludesAllRepositories,
- "read", nil, teamToEdit.UnitsMap)
-
- // Edit team Description only
- editDescription = "second team"
- teamToEditDesc = api.EditTeamOption{Description: &editDescription}
- req = NewRequestWithJSON(t, "PATCH", fmt.Sprintf("/api/v1/teams/%d?token=%s", teamID, token), teamToEditDesc)
- resp = session.MakeRequest(t, req, http.StatusOK)
- apiTeam = api.Team{}
- DecodeJSON(t, resp, &apiTeam)
- checkTeamResponse(t, "EditTeam2_DescOnly", &apiTeam, teamToEdit.Name, *teamToEditDesc.Description, *teamToEdit.IncludesAllRepositories,
- "read", nil, teamToEdit.UnitsMap)
- checkTeamBean(t, apiTeam.ID, teamToEdit.Name, *teamToEditDesc.Description, *teamToEdit.IncludesAllRepositories,
- "read", nil, teamToEdit.UnitsMap)
-
- // Read team.
- teamRead = unittest.AssertExistsAndLoadBean(t, &organization.Team{ID: teamID})
- req = NewRequestf(t, "GET", "/api/v1/teams/%d?token="+token, teamID)
- resp = session.MakeRequest(t, req, http.StatusOK)
- apiTeam = api.Team{}
- DecodeJSON(t, resp, &apiTeam)
- assert.NoError(t, teamRead.GetUnits())
- checkTeamResponse(t, "ReadTeam2", &apiTeam, teamRead.Name, *teamToEditDesc.Description, teamRead.IncludesAllRepositories,
- teamRead.AccessMode.String(), teamRead.GetUnitNames(), teamRead.GetUnitsMap())
-
- // Delete team.
- req = NewRequestf(t, "DELETE", "/api/v1/teams/%d?token="+token, teamID)
- session.MakeRequest(t, req, http.StatusNoContent)
- unittest.AssertNotExistsBean(t, &organization.Team{ID: teamID})
-}
-
-func checkTeamResponse(t *testing.T, testName string, apiTeam *api.Team, name, description string, includesAllRepositories bool, permission string, units []string, unitsMap map[string]string) {
- t.Run(testName, func(t *testing.T) {
- assert.Equal(t, name, apiTeam.Name, "name")
- assert.Equal(t, description, apiTeam.Description, "description")
- assert.Equal(t, includesAllRepositories, apiTeam.IncludesAllRepositories, "includesAllRepositories")
- assert.Equal(t, permission, apiTeam.Permission, "permission")
- if units != nil {
- sort.StringSlice(units).Sort()
- sort.StringSlice(apiTeam.Units).Sort()
- assert.EqualValues(t, units, apiTeam.Units, "units")
- }
- if unitsMap != nil {
- assert.EqualValues(t, unitsMap, apiTeam.UnitsMap, "unitsMap")
- }
- })
-}
-
-func checkTeamBean(t *testing.T, id int64, name, description string, includesAllRepositories bool, permission string, units []string, unitsMap map[string]string) {
- team := unittest.AssertExistsAndLoadBean(t, &organization.Team{ID: id})
- assert.NoError(t, team.GetUnits(), "GetUnits")
- apiTeam, err := convert.ToTeam(team)
- assert.NoError(t, err)
- checkTeamResponse(t, fmt.Sprintf("checkTeamBean/%s_%s", name, description), apiTeam, name, description, includesAllRepositories, permission, units, unitsMap)
-}
-
-type TeamSearchResults struct {
- OK bool `json:"ok"`
- Data []*api.Team `json:"data"`
-}
-
-func TestAPITeamSearch(t *testing.T) {
- defer prepareTestEnv(t)()
-
- user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
- org := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 17})
-
- var results TeamSearchResults
-
- token := getUserToken(t, user.Name)
- req := NewRequestf(t, "GET", "/api/v1/orgs/%s/teams/search?q=%s&token=%s", org.Name, "_team", token)
- resp := MakeRequest(t, req, http.StatusOK)
- DecodeJSON(t, resp, &results)
- assert.NotEmpty(t, results.Data)
- assert.Len(t, results.Data, 1)
- assert.Equal(t, "test_team", results.Data[0].Name)
-
- // no access if not organization member
- user5 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 5})
- token5 := getUserToken(t, user5.Name)
-
- req = NewRequestf(t, "GET", "/api/v1/orgs/%s/teams/search?q=%s&token=%s", org.Name, "team", token5)
- MakeRequest(t, req, http.StatusForbidden)
-}
-
-func TestAPIGetTeamRepo(t *testing.T) {
- defer prepareTestEnv(t)()
-
- user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 15})
- teamRepo := unittest.AssertExistsAndLoadBean(t, &repo.Repository{ID: 24})
- team := unittest.AssertExistsAndLoadBean(t, &organization.Team{ID: 5})
-
- var results api.Repository
-
- token := getUserToken(t, user.Name)
- req := NewRequestf(t, "GET", "/api/v1/teams/%d/repos/%s/?token=%s", team.ID, teamRepo.FullName(), token)
- resp := MakeRequest(t, req, http.StatusOK)
- DecodeJSON(t, resp, &results)
- assert.Equal(t, "big_test_private_4", teamRepo.Name)
-
- // no access if not organization member
- user5 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 5})
- token5 := getUserToken(t, user5.Name)
-
- req = NewRequestf(t, "GET", "/api/v1/teams/%d/repos/%s/?token=%s", team.ID, teamRepo.FullName(), token5)
- MakeRequest(t, req, http.StatusNotFound)
-}