diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 028fd83a4..dbf3bf63d 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -219,3 +219,64 @@ jobs: ./report/**/*.xml event_name: ${{ github.event.workflow_run.event }} report_individual_runs: "true" + + codestyle_all_without_ruff: + runs-on: [self-hosted, linux, light] + needs: gh_build_image + container: + # until https://github.com/github/docs/issues/25520 is resolved, using vars + image: "ghcr.io/${{ github.repository_owner }}/${{ github.event.repository.name }}/datalens_ci_with_code:${{ github.sha }}" + credentials: + username: ${{ github.actor }} + password: ${{ secrets.GITHUB_TOKEN }} + steps: + - name: 'Cleanup build folder' + run: | + rm -rf ./* || true + rm -rf ./.??* || true + - name: Checkout code + uses: actions/checkout@v4 + with: + fetch-depth: 1 + submodules: true + - run: | + task cq:check_dir -- . + task cq:check_dir_strict -- . + env: + VENV_PATH: /venv + SKIP_RUFF: true + + codestyle_changed_without_ruff: + runs-on: [ self-hosted, linux, light ] + needs: gh_build_image + container: + # until https://github.com/github/docs/issues/25520 is resolved, using vars + image: "ghcr.io/${{ github.repository_owner }}/${{ github.event.repository.name }}/datalens_ci_with_code:${{ github.sha }}" + credentials: + username: ${{ github.actor }} + password: ${{ secrets.GITHUB_TOKEN }} + steps: + - name: 'Cleanup build folder' + run: | + rm -rf ./* || true + rm -rf ./.??* || true + - name: Checkout code + uses: actions/checkout@v4 + with: + fetch-depth: 0 + submodules: true + # https://github.com/actions/runner-images/issues/6775 + - run: git config --global --add safe.directory . + - run: git config --global --add safe.directory /__w/${{ github.event.repository.name }}/${{ github.event.repository.name }} + - run: | + TARGET=$(. /venv/bin/activate && dl-git range-diff-paths --only-added-commits --base ${{ github.event.pull_request.base.sha }} --head ${{ github.event.pull_request.head.sha }}) + echo $TARGET + - run: | + TARGET=$(. /venv/bin/activate && dl-git range-diff-paths --only-added-commits --base ${{ github.event.pull_request.base.sha }} --head ${{ github.event.pull_request.head.sha }}) + echo $TARGET + task cq:check_target -- "$TARGET" + task cq:check_target_strict -- "$TARGET" 1>/dev/null 2>/dev/null + env: + VENV_PATH: /venv + SKIP_RUFF: true + TEST_TARGET_OVERRIDE: ${{ github.event.inputs.test_targets }} diff --git a/ci/build_naive.sh b/ci/build_naive.sh index 2d23efa79..16232b461 100644 --- a/ci/build_naive.sh +++ b/ci/build_naive.sh @@ -12,6 +12,7 @@ DKR_IMG_REPO_PREFIX=${DKR_IMG_REPO_PREFIX:-"ghcr.io/${REPO_OWNER}/${REPO_NAME}"} # Internal constants BAKE_TARGET_BASE_CI="base_ci" BAKE_TARGET_CI_W_SRC="ci_with_src" +BAKE_TARGET_CI_CODE_QUALITY="ci_code_quality" BAKE_EXECUTABLE="${ROOT_DIR}/docker_build/run-project-bake" # Will be used as base image for ci_with_src @@ -21,6 +22,7 @@ DKR_IMG_CACHED_TARGET_DL_CI_BASE="${DKR_IMG_REPO_PREFIX}/datalens_base_ci:$(bash # CI image with all sources will be pushed here DKR_IMG_TARGET_DL_CI_WITH_SRC="${DKR_IMG_REPO_PREFIX}/datalens_ci_with_code:${GIT_SHA}" +DKR_IMG_TARGET_DL_CI_CODE_QUALITY="${DKR_IMG_REPO_PREFIX}/datalens_ci_code_quality:${GIT_SHA}" set +x @@ -42,8 +44,11 @@ fi echo "Building & pushing CI docker image with sources" DL_B_EXT_CACHED_TARGET_BASE_CI="${DKR_IMG_CACHED_TARGET_DL_CI_BASE}" \ - "${BAKE_EXECUTABLE}" "${BAKE_TARGET_CI_W_SRC}" \ + "${BAKE_EXECUTABLE}" \ + "${BAKE_TARGET_CI_W_SRC}" \ + "${BAKE_TARGET_CI_CODE_QUALITY}" \ --set "${BAKE_TARGET_CI_W_SRC}.tags=${DKR_IMG_TARGET_DL_CI_WITH_SRC}" \ + --set "${BAKE_TARGET_CI_CODE_QUALITY}.tags=${DKR_IMG_TARGET_DL_CI_CODE_QUALITY}" \ --progress=plain \ --push diff --git a/docker_build/bake_ci.hcl b/docker_build/bake_ci.hcl index ee1eba7b7..ede5b9ec6 100644 --- a/docker_build/bake_ci.hcl +++ b/docker_build/bake_ci.hcl @@ -42,3 +42,21 @@ target "ci_with_src" { "RUN . /venv/bin/activate && pip install -r /src/ci/requirements_types.txt" ]) } + +target "ci_code_quality" { + contexts = { + base_img = "target:ci_with_src" + } + dockerfile-inline = <