aboutsummaryrefslogtreecommitdiffstats
path: root/integrations/links_test.go
diff options
context:
space:
mode:
authorKyle D <kdumontnu@gmail.com>2022-09-02 15:18:23 -0400
committerGitHub <noreply@github.com>2022-09-02 15:18:23 -0400
commitc8ded77680db7344c8dc1ccee76bce0b4e02e103 (patch)
treebc63678ef62dc71ce68b29eeaf019c45cdb12034 /integrations/links_test.go
parent5710ff343c9f16119ddbff06044e5d61388baa22 (diff)
downloadgitea-c8ded77680db7344c8dc1ccee76bce0b4e02e103.tar.gz
gitea-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/links_test.go')
-rw-r--r--integrations/links_test.go175
1 files changed, 0 insertions, 175 deletions
diff --git a/integrations/links_test.go b/integrations/links_test.go
deleted file mode 100644
index d0cf978f65..0000000000
--- a/integrations/links_test.go
+++ /dev/null
@@ -1,175 +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"
- "path"
- "testing"
-
- "code.gitea.io/gitea/modules/setting"
- api "code.gitea.io/gitea/modules/structs"
- "code.gitea.io/gitea/modules/test"
-
- "github.com/stretchr/testify/assert"
-)
-
-func TestLinksNoLogin(t *testing.T) {
- defer prepareTestEnv(t)()
-
- links := []string{
- "/explore/repos",
- "/explore/repos?q=test",
- "/explore/users",
- "/explore/users?q=test",
- "/explore/organizations",
- "/explore/organizations?q=test",
- "/",
- "/user/sign_up",
- "/user/login",
- "/user/forgot_password",
- "/api/swagger",
- "/user2/repo1",
- "/user2/repo1/",
- "/user2/repo1/projects",
- "/user2/repo1/projects/1",
- "/assets/img/404.png",
- "/assets/img/500.png",
- }
-
- for _, link := range links {
- req := NewRequest(t, "GET", link)
- MakeRequest(t, req, http.StatusOK)
- }
-}
-
-func TestRedirectsNoLogin(t *testing.T) {
- defer prepareTestEnv(t)()
-
- redirects := map[string]string{
- "/user2/repo1/commits/master": "/user2/repo1/commits/branch/master",
- "/user2/repo1/src/master": "/user2/repo1/src/branch/master",
- "/user2/repo1/src/master/file.txt": "/user2/repo1/src/branch/master/file.txt",
- "/user2/repo1/src/master/directory/file.txt": "/user2/repo1/src/branch/master/directory/file.txt",
- "/user/avatar/Ghost/-1": "/assets/img/avatar_default.png",
- "/api/v1/swagger": "/api/swagger",
- }
- for link, redirectLink := range redirects {
- req := NewRequest(t, "GET", link)
- resp := MakeRequest(t, req, http.StatusSeeOther)
- assert.EqualValues(t, path.Join(setting.AppSubURL, redirectLink), test.RedirectURL(resp))
- }
-}
-
-func TestNoLoginNotExist(t *testing.T) {
- defer prepareTestEnv(t)()
-
- links := []string{
- "/user5/repo4/projects",
- "/user5/repo4/projects/3",
- }
-
- for _, link := range links {
- req := NewRequest(t, "GET", link)
- MakeRequest(t, req, http.StatusNotFound)
- }
-}
-
-func testLinksAsUser(userName string, t *testing.T) {
- links := []string{
- "/explore/repos",
- "/explore/repos?q=test",
- "/explore/users",
- "/explore/users?q=test",
- "/explore/organizations",
- "/explore/organizations?q=test",
- "/",
- "/user/forgot_password",
- "/api/swagger",
- "/issues",
- "/issues?type=your_repositories&repos=[0]&sort=&state=open",
- "/issues?type=assigned&repos=[0]&sort=&state=open",
- "/issues?type=your_repositories&repos=[0]&sort=&state=closed",
- "/issues?type=assigned&repos=[]&sort=&state=closed",
- "/issues?type=assigned&sort=&state=open",
- "/issues?type=created_by&repos=[1,2]&sort=&state=closed",
- "/issues?type=created_by&repos=[1,2]&sort=&state=open",
- "/pulls",
- "/pulls?type=your_repositories&repos=[2]&sort=&state=open",
- "/pulls?type=assigned&repos=[]&sort=&state=open",
- "/pulls?type=created_by&repos=[0]&sort=&state=open",
- "/pulls?type=your_repositories&repos=[0]&sort=&state=closed",
- "/pulls?type=assigned&repos=[0]&sort=&state=closed",
- "/pulls?type=created_by&repos=[0]&sort=&state=closed",
- "/milestones",
- "/milestones?sort=mostcomplete&state=closed",
- "/milestones?type=your_repositories&sort=mostcomplete&state=closed",
- "/milestones?sort=&repos=[1]&state=closed",
- "/milestones?sort=&repos=[1]&state=open",
- "/milestones?repos=[0]&sort=mostissues&state=open",
- "/notifications",
- "/repo/create",
- "/repo/migrate",
- "/org/create",
- "/user2",
- "/user2?tab=stars",
- "/user2?tab=activity",
- "/user/settings",
- "/user/settings/account",
- "/user/settings/security",
- "/user/settings/security/two_factor/enroll",
- "/user/settings/keys",
- "/user/settings/organization",
- "/user/settings/repos",
- }
-
- session := loginUser(t, userName)
- for _, link := range links {
- req := NewRequest(t, "GET", link)
- session.MakeRequest(t, req, http.StatusOK)
- }
-
- reqAPI := NewRequestf(t, "GET", "/api/v1/users/%s/repos", userName)
- respAPI := MakeRequest(t, reqAPI, http.StatusOK)
-
- var apiRepos []*api.Repository
- DecodeJSON(t, respAPI, &apiRepos)
-
- repoLinks := []string{
- "",
- "/issues",
- "/pulls",
- "/commits/branch/master",
- "/graph",
- "/settings",
- "/settings/collaboration",
- "/settings/branches",
- "/settings/hooks",
- // FIXME: below links should return 200 but 404 ??
- //"/settings/hooks/git",
- //"/settings/hooks/git/pre-receive",
- //"/settings/hooks/git/update",
- //"/settings/hooks/git/post-receive",
- "/settings/keys",
- "/releases",
- "/releases/new",
- //"/wiki/_pages",
- "/wiki/?action=_new",
- }
-
- for _, repo := range apiRepos {
- for _, link := range repoLinks {
- req := NewRequest(t, "GET", fmt.Sprintf("/%s/%s%s", userName, repo.Name, link))
- session.MakeRequest(t, req, http.StatusOK)
- }
- }
-}
-
-func TestLinksLogin(t *testing.T) {
- defer prepareTestEnv(t)()
-
- testLinksAsUser("user2", t)
-}