name: CIGithubActions on: # yamllint disable-line rule:truthy pull_request: types: - labeled - unlabeled - synchronize - reopened - opened branches: - master jobs: CheckLabels: runs-on: [self-hosted, style-checker] steps: - name: Check out repository code uses: actions/checkout@v2 - name: Labels check run: | cd $GITHUB_WORKSPACE/tests/ci python3 run_check.py DockerHubPush: needs: CheckLabels runs-on: [self-hosted, style-checker] steps: - name: Check out repository code uses: actions/checkout@v2 - name: Images check run: | cd $GITHUB_WORKSPACE/tests/ci python3 docker_images_check.py - name: Upload images files to artifacts uses: actions/upload-artifact@v2 with: name: changed_images path: ${{ runner.temp }}/docker_images_check/changed_images.json StyleCheck: needs: DockerHubPush runs-on: [self-hosted, style-checker] steps: - name: Download changed images uses: actions/download-artifact@v2 with: name: changed_images path: ${{ runner.temp }}/style_check - name: Check out repository code uses: actions/checkout@v2 - name: Style Check env: TEMP_PATH: ${{ runner.temp }}/style_check run: | cd $GITHUB_WORKSPACE/tests/ci python3 style_check.py - name: Cleanup if: always() run: | docker kill $(docker ps -q) ||: docker rm -f $(docker ps -a -q) ||: sudo rm -fr $TEMP_PATH DocsCheck: needs: DockerHubPush runs-on: [self-hosted, func-tester] steps: - name: Download changed images uses: actions/download-artifact@v2 with: name: changed_images path: ${{ runner.temp }}/docs_check - name: Check out repository code uses: actions/checkout@v2 - name: Docs Check env: TEMP_PATH: ${{runner.temp}}/docs_check REPO_COPY: ${{runner.temp}}/docs_check/ClickHouse run: | cp -r $GITHUB_WORKSPACE $TEMP_PATH cd $REPO_COPY/tests/ci python3 docs_check.py - name: Cleanup if: always() run: | docker kill $(docker ps -q) ||: docker rm -f $(docker ps -a -q) ||: sudo rm -fr $TEMP_PATH BuilderDebDebug: needs: DockerHubPush if: ${{ !contains(github.event.pull_request.labels.*.name, 'pr-documentation') && !contains(github.event.pull_request.labels.*.name, 'pr-doc-fix') }} runs-on: [self-hosted, builder] steps: - name: Download changed images uses: actions/download-artifact@v2 with: name: changed_images path: ${{ runner.temp }}/images_path - name: Check out repository code uses: actions/checkout@v2 with: submodules: 'recursive' fetch-depth: 0 # otherwise we will have no info about contributors - name: Build env: TEMP_PATH: ${{runner.temp}}/build_check IMAGES_PATH: ${{runner.temp}}/images_path REPO_COPY: ${{runner.temp}}/build_check/ClickHouse CACHES_PATH: ${{runner.temp}}/../ccaches CHECK_NAME: 'ClickHouse build check (actions)' BUILD_NUMBER: 7 run: | sudo rm -fr $TEMP_PATH mkdir -p $TEMP_PATH cp -r $GITHUB_WORKSPACE $TEMP_PATH cd $REPO_COPY/tests/ci && python3 build_check.py "$CHECK_NAME" $BUILD_NUMBER - name: Upload build URLs to artifacts uses: actions/upload-artifact@v2 with: name: ${{ env.BUILD_NAME }} path: ${{ runner.temp }}/build_check/${{ env.BUILD_NAME }}.json - name: Cleanup if: always() run: | docker kill $(docker ps -q) ||: docker rm -f $(docker ps -a -q) ||: sudo rm -fr $TEMP_PATH BuilderDebAsan: needs: DockerHubPush if: ${{ !contains(github.event.pull_request.labels.*.name, 'pr-documentation') && !contains(github.event.pull_request.labels.*.name, 'pr-doc-fix') }} runs-on: [self-hosted, builder] steps: - name: Download changed images uses: actions/download-artifact@v2 with: name: changed_images path: ${{ runner.temp }}/images_path - name: Check out repository code uses: actions/checkout@v2 with: submodules: 'recursive' fetch-depth: 0 # otherwise we will have no info about contributors - name: Build env: TEMP_PATH: ${{runner.temp}}/build_check IMAGES_PATH: ${{runner.temp}}/images_path REPO_COPY: ${{runner.temp}}/build_check/ClickHouse CACHES_PATH: ${{runner.temp}}/../ccaches CHECK_NAME: 'ClickHouse build check (actions)' BUILD_NUMBER: 3 run: | sudo rm -fr $TEMP_PATH mkdir -p $TEMP_PATH cp -r $GITHUB_WORKSPACE $TEMP_PATH cd $REPO_COPY/tests/ci && python3 build_check.py "$CHECK_NAME" $BUILD_NUMBER - name: Upload build URLs to artifacts uses: actions/upload-artifact@v2 with: name: ${{ env.BUILD_NAME }} path: ${{ runner.temp }}/build_check/${{ env.BUILD_NAME }}.json - name: Cleanup if: always() run: | docker kill $(docker ps -q) ||: docker rm -f $(docker ps -a -q) ||: sudo rm -fr $TEMP_PATH BuilderDebRelease: needs: DockerHubPush if: ${{ !contains(github.event.pull_request.labels.*.name, 'pr-documentation') && !contains(github.event.pull_request.labels.*.name, 'pr-doc-fix') }} runs-on: [self-hosted, builder] steps: - name: Download changed images uses: actions/download-artifact@v2 with: name: changed_images path: ${{ runner.temp }}/images_path - name: Check out repository code uses: actions/checkout@v2 with: submodules: 'recursive' fetch-depth: 0 # otherwise we will have no info about contributors - name: Build env: TEMP_PATH: ${{runner.temp}}/build_check IMAGES_PATH: ${{runner.temp}}/images_path REPO_COPY: ${{runner.temp}}/build_check/ClickHouse CACHES_PATH: ${{runner.temp}}/../ccaches CHECK_NAME: 'ClickHouse build check (actions)' BUILD_NUMBER: 0 run: | sudo rm -fr $TEMP_PATH mkdir -p $TEMP_PATH cp -r $GITHUB_WORKSPACE $TEMP_PATH cd $REPO_COPY/tests/ci && python3 build_check.py "$CHECK_NAME" $BUILD_NUMBER - name: Upload build URLs to artifacts uses: actions/upload-artifact@v2 with: name: ${{ env.BUILD_NAME }} path: ${{ runner.temp }}/build_check/${{ env.BUILD_NAME }}.json - name: Cleanup if: always() run: | docker kill $(docker ps -q) ||: docker rm -f $(docker ps -a -q) ||: sudo rm -fr $TEMP_PATH BuilderDebSplitted: needs: DockerHubPush if: ${{ !contains(github.event.pull_request.labels.*.name, 'pr-documentation') && !contains(github.event.pull_request.labels.*.name, 'pr-doc-fix') }} runs-on: [self-hosted, builder] steps: - name: Download changed images uses: actions/download-artifact@v2 with: name: changed_images path: ${{ runner.temp }}/images_path - name: Check out repository code uses: actions/checkout@v2 with: submodules: 'recursive' fetch-depth: 0 # otherwise we will have no info about contributors - name: Build env: TEMP_PATH: ${{runner.temp}}/build_check IMAGES_PATH: ${{runner.temp}}/images_path REPO_COPY: ${{runner.temp}}/build_check/ClickHouse CACHES_PATH: ${{runner.temp}}/../ccaches CHECK_NAME: 'ClickHouse special build check (actions)' BUILD_NUMBER: 1 run: | sudo rm -fr $TEMP_PATH mkdir -p $TEMP_PATH cp -r $GITHUB_WORKSPACE $TEMP_PATH cd $REPO_COPY/tests/ci && python3 build_check.py "$CHECK_NAME" $BUILD_NUMBER - name: Upload build URLs to artifacts uses: actions/upload-artifact@v2 with: name: ${{ env.BUILD_NAME }} path: ${{ runner.temp }}/build_check/${{ env.BUILD_NAME }}.json - name: Cleanup if: always() run: | docker kill $(docker ps -q) ||: docker rm -f $(docker ps -a -q) ||: sudo rm -fr $TEMP_PATH BuilderReport: needs: [BuilderDebDebug, BuilderDebAsan, BuilderDebRelease, BuilderDebSplitted] runs-on: [self-hosted, style-checker] steps: - name: Download json reports uses: actions/download-artifact@v2 with: path: ${{runner.temp}}/reports_dir - name: Check out repository code uses: actions/checkout@v2 - name: Report Builder env: TEMP_PATH: ${{runner.temp}}/report_check REPORTS_PATH: ${{runner.temp}}/reports_dir CHECK_NAME: 'ClickHouse build check (actions)' run: | sudo rm -fr $TEMP_PATH mkdir -p $TEMP_PATH cd $GITHUB_WORKSPACE/tests/ci python3 build_report_check.py "$CHECK_NAME" - name: Cleanup if: always() run: | docker kill $(docker ps -q) ||: docker rm -f $(docker ps -a -q) ||: sudo rm -fr $TEMP_PATH FunctionalStatelessTestDebug: needs: [BuilderDebDebug] runs-on: [self-hosted, func-tester] steps: - name: Download json reports uses: actions/download-artifact@v2 with: path: ${{runner.temp}}/reports_dir - name: Check out repository code uses: actions/checkout@v2 - name: Functional test env: TEMP_PATH: ${{runner.temp}}/stateless_debug REPORTS_PATH: ${{runner.temp}}/reports_dir CHECK_NAME: 'Stateless tests (debug, actions)' REPO_COPY: ${{runner.temp}}/stateless_debug/ClickHouse KILL_TIMEOUT: 10800 run: | sudo rm -fr $TEMP_PATH mkdir -p $TEMP_PATH cp -r $GITHUB_WORKSPACE $TEMP_PATH cd $REPO_COPY/tests/ci python3 functional_test_check.py "$CHECK_NAME" $KILL_TIMEOUT - name: Cleanup if: always() run: | docker kill $(docker ps -q) ||: docker rm -f $(docker ps -a -q) ||: sudo rm -fr $TEMP_PATH FunctionalStatefulTestDebug: needs: [BuilderDebDebug] runs-on: [self-hosted, func-tester] steps: - name: Download json reports uses: actions/download-artifact@v2 with: path: ${{runner.temp}}/reports_dir - name: Check out repository code uses: actions/checkout@v2 - name: Functional test env: TEMP_PATH: ${{runner.temp}}/stateful_debug REPORTS_PATH: ${{runner.temp}}/reports_dir CHECK_NAME: 'Stateful tests (debug, actions)' REPO_COPY: ${{runner.temp}}/stateful_debug/ClickHouse KILL_TIMEOUT: 3600 run: | sudo rm -fr $TEMP_PATH mkdir -p $TEMP_PATH cp -r $GITHUB_WORKSPACE $TEMP_PATH cd $REPO_COPY/tests/ci python3 functional_test_check.py "$CHECK_NAME" $KILL_TIMEOUT - name: Cleanup if: always() run: | docker kill $(docker ps -q) ||: docker rm -f $(docker ps -a -q) ||: sudo rm -fr $TEMP_PATH FunctionalStatelessTestFlakyCheck: needs: [BuilderDebAsan] runs-on: [self-hosted, func-tester] steps: - name: Download json reports uses: actions/download-artifact@v2 with: path: ${{runner.temp}}/reports_dir - name: Check out repository code uses: actions/checkout@v2 - name: Functional test env: TEMP_PATH: ${{runner.temp}}/stateless_flaky_asan REPORTS_PATH: ${{runner.temp}}/reports_dir CHECK_NAME: 'Stateless tests flaky check (address, actions)' REPO_COPY: ${{runner.temp}}/stateless_flaky_asan/ClickHouse KILL_TIMEOUT: 3600 run: | sudo rm -fr $TEMP_PATH mkdir -p $TEMP_PATH cp -r $GITHUB_WORKSPACE $TEMP_PATH cd $REPO_COPY/tests/ci python3 functional_test_check.py "$CHECK_NAME" $KILL_TIMEOUT - name: Cleanup if: always() run: | docker kill $(docker ps -q) ||: docker rm -f $(docker ps -a -q) ||: sudo rm -fr $TEMP_PATH StressTestDebug: needs: [BuilderDebDebug] runs-on: [self-hosted, stress-tester] steps: - name: Download json reports uses: actions/download-artifact@v2 with: path: ${{runner.temp}}/reports_dir - name: Check out repository code uses: actions/checkout@v2 - name: Stress test env: TEMP_PATH: ${{runner.temp}}/stress_debug REPORTS_PATH: ${{runner.temp}}/reports_dir CHECK_NAME: 'Stress tests (debug, actions)' REPO_COPY: ${{runner.temp}}/stress_debug/ClickHouse run: | sudo rm -fr $TEMP_PATH mkdir -p $TEMP_PATH cp -r $GITHUB_WORKSPACE $TEMP_PATH cd $REPO_COPY/tests/ci python3 stress_check.py "$CHECK_NAME" - name: Cleanup if: always() run: | docker kill $(docker ps -q) ||: docker rm -f $(docker ps -a -q) ||: sudo rm -fr $TEMP_PATH ASTFuzzerTestDebug: needs: [BuilderDebDebug] runs-on: [self-hosted, func-tester] steps: - name: Download json reports uses: actions/download-artifact@v2 with: path: ${{runner.temp}}/reports_dir - name: Check out repository code uses: actions/checkout@v2 - name: Fuzzer env: TEMP_PATH: ${{runner.temp}}/ast_fuzzer_debug REPORTS_PATH: ${{runner.temp}}/reports_dir CHECK_NAME: 'AST fuzzer (debug, actions)' REPO_COPY: ${{runner.temp}}/ast_fuzzer_debug/ClickHouse run: | sudo rm -fr $TEMP_PATH mkdir -p $TEMP_PATH cp -r $GITHUB_WORKSPACE $TEMP_PATH cd $REPO_COPY/tests/ci python3 ast_fuzzer_check.py "$CHECK_NAME" - name: Cleanup if: always() run: | docker kill $(docker ps -q) ||: docker rm -f $(docker ps -a -q) ||: sudo rm -fr $TEMP_PATH # IntegrationTestsAsan: # needs: [BuilderDebAsan] # runs-on: [self-hosted, stress-tester] # steps: # - name: Download json reports # uses: actions/download-artifact@v2 # with: # path: ${{runner.temp}}/reports_dir # - name: Check out repository code # uses: actions/checkout@v2 # - name: Integration test # env: # TEMP_PATH: ${{runner.temp}}/integration_tests_asan # REPORTS_PATH: ${{runner.temp}}/reports_dir # CHECK_NAME: 'Integration tests (asan, actions)' # REPO_COPY: ${{runner.temp}}/integration_tests_asan/ClickHouse # run: | # sudo rm -fr $TEMP_PATH # mkdir -p $TEMP_PATH # cp -r $GITHUB_WORKSPACE $TEMP_PATH # cd $REPO_COPY/tests/ci # python3 integration_test_check.py "$CHECK_NAME" # - name: Cleanup # if: always() # run: | # docker kill $(docker ps -q) ||: # docker rm -f $(docker ps -a -q) ||: # sudo rm -fr $TEMP_PATH UnitTestsAsan: needs: [BuilderDebAsan] runs-on: [self-hosted, func-tester] steps: - name: Download json reports uses: actions/download-artifact@v2 with: path: ${{runner.temp}}/reports_dir - name: Check out repository code uses: actions/checkout@v2 - name: Unit test env: TEMP_PATH: ${{runner.temp}}/unit_tests_asan REPORTS_PATH: ${{runner.temp}}/reports_dir CHECK_NAME: 'Unit tests (asan, actions)' REPO_COPY: ${{runner.temp}}/unit_tests_asan/ClickHouse run: | sudo rm -fr $TEMP_PATH mkdir -p $TEMP_PATH cp -r $GITHUB_WORKSPACE $TEMP_PATH cd $REPO_COPY/tests/ci python3 unit_tests_check.py "$CHECK_NAME" - name: Cleanup if: always() run: | docker kill $(docker ps -q) ||: docker rm -f $(docker ps -a -q) ||: sudo rm -fr $TEMP_PATH FastTest: needs: DockerHubPush if: ${{ !contains(github.event.pull_request.labels.*.name, 'pr-documentation') && !contains(github.event.pull_request.labels.*.name, 'pr-doc-fix') }} runs-on: [self-hosted, builder] steps: - name: Check out repository code uses: actions/checkout@v2 - name: Fast Test env: TEMP_PATH: ${{runner.temp}}/fasttest REPO_COPY: ${{runner.temp}}/fasttest/ClickHouse CACHES_PATH: ${{runner.temp}}/../ccaches run: | sudo rm -fr $TEMP_PATH mkdir -p $TEMP_PATH cp -r $GITHUB_WORKSPACE $TEMP_PATH cd $REPO_COPY/tests/ci && python3 fast_test_check.py - name: Cleanup if: always() run: | docker kill $(docker ps -q) ||: docker rm -f $(docker ps -a -q) ||: sudo rm -fr $TEMP_PATH PVSCheck: needs: DockerHubPush if: ${{ !contains(github.event.pull_request.labels.*.name, 'pr-documentation') && !contains(github.event.pull_request.labels.*.name, 'pr-doc-fix') }} runs-on: [self-hosted, func-tester] steps: - name: Check out repository code uses: actions/checkout@v2 with: submodules: 'recursive' - name: PVS Check env: TEMP_PATH: ${{runner.temp}}/pvs_check REPO_COPY: ${{runner.temp}}/pvs_check/ClickHouse run: | sudo rm -fr $TEMP_PATH mkdir -p $TEMP_PATH cp -r $GITHUB_WORKSPACE $TEMP_PATH cd $REPO_COPY/tests/ci && python3 pvs_check.py - name: Cleanup if: always() run: | docker kill $(docker ps -q) ||: docker rm -f $(docker ps -a -q) ||: sudo rm -fr $TEMP_PATH CompatibilityCheck: needs: [BuilderDebRelease] if: ${{ !contains(github.event.pull_request.labels.*.name, 'pr-documentation') && !contains(github.event.pull_request.labels.*.name, 'pr-doc-fix') }} runs-on: [self-hosted, style-checker] steps: - name: Check out repository code uses: actions/checkout@v2 - name: Download json reports uses: actions/download-artifact@v2 with: path: ${{runner.temp}}/reports_dir - name: CompatibilityCheck env: TEMP_PATH: ${{runner.temp}}/compatibility_check REPO_COPY: ${{runner.temp}}/compatibility_check/ClickHouse REPORTS_PATH: ${{runner.temp}}/reports_dir run: | sudo rm -fr $TEMP_PATH mkdir -p $TEMP_PATH cp -r $GITHUB_WORKSPACE $TEMP_PATH cd $REPO_COPY/tests/ci && python3 compatibility_check.py 0 - name: Cleanup if: always() run: | docker kill $(docker ps -q) ||: docker rm -f $(docker ps -a -q) ||: sudo rm -fr $TEMP_PATH SplitBuildSmokeTest: needs: [BuilderDebSplitted] if: ${{ !contains(github.event.pull_request.labels.*.name, 'pr-documentation') && !contains(github.event.pull_request.labels.*.name, 'pr-doc-fix') }} runs-on: [self-hosted, style-checker] steps: - name: Check out repository code uses: actions/checkout@v2 - name: Download json reports uses: actions/download-artifact@v2 with: path: ${{runner.temp}}/reports_dir - name: Split build check env: TEMP_PATH: ${{runner.temp}}/split_build_check REPO_COPY: ${{runner.temp}}/split_build_check/ClickHouse REPORTS_PATH: ${{runner.temp}}/reports_dir run: | sudo rm -fr $TEMP_PATH mkdir -p $TEMP_PATH cp -r $GITHUB_WORKSPACE $TEMP_PATH cd $REPO_COPY/tests/ci && python3 split_build_smoke_check.py - name: Cleanup if: always() run: | docker kill $(docker ps -q) ||: docker rm -f $(docker ps -a -q) ||: sudo rm -fr $TEMP_PATH FinishCheck: needs: [StyleCheck, DockerHubPush, CheckLabels, BuilderReport, FastTest, FunctionalStatelessTestDebug, FunctionalStatefulTestDebug, DocsCheck, StressTestDebug, ASTFuzzerTestDebug, PVSCheck, UnitTestsAsan, SplitBuildSmokeTest, CompatibilityCheck] runs-on: [self-hosted, style-checker] steps: - name: Check out repository code uses: actions/checkout@v2 - name: Finish label run: | cd $GITHUB_WORKSPACE/tests/ci python3 finish_check.py