Непрерывная интеграция (CI)
Когда вы отправляете pull request, для вашего кода выполняются автоматические проверки системой ClickHouse непрерывной интеграции (CI).
Это происходит после того, как сопровождающий репозитория (кто‑то из команды ClickHouse) просмотрел ваш код и добавил к вашему pull request метку can be tested.
Результаты проверок перечислены на странице pull request в GitHub, как описано в документации по проверкам GitHub.
Если проверка завершилась с ошибкой, возможно, вам потребуется её исправить.
На этой странице приведён обзор проверок, с которыми вы можете столкнуться, и того, что можно сделать для их исправления.
Если кажется, что сбой проверки не связан с вашими изменениями, это может быть временной ошибкой или проблемой с инфраструктурой. Запушьте пустой коммит в pull request, чтобы перезапустить проверки CI:
Если вы не уверены, как поступить, обратитесь за помощью к мейнтейнеру проекта.
Объединение с master
Проверяет, что PR может быть объединён с веткой master.
Если это невозможно, проверка завершится с ошибкой Cannot fetch mergecommit.
Чтобы пройти эту проверку, разрешите конфликт, как описано в документации GitHub, или выполните слияние ветки master в ветку вашего pull request с помощью git.
Проверка документации
Эта проверка пытается собрать сайт документации ClickHouse.
Она может завершиться с ошибкой, если вы изменили что-то в документации.
Наиболее вероятная причина — некорректная перекрёстная ссылка в документации.
Перейдите к отчёту проверки и найдите сообщения ERROR и WARNING.
Проверка описания
Убедитесь, что описание вашего pull request соответствует шаблону PULL_REQUEST_TEMPLATE.md. Вы должны указать категорию изменения для changelog (например, Bug Fix) и написать понятное пользователю сообщение, описывающее изменение, для CHANGELOG.md
Docker-образ
Собирает Docker-образы сервера ClickHouse и Keeper, чтобы проверить, что они корректно собираются.
Тесты официальной библиотеки Docker
Запускает тесты из официальной библиотеки Docker, чтобы проверить, что Docker-образ clickhouse/clickhouse-server работает корректно.
Чтобы добавить новые тесты, создайте каталог ci/jobs/scripts/docker_server/tests/$test_name и скрипт run.sh в нём.
Дополнительные сведения о тестах можно найти в документации по скриптам заданий CI.
Проверка маркера
Эта проверка означает, что система CI начала обрабатывать pull request. Когда у неё статус «pending», это означает, что ещё не все проверки были запущены. После того как все проверки будут запущены, её статус изменится на «success».
Проверка стиля
Выполняет различные проверки стиля кода.
В задаче Style Check выполняются следующие базовые проверки:
cpp
Выполняет простые проверки стиля кода на основе регулярных выражений с помощью скрипта ci/jobs/scripts/check_style/check_cpp.sh (его также можно запускать локально).
Если проверка завершается с ошибкой, исправьте проблемы со стилем в соответствии с руководством по стилю кода.
codespell, aspell
Проверяют грамматические ошибки и опечатки.
mypy
Выполняет статическую проверку типов для кода на Python.
Запуск задачи проверки стиля локально
Всю задачу Style Check можно запустить локально в Docker-контейнере с помощью:
Чтобы выполнить отдельную проверку (например, проверку cpp):
Эти команды скачивают Docker-образ clickhouse/style-test и запускают задачу в контейнеризованной среде.
Дополнительные зависимости не требуются — достаточно Python 3 и Docker.
Быстрый тест
Обычно это первая проверка, которая запускается для PR. Она собирает ClickHouse и запускает большинство stateless-функциональных тестов, пропуская некоторые. Если она не проходит, последующие проверки не запускаются, пока проблема не будет устранена. Ознакомьтесь с отчетом, чтобы увидеть, какие тесты завершились с ошибкой, затем воспроизведите сбой локально, как описано здесь.
Запуск быстрого теста локально:
Эти команды загружают Docker-образ clickhouse/fast-test и запускают задачу в контейнеризированной среде.
Никаких зависимостей, кроме Python 3 и Docker, не требуется.
Проверка сборки
Выполняет сборку ClickHouse в различных конфигурациях для использования на следующих шагах.
Локальный запуск сборки
Сборку можно запустить локально в среде, имитирующей CI, с помощью:
Никаких дополнительных зависимостей, кроме Python 3 и Docker, не требуется.
Доступные задания сборки
Имена заданий сборки указаны в точности так, как они отображаются в отчёте CI:
Сборки AMD64:
Build (amd_debug)- отладочная сборка с символамиBuild (amd_release)- оптимизированная релизная сборкаBuild (amd_asan)- сборка с Address SanitizerBuild (amd_tsan)- сборка с Thread SanitizerBuild (amd_msan)- сборка с Memory SanitizerBuild (amd_ubsan)- сборка с Undefined Behavior SanitizerBuild (amd_binary)- быстрая релизная сборка без Thin LTOBuild (amd_compat)- совместимая сборка для более старых системBuild (amd_musl)- сборка с musl libcBuild (amd_darwin)- сборка для macOSBuild (amd_freebsd)- сборка для FreeBSD
Сборки ARM64:
Build (arm_release)- оптимизированная релизная сборка ARM64Build (arm_asan)- сборка ARM64 с Address SanitizerBuild (arm_coverage)- сборка ARM64 с инструментированием для покрытияBuild (arm_binary)- быстрая релизная сборка ARM64 без Thin LTOBuild (arm_darwin)- сборка macOS ARM64Build (arm_v80compat)- сборка совместимости ARMv8.0
Другие архитектуры:
Build (ppc64le)- PowerPC, 64-бит, порядок байтов Little EndianBuild (riscv64)- RISC-V, 64-битBuild (s390x)- IBM System/390, 64-битBuild (loongarch64)- LoongArch, 64-бит
Если задание выполнено успешно, результаты сборки будут доступны в каталоге <repo_root>/ci/tmp/build.
Примечание: Для сборок, не относящихся к категории «Другие архитектуры» (сборки из категории «Другие архитектуры» используют кросс-компиляцию), архитектура вашей локальной машины должна совпадать с типом сборки, чтобы она была выполнена так, как запрошено в BUILD_JOB_NAME.
Пример
Чтобы выполнить локальную отладочную сборку:
Если описанный выше подход вам не подходит, используйте параметры cmake из лога сборки и следуйте общему процессу сборки.
Functional stateless tests
Запускает функциональные stateless-тесты для бинарных файлов ClickHouse, собранных в различных конфигурациях — release, debug, с санитайзерами и т. д. Изучите отчёт, чтобы увидеть, какие тесты завершаются с ошибкой, затем воспроизведите сбой локально, как описано здесь. Обратите внимание, что для воспроизведения необходимо использовать правильную конфигурацию сборки — тест может падать под AddressSanitizer, но проходить в Debug. Скачайте бинарный файл со страницы проверок сборки CI или соберите его локально.
Интеграционные тесты
Выполняет интеграционные тесты.
Проверка исправления ошибки
Проверяет, что либо добавлен новый тест (функциональный или интеграционный), либо есть изменённые тесты, которые падают при использовании бинарника, собранного из ветки master. Эта проверка запускается, когда у pull request есть метка "pr-bugfix".
Стресс-тест
Запускает функциональные тесты без сохранения состояния одновременно с нескольких клиентов для выявления ошибок, связанных с конкурентным выполнением. Если тест завершился неуспешно:
- Сначала исправьте все остальные ошибки тестов;
- Ознакомьтесь с отчетом, найдите журналы сервера и проверьте их на возможные причины ошибки.
Проверка совместимости
Проверяет, запускается ли бинарный файл clickhouse на дистрибутивах со старыми версиями libc.
Если проверка не проходит, обратитесь за помощью к мейнтейнеру.
AST fuzzer
Выполняет случайно сгенерированные запросы для обнаружения ошибок в программе. Если он завершится с ошибкой, обратитесь за помощью к мейнтейнеру.
Тесты производительности
Измеряйте, как изменяется производительность запросов. Это самая длительная проверка, она занимает чуть меньше 6 часов. Отчёт о тестах производительности подробно описан здесь.