mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-18 04:12:19 +00:00
329 lines
12 KiB
YAML
329 lines
12 KiB
YAML
# yamllint disable rule:comments-indentation
|
|
name: BackportPR
|
|
|
|
env:
|
|
# Force the stdout and stderr streams to be unbuffered
|
|
PYTHONUNBUFFERED: 1
|
|
|
|
on: # yamllint disable-line rule:truthy
|
|
push:
|
|
branches:
|
|
- 'backport/**'
|
|
jobs:
|
|
CheckLabels:
|
|
runs-on: [self-hosted, style-checker]
|
|
# Run the first check always, even if the CI is cancelled
|
|
if: ${{ always() }}
|
|
steps:
|
|
- name: Check out repository code
|
|
uses: ClickHouse/checkout@v1
|
|
with:
|
|
clear-repository: true
|
|
- name: Labels check
|
|
run: |
|
|
cd "$GITHUB_WORKSPACE/tests/ci"
|
|
python3 run_check.py
|
|
PythonUnitTests:
|
|
runs-on: [self-hosted, style-checker]
|
|
needs: CheckLabels
|
|
steps:
|
|
- name: Check out repository code
|
|
uses: ClickHouse/checkout@v1
|
|
with:
|
|
clear-repository: true
|
|
- name: Python unit tests
|
|
run: |
|
|
cd "$GITHUB_WORKSPACE/tests/ci"
|
|
echo "Testing the main ci directory"
|
|
python3 -m unittest discover -s . -p 'test_*.py'
|
|
for dir in *_lambda/; do
|
|
echo "Testing $dir"
|
|
python3 -m unittest discover -s "$dir" -p 'test_*.py'
|
|
done
|
|
DockerHubPushAarch64:
|
|
runs-on: [self-hosted, style-checker-aarch64]
|
|
needs: CheckLabels
|
|
steps:
|
|
- name: Check out repository code
|
|
uses: ClickHouse/checkout@v1
|
|
with:
|
|
clear-repository: true
|
|
- name: Images check
|
|
run: |
|
|
cd "$GITHUB_WORKSPACE/tests/ci"
|
|
python3 docker_images_check.py --suffix aarch64
|
|
- name: Upload images files to artifacts
|
|
uses: actions/upload-artifact@v3
|
|
with:
|
|
name: changed_images_aarch64
|
|
path: ${{ runner.temp }}/docker_images_check/changed_images_aarch64.json
|
|
DockerHubPushAmd64:
|
|
runs-on: [self-hosted, style-checker]
|
|
needs: CheckLabels
|
|
steps:
|
|
- name: Check out repository code
|
|
uses: ClickHouse/checkout@v1
|
|
with:
|
|
clear-repository: true
|
|
- name: Images check
|
|
run: |
|
|
cd "$GITHUB_WORKSPACE/tests/ci"
|
|
python3 docker_images_check.py --suffix amd64
|
|
- name: Upload images files to artifacts
|
|
uses: actions/upload-artifact@v3
|
|
with:
|
|
name: changed_images_amd64
|
|
path: ${{ runner.temp }}/docker_images_check/changed_images_amd64.json
|
|
DockerHubPush:
|
|
needs: [DockerHubPushAmd64, DockerHubPushAarch64, PythonUnitTests]
|
|
runs-on: [self-hosted, style-checker]
|
|
steps:
|
|
- name: Check out repository code
|
|
uses: ClickHouse/checkout@v1
|
|
with:
|
|
clear-repository: true
|
|
fetch-depth: 0 # to find ancestor merge commits necessary for finding proper docker tags
|
|
filter: tree:0
|
|
- name: Download changed aarch64 images
|
|
uses: actions/download-artifact@v3
|
|
with:
|
|
name: changed_images_aarch64
|
|
path: ${{ runner.temp }}
|
|
- name: Download changed amd64 images
|
|
uses: actions/download-artifact@v3
|
|
with:
|
|
name: changed_images_amd64
|
|
path: ${{ runner.temp }}
|
|
- name: Images check
|
|
run: |
|
|
cd "$GITHUB_WORKSPACE/tests/ci"
|
|
python3 docker_manifests_merge.py --suffix amd64 --suffix aarch64
|
|
- name: Upload images files to artifacts
|
|
uses: actions/upload-artifact@v3
|
|
with:
|
|
name: changed_images
|
|
path: ${{ runner.temp }}/changed_images.json
|
|
CompatibilityCheckX86:
|
|
needs: [BuilderDebRelease]
|
|
uses: ./.github/workflows/reusable_test.yml
|
|
with:
|
|
test_name: Compatibility check X86
|
|
runner_type: style-checker
|
|
run_command: |
|
|
cd "$REPO_COPY/tests/ci"
|
|
python3 compatibility_check.py --check-name "Compatibility check (amd64)" --check-glibc --check-distributions
|
|
CompatibilityCheckAarch64:
|
|
needs: [BuilderDebAarch64]
|
|
uses: ./.github/workflows/reusable_test.yml
|
|
with:
|
|
test_name: Compatibility check X86
|
|
runner_type: style-checker
|
|
run_command: |
|
|
cd "$REPO_COPY/tests/ci"
|
|
python3 compatibility_check.py --check-name "Compatibility check (aarch64)" --check-glibc
|
|
#########################################################################################
|
|
#################################### ORDINARY BUILDS ####################################
|
|
#########################################################################################
|
|
BuilderDebRelease:
|
|
needs: [DockerHubPush]
|
|
uses: ./.github/workflows/reusable_build.yml
|
|
with:
|
|
build_name: package_release
|
|
checkout_depth: 0
|
|
BuilderDebAarch64:
|
|
needs: [DockerHubPush]
|
|
uses: ./.github/workflows/reusable_build.yml
|
|
with:
|
|
build_name: package_aarch64
|
|
checkout_depth: 0
|
|
BuilderDebAsan:
|
|
needs: [DockerHubPush]
|
|
uses: ./.github/workflows/reusable_build.yml
|
|
with:
|
|
build_name: package_asan
|
|
BuilderDebTsan:
|
|
needs: [DockerHubPush]
|
|
uses: ./.github/workflows/reusable_build.yml
|
|
with:
|
|
build_name: package_tsan
|
|
BuilderDebDebug:
|
|
needs: [DockerHubPush]
|
|
uses: ./.github/workflows/reusable_build.yml
|
|
with:
|
|
build_name: package_debug
|
|
BuilderBinDarwin:
|
|
needs: [DockerHubPush]
|
|
uses: ./.github/workflows/reusable_build.yml
|
|
with:
|
|
build_name: binary_darwin
|
|
checkout_depth: 0
|
|
BuilderBinDarwinAarch64:
|
|
needs: [DockerHubPush]
|
|
uses: ./.github/workflows/reusable_build.yml
|
|
with:
|
|
build_name: binary_darwin_aarch64
|
|
checkout_depth: 0
|
|
############################################################################################
|
|
##################################### Docker images #######################################
|
|
############################################################################################
|
|
DockerServerImages:
|
|
needs:
|
|
- BuilderDebRelease
|
|
- BuilderDebAarch64
|
|
runs-on: [self-hosted, style-checker]
|
|
steps:
|
|
- name: Check out repository code
|
|
uses: ClickHouse/checkout@v1
|
|
with:
|
|
clear-repository: true
|
|
fetch-depth: 0 # It MUST BE THE SAME for all dependencies and the job itself
|
|
filter: tree:0
|
|
- name: Check docker clickhouse/clickhouse-server building
|
|
run: |
|
|
cd "$GITHUB_WORKSPACE/tests/ci"
|
|
python3 docker_server.py --release-type head --no-push \
|
|
--image-repo clickhouse/clickhouse-server --image-path docker/server
|
|
python3 docker_server.py --release-type head --no-push \
|
|
--image-repo clickhouse/clickhouse-keeper --image-path docker/keeper
|
|
- name: Cleanup
|
|
if: always()
|
|
run: |
|
|
docker ps --quiet | xargs --no-run-if-empty docker kill ||:
|
|
docker ps --all --quiet | xargs --no-run-if-empty docker rm -f ||:
|
|
sudo rm -fr "$TEMP_PATH"
|
|
############################################################################################
|
|
##################################### BUILD REPORTER #######################################
|
|
############################################################################################
|
|
BuilderReport:
|
|
if: ${{ success() || failure() }}
|
|
needs:
|
|
- BuilderDebRelease
|
|
- BuilderDebAarch64
|
|
- BuilderDebAsan
|
|
- BuilderDebTsan
|
|
- BuilderDebDebug
|
|
uses: ./.github/workflows/reusable_test.yml
|
|
with:
|
|
test_name: ClickHouse build check
|
|
runner_type: style-checker
|
|
additional_envs: |
|
|
NEEDS_DATA<<NDENV
|
|
${{ toJSON(needs) }}
|
|
NDENV
|
|
run_command: |
|
|
cd "$GITHUB_WORKSPACE/tests/ci"
|
|
python3 build_report_check.py "$CHECK_NAME"
|
|
BuilderSpecialReport:
|
|
if: ${{ success() || failure() }}
|
|
needs:
|
|
- BuilderBinDarwin
|
|
- BuilderBinDarwinAarch64
|
|
uses: ./.github/workflows/reusable_test.yml
|
|
with:
|
|
test_name: ClickHouse special build check
|
|
runner_type: style-checker
|
|
additional_envs: |
|
|
NEEDS_DATA<<NDENV
|
|
${{ toJSON(needs) }}
|
|
NDENV
|
|
run_command: |
|
|
cd "$GITHUB_WORKSPACE/tests/ci"
|
|
python3 build_report_check.py "$CHECK_NAME"
|
|
############################################################################################
|
|
#################################### INSTALL PACKAGES ######################################
|
|
############################################################################################
|
|
InstallPackagesTestRelease:
|
|
needs: [BuilderDebRelease]
|
|
uses: ./.github/workflows/reusable_test.yml
|
|
with:
|
|
test_name: Install packages (amd64)
|
|
runner_type: style-checker
|
|
run_command: |
|
|
cd "$REPO_COPY/tests/ci"
|
|
python3 install_check.py "$CHECK_NAME"
|
|
InstallPackagesTestAarch64:
|
|
needs: [BuilderDebAarch64]
|
|
uses: ./.github/workflows/reusable_test.yml
|
|
with:
|
|
test_name: Install packages (arm64)
|
|
runner_type: style-checker-aarch64
|
|
run_command: |
|
|
cd "$REPO_COPY/tests/ci"
|
|
python3 install_check.py "$CHECK_NAME"
|
|
##############################################################################################
|
|
########################### FUNCTIONAl STATELESS TESTS #######################################
|
|
##############################################################################################
|
|
FunctionalStatelessTestAsan:
|
|
needs: [BuilderDebAsan]
|
|
uses: ./.github/workflows/reusable_test.yml
|
|
with:
|
|
test_name: Stateless tests (asan)
|
|
runner_type: func-tester
|
|
additional_envs: |
|
|
KILL_TIMEOUT=10800
|
|
run_command: |
|
|
cd "$REPO_COPY/tests/ci"
|
|
python3 functional_test_check.py "$CHECK_NAME" "$KILL_TIMEOUT"
|
|
##############################################################################################
|
|
############################ FUNCTIONAl STATEFUL TESTS #######################################
|
|
##############################################################################################
|
|
FunctionalStatefulTestDebug:
|
|
needs: [BuilderDebDebug]
|
|
uses: ./.github/workflows/reusable_test.yml
|
|
with:
|
|
test_name: Stateful tests (debug)
|
|
runner_type: func-tester
|
|
additional_envs: |
|
|
KILL_TIMEOUT=3600
|
|
run_command: |
|
|
cd "$REPO_COPY/tests/ci"
|
|
python3 functional_test_check.py "$CHECK_NAME" "$KILL_TIMEOUT"
|
|
##############################################################################################
|
|
######################################### STRESS TESTS #######################################
|
|
##############################################################################################
|
|
StressTestTsan:
|
|
needs: [BuilderDebTsan]
|
|
uses: ./.github/workflows/reusable_test.yml
|
|
with:
|
|
test_name: Stress test (tsan)
|
|
runner_type: stress-tester
|
|
run_command: |
|
|
cd "$REPO_COPY/tests/ci"
|
|
python3 stress_check.py "$CHECK_NAME"
|
|
#############################################################################################
|
|
############################# INTEGRATION TESTS #############################################
|
|
#############################################################################################
|
|
IntegrationTestsRelease:
|
|
needs: [BuilderDebRelease]
|
|
uses: ./.github/workflows/reusable_test.yml
|
|
with:
|
|
test_name: Integration tests (release)
|
|
runner_type: stress-tester
|
|
batches: 4
|
|
run_command: |
|
|
cd "$REPO_COPY/tests/ci"
|
|
python3 integration_test_check.py "$CHECK_NAME"
|
|
FinishCheck:
|
|
needs:
|
|
- DockerHubPush
|
|
- DockerServerImages
|
|
- BuilderReport
|
|
- BuilderSpecialReport
|
|
- FunctionalStatelessTestAsan
|
|
- FunctionalStatefulTestDebug
|
|
- StressTestTsan
|
|
- IntegrationTestsRelease
|
|
- CompatibilityCheckX86
|
|
- CompatibilityCheckAarch64
|
|
runs-on: [self-hosted, style-checker]
|
|
steps:
|
|
- name: Check out repository code
|
|
uses: ClickHouse/checkout@v1
|
|
with:
|
|
clear-repository: true
|
|
- name: Finish label
|
|
run: |
|
|
cd "$GITHUB_WORKSPACE/tests/ci"
|
|
python3 finish_check.py
|
|
python3 merge_pr.py
|