2019-07-07 11:18:12 +05:30
# GitLab QA - End-to-end tests for GitLab
2017-08-17 22:00:37 +05:30
2019-09-04 21:01:54 +05:30
This directory contains [end-to-end tests ](../../../doc/development/testing_guide/end_to_end/index.md )
2019-07-07 11:18:12 +05:30
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/` ).
2017-08-17 22:00:37 +05:30
2018-03-17 18:26:18 +05:30
It is part of the [GitLab QA project ](https://gitlab.com/gitlab-org/gitlab-qa ).
2017-08-17 22:00:37 +05:30
2018-03-17 18:26:18 +05:30
## What is it?
2017-08-17 22:00:37 +05:30
2019-07-07 11:18:12 +05:30
GitLab QA is an end-to-end tests suite for GitLab.
2017-08-17 22:00:37 +05:30
2019-07-07 11:18:12 +05:30
These are black-box and entirely click-driven end-to-end tests you can run
2017-08-17 22:00:37 +05:30
against any existing instance.
## How does it work?
1. When we release a new version of GitLab, we build a Docker images for it.
1. Along with GitLab Docker Images we also build and publish GitLab QA images.
2019-07-07 11:18:12 +05:30
1. GitLab QA project uses these images to execute end-to-end tests.
2018-03-17 18:26:18 +05:30
## 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
2019-09-04 21:01:54 +05:30
fix [page objects ](../doc/development/testing_guide/end_to_end/page_objects.md ). You should also trigger end-to-end tests
2020-03-13 15:44:24 +05:30
using `package-and-qa` manual action, to test if everything works fine.
2018-03-17 18:26:18 +05:30
## How can I use it?
2019-09-30 21:07:59 +05:30
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
2019-12-04 20:38:33 +05:30
the [GitLab Development Kit (GDK) ](https://gitlab.com/gitlab-org/gitlab-development-kit ).
2019-09-30 21:07:59 +05:30
This is the recommended option if you would like to contribute to the tests.
2019-12-04 20:38:33 +05:30
Note: GitLab QA uses [Selenium WebDriver ](https://www.seleniumhq.org/ ) via
[Cabybara ](http://teamcapybara.github.io/capybara/ ), and by default it targets Chrome as
the browser to use. You will need to have Chrome (or Chromium) and
[chromedriver ](https://chromedriver.chromium.org/ ) installed / in your `$PATH` .
2020-04-08 14:13:33 +05:30
### Writing tests
2020-05-24 23:13:21 +05:30
- [Writing tests from scratch tutorial ](../doc/development/testing_guide/end_to_end/beginners_guide.md )
2020-04-08 14:13:33 +05:30
- [Best practices ](../doc/development/testing_guide/best_practices.md )
- [Using page objects ](../doc/development/testing_guide/end_to_end/page_objects.md )
- [Guidelines ](../doc/development/testing_guide/index.md )
2021-01-03 14:25:43 +05:30
- [Tests with special setup for local environments ](../doc/development/testing_guide/end_to_end/running_tests_that_require_special_setup.md )
2020-04-08 14:13:33 +05:30
2019-09-30 21:07:59 +05:30
### Run the end-to-end tests in a local development environment
Follow the GDK instructions to [prepare ](https://gitlab.com/gitlab-org/gitlab-development-kit/blob/master/doc/prepare.md )
and [install ](https://gitlab.com/gitlab-org/gitlab-development-kit/blob/master/doc/set-up-gdk.md )
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` .
From there you can run the tests. For example, the
following call would login to the GDK instance and run all specs in
2018-03-17 18:26:18 +05:30
`qa/specs/features` :
```
2019-07-31 22:56:46 +05:30
# Make sure to install the dependencies first with `bundle install`
bundle exec bin/qa Test::Instance::All http://localhost:3000
2018-03-17 18:26:18 +05:30
```
2019-07-07 11:18:12 +05:30
Note: If you want to run tests requiring SSH against GDK, you
will need to [modify your GDK setup ](https://gitlab.com/gitlab-org/gitlab-qa/blob/master/docs/run_qa_against_gdk.md ).
2020-03-13 15:44:24 +05:30
#### Running EE tests
When running EE tests you'll need to have a license available. GitLab engineers can [request a license ](https://about.gitlab.com/handbook/developer-onboarding/#working-on-gitlab-ee ).
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)
```
2018-03-17 18:26:18 +05:30
### 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:
```
2019-09-30 21:07:59 +05:30
bundle exec bin/qa Test::Instance::All http://localhost:3000 -- qa/specs/features/browser_ui/3_create/repository
2018-03-17 18:26:18 +05:30
```
Since the arguments would be passed to `rspec` , you could use all `rspec`
options there. For example, passing `--backtrace` and also line number:
```
2019-09-30 21:07:59 +05:30
bundle exec bin/qa Test::Instance::All http://localhost:3000 -- qa/specs/features/browser_ui/3_create/merge_request/create_merge_request_spec.rb:6 --backtrace
2018-03-17 18:26:18 +05:30
```
2019-07-07 11:18:12 +05:30
Note that the separator `--` is required; all subsequent options will be
ignored by the QA framework and passed to `rspec` .
2021-03-11 19:13:27 +05:30
#### Running tests for transient bugs
A suite of tests have been written to test for [transient bugs ](https://about.gitlab.com/handbook/engineering/quality/issue-triage/#transient-bugs ).
Those tests are tagged `:transient` and therefore can be run via:
```shell
bundle exec bin/qa Test::Instance::All http://localhost:3000 -- --tag transient
```
2018-03-17 18:26:18 +05:30
### 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:
```
2019-07-31 22:56:46 +05:30
GITLAB_USERNAME=jsmith GITLAB_PASSWORD=password bundle exec bin/qa Test::Instance::All https://gitlab.example.com
2018-03-17 18:26:18 +05:30
```
2019-12-04 20:38:33 +05:30
Some QA tests require logging in as an admin user. By default, the QA
tests will use the 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 bin/qa Test::Instance::All https://gitlab.example.com
```
2018-03-27 19:54:05 +05:30
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` :
```
2019-07-31 22:56:46 +05:30
GITLAB_USERNAME=jsmith GITLAB_PASSWORD=password GITLAB_SANDBOX_NAME=jsmith-qa-sandbox bundle exec bin/qa Test::Instance::All https://gitlab.example.com
2018-03-27 19:54:05 +05:30
```
2018-12-05 23:21:45 +05:30
All [supported environment variables are here ](https://gitlab.com/gitlab-org/gitlab-qa/blob/master/docs/what_tests_can_be_run.md#supported-environment-variables ).
2018-03-17 18:26:18 +05:30
2019-02-15 15:39:39 +05:30
### 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"` .
2019-03-02 22:35:43 +05:30
To set multiple cookies, separate them with the `;` character, for example: `QA_COOKIES="cookie1=value;cookie2=value2"`
2019-02-15 15:39:39 +05:30
2018-03-27 19:54:05 +05:30
### 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
2019-10-12 21:52:04 +05:30
`gitlab-ee-qa` nightly builds. To do that, you can run **from the top `gitlab`
directory** (one level up from this directory):
2018-03-27 19:54:05 +05:30
```sh
2019-10-12 21:52:04 +05:30
docker build -t gitlab/gitlab-ce-qa:nightly --file ./qa/Dockerfile ./
2018-03-27 19:54:05 +05:30
```
2019-03-02 22:35:43 +05:30
### 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` ](https://relishapp.com/rspec/rspec-core/v/3-8/docs/pending-and-skipped-examples )
can be used).
```
2019-09-30 21:07:59 +05:30
bundle exec bin/qa Test::Instance::All http://localhost:3000 -- --tag quarantine
2019-03-02 22:35:43 +05:30
```
If `quarantine` is used with other tags, tests will only be run if they have at
least one of the tags other than `quarantine` . This is different from how RSpec
tags usually work, where all tags are inclusive.
For example, suppose one test has `:smoke` and `:quarantine` metadata, and
another test has `:ldap` and `:quarantine` metadata. If the tests are run with
`--tag smoke --tag quarantine` , only the first test will run. The test with
`:ldap` will not run even though it also has `:quarantine` .
2019-07-07 11:18:12 +05:30
2020-10-24 23:57:45 +05:30
### Running tests with a feature flag enabled or disabled
2019-07-07 11:18:12 +05:30
2020-10-24 23:57:45 +05:30
Tests can be run with 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:
2019-07-07 11:18:12 +05:30
```
2019-09-30 21:07:59 +05:30
bundle exec bin/qa Test::Instance::All http://localhost:3000 --enable-feature gitaly_enforce_requests_limits
2019-07-07 11:18:12 +05:30
```
This will instruct the QA framework to enable the `gitaly_enforce_requests_limits`
feature flag ([via the API](https://docs.gitlab.com/ee/api/features.html)), run
all the tests in the `Test::Instance::All` scenario, and then disable the
feature flag again.
2020-10-24 23:57:45 +05:30
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](https://docs.gitlab.com/ee/api/features.html)) 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.
2019-07-07 11:18:12 +05:30
Note: the QA framework doesn't currently allow you to easily toggle a feature
2021-03-11 19:13:27 +05:30
flag during a single test, [as you can in unit tests ](https://docs.gitlab.com/ee/development/feature_flags/index.html ),
2019-07-07 11:18:12 +05:30
but [that capability is planned ](https://gitlab.com/gitlab-org/quality/team-tasks/issues/77 ).
2020-10-24 23:57:45 +05:30
Note also that the `--` separator isn't used because `--enable-feature` and `--disable-feature`
are QA framework options, not `rspec` options.