debian-mirror-gitlab/spec/frontend_integration/README.md

47 lines
1.6 KiB
Markdown
Raw Normal View History

2020-05-24 23:13:21 +05:30
## Frontend Integration Specs
This directory contains Frontend integration specs. Go to `spec/frontend` if you're looking for Frontend unit tests.
Frontend integration specs:
- Mock out the Backend.
- Don't test individual components, but instead test use cases.
- Are expected to run slower than unit tests.
- Could end up having their own environment.
As a result, they deserve their own special place.
2021-11-11 11:23:49 +05:30
## Run frontend integration tests locally
The frontend integration specs are all about testing integration frontend bundles against a
mock backend. The mock backend is built using the fixtures and GraphQL schema.
We can generate the necessary fixtures and GraphQL schema by running:
```shell
bundle exec rake frontend:fixtures gitlab:graphql:schema:dump
```
2023-07-09 08:55:56 +05:30
You can also download those fixtures from the package registry: see [download fixtures](https://docs.gitlab.com/ee/development/testing_guide/frontend_testing.html#download-fixtures) for more info.
2021-11-11 11:23:49 +05:30
Then we can use [Jest](https://jestjs.io/) to run the frontend integration tests:
```shell
yarn jest:integration <path-to-integration-test>
```
If you'd like to run the frontend integration specs **without** setting up the fixtures first, then you
can set `GL_IGNORE_WARNINGS=1`:
```shell
GL_IGNORE_WARNINGS=1 yarn jest:integration <path-to-integration-test>
```
The `jest-integration` job executes the frontend integration tests in our
CI/CD pipelines.
2020-05-24 23:13:21 +05:30
## References
- https://docs.gitlab.com/ee/development/testing_guide/testing_levels.html#frontend-integration-tests
- https://gitlab.com/gitlab-org/gitlab/-/issues/208800