ClickHouse/docs/en/development/continuous-integration.md

216 lines
9.8 KiB
Markdown
Raw Normal View History

2020-08-20 19:44:00 +00:00
---
toc_priority: 62
toc_title: Continuous Integration Checks
---
# Continuous Integration Checks
2020-08-13 18:45:55 +00:00
When you submit a pull request, some automated checks are ran for your code by
the ClickHouse [continuous integration (CI) system](tests.md#test-automation).
This happens after a repository maintainer (someone from ClickHouse team) has
screened your code and added the `can be tested` label to your pull request.
The results of the checks are listed on the GitHub pull request page as
described in the [GitHub checks
documentation](https://docs.github.com/en/github/collaborating-with-issues-and-pull-requests/about-status-checks).
If a check is failing, you might be required to fix it. This page gives an
overview of checks you may encounter, and what you can do to fix them.
If it looks like the check failure is not related to your changes, it may be
some transient failure or an infrastructure problem. Push an empty commit to
the pull request to restart the CI checks:
```
git reset
git commit --allow-empty
git push
```
If you are not sure what to do, ask a maintainer for help.
2020-08-20 19:44:00 +00:00
## Merge With Master
2020-08-13 18:45:55 +00:00
Verifies that the PR can be merged to master. If not, it will fail with the
message 'Cannot fetch mergecommit'. To fix this check, resolve the conflict as
described in the [GitHub
documentation](https://docs.github.com/en/github/collaborating-with-issues-and-pull-requests/resolving-a-merge-conflict-on-github),
or merge the `master` branch to your pull request branch using git.
2020-08-20 19:44:00 +00:00
## Docs check
2020-08-13 18:45:55 +00:00
Tries to build the ClickHouse documentation website. It can fail if you changed
something in the documentation. Most probable reason is that some cross-link in
the documentation is wrong. Go to the check report and look for `ERROR` and `WARNING` messages.
2020-08-13 18:45:55 +00:00
2020-08-20 19:44:00 +00:00
### Report Details
2020-08-13 18:45:55 +00:00
- [Status page example](https://clickhouse-test-reports.s3.yandex.net/12550/eabcc293eb02214caa6826b7c15f101643f67a6b/docs_check.html)
- `docs_output.txt` contains the building log. [Successful result example](https://clickhouse-test-reports.s3.yandex.net/12550/eabcc293eb02214caa6826b7c15f101643f67a6b/docs_check/docs_output.txt)
2020-08-20 19:44:00 +00:00
## Description Check
2020-08-13 18:45:55 +00:00
Check that the description of your pull request conforms to the template
[PULL_REQUEST_TEMPLATE.md](https://github.com/ClickHouse/ClickHouse/blob/master/.github/PULL_REQUEST_TEMPLATE.md).
You have to specify a changelog category for your change (e.g., Bug Fix), and
2020-08-13 19:46:34 +00:00
write a user-readable message describing the change for [CHANGELOG.md](../whats-new/changelog/index.md)
2020-08-13 18:45:55 +00:00
2020-08-20 19:44:00 +00:00
## Push To Dockerhub
2020-08-13 18:45:55 +00:00
Builds docker images used for build and tests, then pushes them to DockerHub.
2020-08-13 18:45:55 +00:00
2020-08-20 19:44:00 +00:00
## Marker Check
2020-08-13 18:45:55 +00:00
This check means that the CI system started to process the pull request. When it has 'pending' status, it means that not all checks have been started yet. After all checks have been started, it changes status to 'success'.
2020-08-20 19:44:00 +00:00
## Style Check
2020-08-13 18:45:55 +00:00
2020-08-14 19:37:43 +00:00
Performs some simple regex-based checks of code style, using the [`utils/check-style/check-style`](https://github.com/ClickHouse/ClickHouse/blob/master/utils/check-style/check-style) binary (note that it can be run locally).
2020-08-13 18:45:55 +00:00
If it fails, fix the style errors following the [code style guide](style.md).
2020-08-20 19:44:00 +00:00
### Report Details
2020-08-13 18:45:55 +00:00
- [Status page example](https://clickhouse-test-reports.s3.yandex.net/12550/659c78c7abb56141723af6a81bfae39335aa8cb2/style_check.html)
- `output.txt` contains the check resulting errors (invalid tabulation etc), blank page means no errors. [Successful result example](https://clickhouse-test-reports.s3.yandex.net/12550/659c78c7abb56141723af6a81bfae39335aa8cb2/style_check/output.txt).
2020-08-20 19:44:00 +00:00
## PVS Check
2020-08-13 18:45:55 +00:00
Check the code with [PVS-studio](https://www.viva64.com/en/pvs-studio/), a static analysis tool. Look at the report to see the exact errors. Fix them if you can, if not -- ask a ClickHouse maintainer for help.
2020-08-20 19:44:00 +00:00
### Report Details
2020-08-13 18:45:55 +00:00
- [Status page example](https://clickhouse-test-reports.s3.yandex.net/12550/67d716b5cc3987801996c31a67b31bf141bc3486/pvs_check.html)
- `test_run.txt.out.log` contains the building and analyzing log file. It includes only parsing or not-found errors.
- `HTML report` contains the analysis results. For its description visit PVS's [official site](https://www.viva64.com/en/m/0036/#ID14E9A2B2CD).
2020-08-20 19:44:00 +00:00
## Fast Test
2020-08-13 18:45:55 +00:00
Normally this is the first check that is ran for a PR. It builds ClickHouse and
runs most of [stateless functional tests](tests.md#functional-tests), omitting
some. If it fails, further checks are not started until it is fixed. Look at
the report to see which tests fail, then reproduce the failure locally as
described [here](tests.md#functional-test-locally).
2020-08-20 19:44:00 +00:00
### Report Details
2020-08-13 18:45:55 +00:00
[Status page example](https://clickhouse-test-reports.s3.yandex.net/12550/67d716b5cc3987801996c31a67b31bf141bc3486/fast_test.html)
2020-08-20 19:44:00 +00:00
#### Status Page Files
2020-08-13 18:45:55 +00:00
- `runlog.out.log` is the general log that includes all other logs.
- `test_log.txt`
- `submodule_log.txt` contains the messages about cloning and checkouting needed submodules.
- `stderr.log`
- `stdout.log`
- `clickhouse-server.log`
- `clone_log.txt`
- `install_log.txt`
- `clickhouse-server.err.log`
- `build_log.txt`
- `cmake_log.txt` contains messages about the C/C++ and Linux flags check.
2020-08-20 19:44:00 +00:00
#### Status Page Columns
2020-08-13 18:45:55 +00:00
- *Test name* contains the name of the test (without the path e.g. all types of tests will be stripped to the name).
- *Test status* -- one of _Skipped_, _Success_, or _Fail_.
- *Test time, sec.* -- empty on this test.
2020-08-20 19:44:00 +00:00
## Build Check {#build-check}
2020-08-13 18:45:55 +00:00
Builds ClickHouse in various configurations for use in further steps. You have to fix the builds that fail. Build logs often has enough information to fix the error, but you might have to reproduce the failure locally. The `cmake` options can be found in the build log, grepping for `cmake`. Use these options and follow the [general build process](build.md).
2020-08-20 19:44:00 +00:00
### Report Details
2020-08-13 18:45:55 +00:00
[Status page example](https://clickhouse-builds.s3.yandex.net/12550/67d716b5cc3987801996c31a67b31bf141bc3486/clickhouse_build_check/report.html).
- **Compiler**: `gcc-9` or `clang-10` (or `clang-10-xx` for other architectures e.g. `clang-10-freebsd`).
- **Build type**: `Debug` or `RelWithDebInfo` (cmake).
- **Sanitizer**: `none` (without sanitizers), `address` (ASan), `memory` (MSan), `undefined` (UBSan), or `thread` (TSan).
- **Bundled**: `bundled` build uses system libraries, and `unbundled` build uses libraries from `contrib` folder.
- **Splitted** `splitted` is a [split build](build.md#split-build)
- **Status**: `success` or `fail`
- **Build log**: link to the building and files copying log, useful when build failed.
- **Build time**.
- **Artifacts**: build result files (with `XXX` being the server version e.g. `20.8.1.4344`).
- `clickhouse-client_XXX_all.deb`
- `clickhouse-common-static-dbg_XXX[+asan, +msan, +ubsan, +tsan]_amd64.deb`
- `clickhouse-common-staticXXX_amd64.deb`
- `clickhouse-server_XXX_all.deb`
- `clickhouse-test_XXX_all.deb`
- `clickhouse_XXX_amd64.buildinfo`
- `clickhouse_XXX_amd64.changes`
- `clickhouse`: Main built binary.
- `clickhouse-odbc-bridge`
- `unit_tests_dbms`: GoogleTest binary with ClickHouse unit tests.
- `shared_build.tgz`: build with shared libraries.
- `performance.tgz`: Special package for performance tests.
2020-08-20 19:44:00 +00:00
## Special Build Check
2020-08-13 18:45:55 +00:00
Performs static analysis and code style checks using `clang-tidy`. The report is similar to the [build check](#build-check). Fix the errors found in the build log.
2020-08-20 19:44:00 +00:00
## Functional Stateless Tests
2020-08-13 18:45:55 +00:00
Runs [stateless functional tests](tests.md#functional-tests) for ClickHouse
binaries built in various configurations -- release, debug, with sanitizers,
etc. Look at the report to see which tests fail, then reproduce the failure
locally as described [here](tests.md#functional-test-locally). Note that you
have to use the correct build configuration to reproduce -- a test might fail
under AddressSanitizer but pass in Debug. Download the binary from [CI build
checks page](build.md#you-dont-have-to-build-clickhouse), or build it locally.
2020-08-20 19:44:00 +00:00
## Functional Stateful Tests
2020-08-13 18:45:55 +00:00
Runs [stateful functional tests](tests.md#functional-tests). Treat them in the same way as the functional stateless tests. The difference is that they require `hits` and `visits` tables from the [Yandex.Metrica dataset](../getting-started/example-datasets/metrica.md) to run.
2020-08-20 19:44:00 +00:00
## Integration Tests
2020-08-13 18:45:55 +00:00
Runs [integration tests](tests.md#integration-tests).
2020-08-20 19:44:00 +00:00
## Testflows Check
2020-08-13 18:45:55 +00:00
Runs some tests using Testflows test system. See [here](https://github.com/ClickHouse/ClickHouse/tree/master/tests/testflows#running-tests-locally) how to run them locally.
2020-08-20 19:44:00 +00:00
## Stress Test
2020-08-13 18:45:55 +00:00
Runs stateless functional tests concurrently from several clients to detect
concurrency-related errors. If it fails:
* Fix all other test failures first;
* Look at the report to find the server logs and check them for possible causes
of error.
2020-08-20 19:44:00 +00:00
## Split Build Smoke Test
2020-08-13 18:45:55 +00:00
Checks that the server build in [split build](build.md#split-build)
configuration can start and run simple queries. If it fails:
* Fix other test errors first;
* Build the server in [split build](build.md#split-build) configuration
locally and check whether it can start and run `select 1`.
2020-08-20 19:44:00 +00:00
## Compatibility Check
2020-08-13 18:45:55 +00:00
Checks that `clickhouse` binary runs on distributions with old libc versions. If it fails, ask a maintainer for help.
2020-08-20 19:44:00 +00:00
## AST Fuzzer
2020-08-13 18:45:55 +00:00
Runs randomly generated queries to catch program errors. If it fails, ask a maintainer for help.
2020-08-20 19:44:00 +00:00
## Performance Tests
2020-08-13 18:45:55 +00:00
Measure changes in query performance. This is the longest check that takes just below 6 hours to run. The performance test report is described in detail [here](https://github.com/ClickHouse/ClickHouse/tree/master/docker/test/performance-comparison#how-to-read-the-report).
2020-08-20 19:44:00 +00:00
# QA
2020-08-13 18:45:55 +00:00
> What is a `Task (private network)` item on status pages?
It's a link to the Yandex's internal job system. Yandex employees can see the check's start time and its more verbose status.
> Where the tests are run
Somewhere on Yandex internal infrastructure.