.. | ||
.confiner | ||
bin | ||
contracts | ||
knapsack | ||
lib | ||
qa | ||
spec | ||
tasks | ||
tls_certificates | ||
.gitignore | ||
.rspec | ||
.rspec_internal | ||
.rspec_parallel | ||
chemlab-library-gitlab.gemspec | ||
Dockerfile | ||
Gemfile | ||
Gemfile.lock | ||
qa.rb | ||
Rakefile | ||
README.md |
GitLab QA - End-to-end tests for GitLab
This directory contains end-to-end tests for GitLab. It includes the test framework and the tests themselves.
The tests can be found in qa/specs/features
(not to be confused with the unit
tests for the test framework, which are in spec/
).
It is part of the GitLab QA project.
What is it?
GitLab QA is an end-to-end tests suite for GitLab.
These are black-box and entirely click-driven end-to-end tests you can run against any existing instance.
How does it work?
- When we release a new version of GitLab, we build a Docker images for it.
- Along with GitLab Docker Images we also build and publish GitLab QA images.
- GitLab QA project uses these images to execute end-to-end tests.
Validating GitLab views / partials / selectors in merge requests
We recently added a new CI job that is going to be triggered for every push
event in CE and EE projects. The job is called qa:selectors
and it will
verify coupling between page objects implemented as a part of GitLab QA
and corresponding views / partials / selectors in CE / EE.
Whenever qa:selectors
job fails in your merge request, you are supposed to
fix page objects. You should also trigger end-to-end tests
using package-and-qa
manual action, to test if everything works fine.
How can I use it?
You can use GitLab QA to exercise tests on any live instance! If you don't have an instance available you can follow the instructions below to use the GitLab Development Kit (GDK). This is the recommended option if you would like to contribute to the tests.
Note that tests are using Chrome
web browser by default so it should be installed and present in PATH
.
Writing tests
Run the end-to-end tests in a local development environment
Follow the GDK instructions to install your local GitLab development environment.
Once you have GDK running, switch to the qa
directory. E.g., if you setup
GDK to develop in the main gitlab-ce
repo, the GitLab source code will be
in a gitlab
directory and so the end-to-end test code will be in gitlab/qa
.
Make sure to install the dependencies first with bundle install
.
Most tests that do not require special setup could simply be run with:
bundle exec rspec <path/to/spec.rb>
However, tests that are tagged with :orchestrated
tag require special setup. These tests can only be run with bin/qa script.
Note: If you want to run tests requiring SSH against GDK, you will need to modify your GDK setup.
Note: When you log into your GDK instance of GitLab for the first time, the root password requires a change.
GitLab QA expects the default initial password to be used in tests; see all default values listed in
Supported GitLab environment variables.
If you have changed your root password, you must set the GITLAB_INITIAL_ROOT_PASSWORD
environment
variable.
export GITLAB_INITIAL_ROOT_PASSWORD="<GDK root password>"
Running EE tests
When running EE tests you'll need to have a license available. GitLab engineers can request a license.
Once you have the license file you can export it as an environment variable and then the framework can use it. If you do so it will be installed automatically.
export EE_LICENSE=$(cat /path/to/gitlab_license)
Running specific tests
You can also supply specific tests to run as another parameter. For example, to run the repository-related specs, you can execute:
bundle exec rspec qa/specs/features/browser_ui/3_create/repository
Running tests for transient bugs
A suite of tests have been written to test for transient bugs.
Those tests are tagged :transient
and therefore can be run via:
bundle exec rspec --tag transient
Overriding gitlab address
When running tests against GDK, the default address is http://127.0.0.1:3000
. This value can be overridden by providing environment variable QA_GITLAB_URL
:
QA_GITLAB_URL=https://gdk.test:3000 bundle exec rspec
Overriding the authenticated user
Unless told otherwise, the QA tests will run as the default root
user seeded
by the GDK.
If you need to authenticate as a different user, you can provide the
GITLAB_USERNAME
and GITLAB_PASSWORD
environment variables:
GITLAB_USERNAME=jsmith GITLAB_PASSWORD=password bundle exec rspec
Some QA tests require logging in as an admin user. By default, the QA
tests will use the same root
user seeded by the GDK.
If you need to authenticate with different admin credentials, you can
provide the GITLAB_ADMIN_USERNAME
and GITLAB_ADMIN_PASSWORD
environment variables:
GITLAB_ADMIN_USERNAME=admin GITLAB_ADMIN_PASSWORD=myadminpassword GITLAB_USERNAME=jsmith GITLAB_PASSWORD=password bundle exec rspec
If your user doesn't have permission to default sandbox group
gitlab-qa-sandbox
, you could also use another sandbox group by giving
GITLAB_SANDBOX_NAME
:
GITLAB_USERNAME=jsmith GITLAB_PASSWORD=password GITLAB_SANDBOX_NAME=jsmith-qa-sandbox bundle exec rspec
All supported environment variables are here.
Sending additional cookies
The environment variable QA_COOKIES
can be set to send additional cookies
on every request. This is necessary on gitlab.com to direct traffic to the
canary fleet. To do this set QA_COOKIES="gitlab_canary=true"
.
To set multiple cookies, separate them with the ;
character, for example: QA_COOKIES="cookie1=value;cookie2=value2"
Building a Docker image to test
Once you have made changes to the CE/EE repositories, you may want to build a
Docker image to test locally instead of waiting for the gitlab-ce-qa
or
gitlab-ee-qa
nightly builds. To do that, you can run from the top gitlab
directory (one level up from this directory):
docker build -t gitlab/gitlab-ce-qa:nightly --file ./qa/Dockerfile ./
Quarantined tests
Tests can be put in quarantine by assigning :quarantine
metadata. This means
they will be skipped unless run with --tag quarantine
. This can be used for
tests that are expected to fail while a fix is in progress (similar to how
skip
or pending
can be used).
bundle exec rspec --tag quarantine
Running tests with a custom bin/qa test runner
bin/qa
is an additional custom wrapper script that abstracts away some of the more complicated setups that some tests require. This option requires test scenario and test instance's Gitlab address to be specified in the command. For example, to run any Instance
scenario test, the following command can be used:
bundle exec bin/qa Test::Instance::All http://localhost:3000
Running tests with a feature flag enabled or disabled
Tests can be run with a feature flag enabled or disabled by using the command-line
option --enable-feature FEATURE_FLAG
or --disable-feature FEATURE_FLAG
.
For example, to enable the feature flag that enforces Gitaly request limits, you would use the command:
bundle exec bin/qa Test::Instance::All http://localhost:3000 --enable-feature gitaly_enforce_requests_limits
This will instruct the QA framework to enable the gitaly_enforce_requests_limits
feature flag (via the API), run
all the tests in the Test::Instance::All
scenario, and then disable the
feature flag again.
Similarly, to disable the feature flag that enforces Gitaly request limits, you would use the command:
bundle exec bin/qa Test::Instance::All http://localhost:3000 --disable-feature gitaly_enforce_requests_limits
This will instruct the QA framework to disable the gitaly_enforce_requests_limits
feature flag (via the API) if not already disabled,
run all the tests in the Test::Instance::All
scenario, and then enable the
feature flag again if it was enabled earlier.
Note: the QA framework doesn't currently allow you to easily toggle a feature flag during a single test, as you can in unit tests, but that capability is planned.
Note also that the --
separator isn't used because --enable-feature
and --disable-feature
are QA framework options, not rspec
options.