You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
gitea/tests/integration
M Hickford 191a74d622
Record OAuth client type at registration (#21316)
The OAuth spec [defines two types of
client](https://datatracker.ietf.org/doc/html/rfc6749#section-2.1),
confidential and public. Previously Gitea assumed all clients to be
confidential.

> OAuth defines two client types, based on their ability to authenticate
securely with the authorization server (i.e., ability to
>   maintain the confidentiality of their client credentials):
>
>   confidential
> Clients capable of maintaining the confidentiality of their
credentials (e.g., client implemented on a secure server with
> restricted access to the client credentials), or capable of secure
client authentication using other means.
>
>   **public
> Clients incapable of maintaining the confidentiality of their
credentials (e.g., clients executing on the device used by the resource
owner, such as an installed native application or a web browser-based
application), and incapable of secure client authentication via any
other means.**
>
> The client type designation is based on the authorization server's
definition of secure authentication and its acceptable exposure levels
of client credentials. The authorization server SHOULD NOT make
assumptions about the client type.

 https://datatracker.ietf.org/doc/html/rfc8252#section-8.4

> Authorization servers MUST record the client type in the client
registration details in order to identify and process requests
accordingly.

Require PKCE for public clients:
https://datatracker.ietf.org/doc/html/rfc8252#section-8.1

> Authorization servers SHOULD reject authorization requests from native
apps that don't use PKCE by returning an error message

Fixes #21299

Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
2 years ago
..
migration-test Kd/ci playwright go test (#20123) 2 years ago
README.md Kd/ci playwright go test (#20123) 2 years ago
README_ZH.md Kd/ci playwright go test (#20123) 2 years ago
admin_user_test.go Kd/ci playwright go test (#20123) 2 years ago
api_activitypub_person_test.go Kd/ci playwright go test (#20123) 2 years ago
api_admin_org_test.go Add name field for org api (#21270) 2 years ago
api_admin_test.go Add some api integration tests (#18872) 2 years ago
api_branch_test.go Kd/ci playwright go test (#20123) 2 years ago
api_comment_test.go Kd/ci playwright go test (#20123) 2 years ago
api_feed_user_test.go Add some api integration tests (#18872) 2 years ago
api_fork_test.go Kd/ci playwright go test (#20123) 2 years ago
api_gpg_keys_test.go Kd/ci playwright go test (#20123) 2 years ago
api_helper_for_declarative_test.go Kd/ci playwright go test (#20123) 2 years ago
api_httpsig_test.go Kd/ci playwright go test (#20123) 2 years ago
api_issue_label_test.go Kd/ci playwright go test (#20123) 2 years ago
api_issue_milestone_test.go Kd/ci playwright go test (#20123) 2 years ago
api_issue_reaction_test.go Kd/ci playwright go test (#20123) 2 years ago
api_issue_stopwatch_test.go Kd/ci playwright go test (#20123) 2 years ago
api_issue_subscription_test.go Kd/ci playwright go test (#20123) 2 years ago
api_issue_test.go Kd/ci playwright go test (#20123) 2 years ago
api_issue_tracked_time_test.go Kd/ci playwright go test (#20123) 2 years ago
api_keys_test.go Kd/ci playwright go test (#20123) 2 years ago
api_nodeinfo_test.go Fix user visible check (#21210) 2 years ago
api_notification_test.go Kd/ci playwright go test (#20123) 2 years ago
api_oauth2_apps_test.go Record OAuth client type at registration (#21316) 2 years ago
api_org_test.go Add name field for org api (#21270) 2 years ago
api_packages_composer_test.go Kd/ci playwright go test (#20123) 2 years ago
api_packages_conan_test.go Set SemverCompatible to false for Conan packages (#21275) 2 years ago
api_packages_container_test.go Add GET and DELETE endpoints for Docker blob uploads (#21367) 2 years ago
api_packages_generic_test.go Respect `REQUIRE_SIGNIN_VIEW` for packages (#20873) 2 years ago
api_packages_helm_test.go Kd/ci playwright go test (#20123) 2 years ago
api_packages_maven_test.go Kd/ci playwright go test (#20123) 2 years ago
api_packages_npm_test.go npm package registry support for `bin` (#21372) 2 years ago
api_packages_nuget_test.go Enforce grouped NuGet search results (#21442) 2 years ago
api_packages_pub_test.go Kd/ci playwright go test (#20123) 2 years ago
api_packages_pypi_test.go Kd/ci playwright go test (#20123) 2 years ago
api_packages_rubygems_test.go Kd/ci playwright go test (#20123) 2 years ago
api_packages_test.go Kd/ci playwright go test (#20123) 2 years ago
api_packages_vagrant_test.go Kd/ci playwright go test (#20123) 2 years ago
api_private_serv_test.go Kd/ci playwright go test (#20123) 2 years ago
api_pull_commits_test.go Kd/ci playwright go test (#20123) 2 years ago
api_pull_review_test.go Kd/ci playwright go test (#20123) 2 years ago
api_pull_test.go Add API endpoint to get changed files of a PR (#21177) 2 years ago
api_releases_test.go Kd/ci playwright go test (#20123) 2 years ago
api_repo_archive_test.go Kd/ci playwright go test (#20123) 2 years ago
api_repo_collaborator_test.go Kd/ci playwright go test (#20123) 2 years ago
api_repo_edit_test.go Make external issue tracker regexp configurable via API (#21338) 2 years ago
api_repo_file_create_test.go Kd/ci playwright go test (#20123) 2 years ago
api_repo_file_delete_test.go Kd/ci playwright go test (#20123) 2 years ago
api_repo_file_get_test.go test: use `T.TempDir` to create temporary test directory (#21043) 2 years ago
api_repo_file_helpers.go Kd/ci playwright go test (#20123) 2 years ago
api_repo_file_update_test.go Kd/ci playwright go test (#20123) 2 years ago
api_repo_get_contents_list_test.go Kd/ci playwright go test (#20123) 2 years ago
api_repo_get_contents_test.go Kd/ci playwright go test (#20123) 2 years ago
api_repo_git_blobs_test.go Kd/ci playwright go test (#20123) 2 years ago
api_repo_git_commits_test.go Kd/ci playwright go test (#20123) 2 years ago
api_repo_git_hook_test.go Kd/ci playwright go test (#20123) 2 years ago
api_repo_git_notes_test.go Kd/ci playwright go test (#20123) 2 years ago
api_repo_git_ref_test.go Kd/ci playwright go test (#20123) 2 years ago
api_repo_git_tags_test.go Refactor git command arguments and make all arguments to be safe to be used (#21535) 2 years ago
api_repo_git_trees_test.go Kd/ci playwright go test (#20123) 2 years ago
api_repo_languages_test.go Kd/ci playwright go test (#20123) 2 years ago
api_repo_lfs_locks_test.go Use Name instead of DisplayName in LFS Lock (#21415) 2 years ago
api_repo_lfs_migrate_test.go Kd/ci playwright go test (#20123) 2 years ago
api_repo_lfs_test.go Kd/ci playwright go test (#20123) 2 years ago
api_repo_raw_test.go Kd/ci playwright go test (#20123) 2 years ago
api_repo_tags_test.go Kd/ci playwright go test (#20123) 2 years ago
api_repo_teams_test.go Kd/ci playwright go test (#20123) 2 years ago
api_repo_test.go test: use `T.TempDir` to create temporary test directory (#21043) 2 years ago
api_repo_topic_test.go Kd/ci playwright go test (#20123) 2 years ago
api_settings_test.go Kd/ci playwright go test (#20123) 2 years ago
api_team_test.go Kd/ci playwright go test (#20123) 2 years ago
api_team_user_test.go Kd/ci playwright go test (#20123) 2 years ago
api_token_test.go Kd/ci playwright go test (#20123) 2 years ago
api_user_email_test.go Kd/ci playwright go test (#20123) 2 years ago
api_user_follow_test.go Add some api integration tests (#18872) 2 years ago
api_user_heatmap_test.go Kd/ci playwright go test (#20123) 2 years ago
api_user_info_test.go Add some api integration tests (#18872) 2 years ago
api_user_org_perm_test.go Kd/ci playwright go test (#20123) 2 years ago
api_user_orgs_test.go Add name field for org api (#21270) 2 years ago
api_user_search_test.go Kd/ci playwright go test (#20123) 2 years ago
api_user_star_test.go Add some api integration tests (#18872) 2 years ago
api_user_watch_test.go Add some api integration tests (#18872) 2 years ago
api_wiki_test.go Kd/ci playwright go test (#20123) 2 years ago
attachment_test.go Kd/ci playwright go test (#20123) 2 years ago
auth_ldap_test.go Kd/ci playwright go test (#20123) 2 years ago
benchmarks_test.go Kd/ci playwright go test (#20123) 2 years ago
branches_test.go Kd/ci playwright go test (#20123) 2 years ago
change_default_branch_test.go Kd/ci playwright go test (#20123) 2 years ago
cmd_keys_test.go Kd/ci playwright go test (#20123) 2 years ago
compare_test.go Move go-licenses to generate and separate generate into a frontend and backend component (#21061) 2 years ago
cors_test.go Move go-licenses to generate and separate generate into a frontend and backend component (#21061) 2 years ago
create_no_session_test.go test: use `T.TempDir` to create temporary test directory (#21043) 2 years ago
csrf_test.go Kd/ci playwright go test (#20123) 2 years ago
delete_user_test.go Kd/ci playwright go test (#20123) 2 years ago
download_test.go Kd/ci playwright go test (#20123) 2 years ago
dump_restore_test.go Kd/ci playwright go test (#20123) 2 years ago
editor_test.go Kd/ci playwright go test (#20123) 2 years ago
empty_repo_test.go Kd/ci playwright go test (#20123) 2 years ago
eventsource_test.go Kd/ci playwright go test (#20123) 2 years ago
explore_repos_test.go Kd/ci playwright go test (#20123) 2 years ago
git_clone_wiki_test.go Refactor git command arguments and make all arguments to be safe to be used (#21535) 2 years ago
git_helper_for_declarative_test.go Refactor git command arguments and make all arguments to be safe to be used (#21535) 2 years ago
git_smart_http_test.go Kd/ci playwright go test (#20123) 2 years ago
git_test.go Refactor git command arguments and make all arguments to be safe to be used (#21535) 2 years ago
goget_test.go Kd/ci playwright go test (#20123) 2 years ago
gpg_git_test.go test: use `T.TempDir` to create temporary test directory (#21043) 2 years ago
html_helper.go Kd/ci playwright go test (#20123) 2 years ago
integration_test.go Check for valid user token in integration tests (#21520) 2 years ago
issue_test.go Kd/ci playwright go test (#20123) 2 years ago
lfs_getobject_test.go Kd/ci playwright go test (#20123) 2 years ago
lfs_local_endpoint_test.go test: use `T.TempDir` to create temporary test directory (#21043) 2 years ago
links_test.go Kd/ci playwright go test (#20123) 2 years ago
migrate_test.go test: use `T.TempDir` to create temporary test directory (#21043) 2 years ago
mirror_pull_test.go Kd/ci playwright go test (#20123) 2 years ago
mirror_push_test.go Kd/ci playwright go test (#20123) 2 years ago
nonascii_branches_test.go Move go-licenses to generate and separate generate into a frontend and backend component (#21061) 2 years ago
oauth_test.go Record OAuth client type at registration (#21316) 2 years ago
org_count_test.go Kd/ci playwright go test (#20123) 2 years ago
org_team_invite_test.go Add team member invite by email (#20307) 2 years ago
org_test.go Kd/ci playwright go test (#20123) 2 years ago
private-testing.key Kd/ci playwright go test (#20123) 2 years ago
privateactivity_test.go Kd/ci playwright go test (#20123) 2 years ago
pull_compare_test.go Move go-licenses to generate and separate generate into a frontend and backend component (#21061) 2 years ago
pull_create_test.go Move go-licenses to generate and separate generate into a frontend and backend component (#21061) 2 years ago
pull_merge_test.go Refactor git command arguments and make all arguments to be safe to be used (#21535) 2 years ago
pull_review_test.go Kd/ci playwright go test (#20123) 2 years ago
pull_status_test.go Fix various typos (#21103) 2 years ago
pull_update_test.go Kd/ci playwright go test (#20123) 2 years ago
release_test.go Kd/ci playwright go test (#20123) 2 years ago
rename_branch_test.go Kd/ci playwright go test (#20123) 2 years ago
repo_activity_test.go Kd/ci playwright go test (#20123) 2 years ago
repo_branch_test.go Kd/ci playwright go test (#20123) 2 years ago
repo_commits_search_test.go Move go-licenses to generate and separate generate into a frontend and backend component (#21061) 2 years ago
repo_commits_test.go Kd/ci playwright go test (#20123) 2 years ago
repo_fork_test.go Kd/ci playwright go test (#20123) 2 years ago
repo_generate_test.go Kd/ci playwright go test (#20123) 2 years ago
repo_migrate_test.go Kd/ci playwright go test (#20123) 2 years ago
repo_search_test.go Kd/ci playwright go test (#20123) 2 years ago
repo_tag_test.go test: use `T.TempDir` to create temporary test directory (#21043) 2 years ago
repo_test.go Fix #21406: Hide repo information from file view/blame mode (#21420) 2 years ago
repo_topic_test.go Kd/ci playwright go test (#20123) 2 years ago
repo_watch_test.go Kd/ci playwright go test (#20123) 2 years ago
repofiles_delete_test.go Kd/ci playwright go test (#20123) 2 years ago
repofiles_update_test.go Kd/ci playwright go test (#20123) 2 years ago
setting_test.go Kd/ci playwright go test (#20123) 2 years ago
signin_test.go Kd/ci playwright go test (#20123) 2 years ago
signout_test.go Kd/ci playwright go test (#20123) 2 years ago
signup_test.go Kd/ci playwright go test (#20123) 2 years ago
ssh_key_test.go test: use `T.TempDir` to create temporary test directory (#21043) 2 years ago
timetracking_test.go Kd/ci playwright go test (#20123) 2 years ago
user_avatar_test.go Kd/ci playwright go test (#20123) 2 years ago
user_test.go Kd/ci playwright go test (#20123) 2 years ago
version_test.go Kd/ci playwright go test (#20123) 2 years ago
view_test.go Move go-licenses to generate and separate generate into a frontend and backend component (#21061) 2 years ago
webfinger_test.go Kd/ci playwright go test (#20123) 2 years ago
xss_test.go Kd/ci playwright go test (#20123) 2 years ago

README.md

Integration tests

Integration tests can be run with make commands for the appropriate backends, namely:

make test-sqlite
make test-pgsql
make test-mysql
make test-mysql8
make test-mssql

Make sure to perform a clean build before running tests:

make clean build

Run all tests via local drone

drone exec --local --build-event "pull_request"

Run sqlite integration tests

Start tests

make test-sqlite

Run MySQL integration tests

Setup a MySQL database inside docker

docker run -e "MYSQL_DATABASE=test" -e "MYSQL_ALLOW_EMPTY_PASSWORD=yes" -p 3306:3306 --rm --name mysql mysql:latest #(just ctrl-c to stop db and clean the container)
docker run -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" --rm --name elasticsearch elasticsearch:7.6.0 #(in a second terminal, just ctrl-c to stop db and clean the container)

Start tests based on the database container

TEST_MYSQL_HOST=localhost:3306 TEST_MYSQL_DBNAME=test TEST_MYSQL_USERNAME=root TEST_MYSQL_PASSWORD='' make test-mysql

Run pgsql integration tests

Setup a pgsql database inside docker

docker run -e "POSTGRES_DB=test" -p 5432:5432 --rm --name pgsql postgres:latest #(just ctrl-c to stop db and clean the container)

Start tests based on the database container

TEST_PGSQL_HOST=localhost:5432 TEST_PGSQL_DBNAME=test TEST_PGSQL_USERNAME=postgres TEST_PGSQL_PASSWORD=postgres make test-pgsql

Run mssql integration tests

Setup a mssql database inside docker

docker run -e "ACCEPT_EULA=Y" -e "MSSQL_PID=Standard" -e "SA_PASSWORD=MwantsaSecurePassword1" -p 1433:1433 --rm --name mssql microsoft/mssql-server-linux:latest #(just ctrl-c to stop db and clean the container)

Start tests based on the database container

TEST_MSSQL_HOST=localhost:1433 TEST_MSSQL_DBNAME=gitea_test TEST_MSSQL_USERNAME=sa TEST_MSSQL_PASSWORD=MwantsaSecurePassword1 make test-mssql

Running individual tests

Example command to run GPG test:

For SQLite:

make test-sqlite#GPG

For other databases(replace mssql to mysql, mysql8 or pgsql):

TEST_MSSQL_HOST=localhost:1433 TEST_MSSQL_DBNAME=test TEST_MSSQL_USERNAME=sa TEST_MSSQL_PASSWORD=MwantsaSecurePassword1 make test-mssql#GPG

Setting timeouts for declaring long-tests and long-flushes

We appreciate that some testing machines may not be very powerful and the default timeouts for declaring a slow test or a slow clean-up flush may not be appropriate.

You can either:

  • Within the test ini file set the following section:
[integration-tests]
SLOW_TEST = 10s ; 10s is the default value
SLOW_FLUSH = 5S ; 5s is the default value
  • Set the following environment variables:
GITEA_SLOW_TEST_TIME="10s" GITEA_SLOW_FLUSH_TIME="5s" make test-sqlite