# Warning: This file is generated automatically, and should not be modified. # Instead, please modify the template in the pr-checks directory and run: # (cd pr-checks; pip install ruamel.yaml@0.17.31 && python3 sync.py) # to regenerate this file. name: PR Check - Split workflow env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} GO111MODULE: auto on: push: branches: - main - releases/v* pull_request: types: - opened - synchronize - reopened - ready_for_review schedule: - cron: '0 5 * * *' workflow_dispatch: {} jobs: split-workflow: strategy: fail-fast: false matrix: include: - os: ubuntu-latest version: linked - os: macos-latest version: linked - os: ubuntu-latest version: default - os: macos-latest version: default - os: ubuntu-latest version: nightly-latest - os: macos-latest version: nightly-latest name: Split workflow permissions: contents: read security-events: read timeout-minutes: 45 runs-on: ${{ matrix.os }} steps: - name: Check out repository uses: actions/checkout@v4 - name: Prepare test id: prepare-test uses: ./.github/actions/prepare-test with: version: ${{ matrix.version }} use-all-platform-bundle: 'false' setup-kotlin: 'true' - name: Install Go uses: actions/setup-go@v5 with: go-version: '>=1.21.0' cache: false - uses: ./../action/init with: config-file: .github/codeql/codeql-config-packaging3.yml packs: +codeql-testing/codeql-pack1@1.0.0 languages: javascript tools: ${{ steps.prepare-test.outputs.tools-url }} - name: Build code shell: bash run: ./build.sh - uses: ./../action/analyze with: skip-queries: true output: ${{ runner.temp }}/results upload-database: false - name: Assert No Results shell: bash run: | if [ "$(ls -A $RUNNER_TEMP/results)" ]; then echo "Expected results directory to be empty after skipping query execution!" exit 1 fi - uses: ./../action/analyze with: output: ${{ runner.temp }}/results upload-database: false - name: Assert Results shell: bash run: | cd "$RUNNER_TEMP/results" # We should have 4 hits from these rules EXPECTED_RULES="javascript/example/empty-or-one-block javascript/example/empty-or-one-block javascript/example/other-query-block javascript/example/two-block" # use tr to replace newlines with spaces and xargs to trim leading and trailing whitespace RULES="$(cat javascript.sarif | jq -r '.runs[0].results[].ruleId' | sort | tr "\n\r" " " | xargs)" echo "Found matching rules '$RULES'" if [ "$RULES" != "$EXPECTED_RULES" ]; then echo "Did not match expected rules '$EXPECTED_RULES'." exit 1 fi env: CODEQL_ACTION_TEST_MODE: true