# 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 - Packaging: Config file' env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} GO111MODULE: auto CODEQL_EXTRACTOR_JAVA_AGENT_DISABLE_KOTLIN: 'true' on: push: branches: - main - releases/v* pull_request: types: - opened - synchronize - reopened - ready_for_review workflow_dispatch: {} jobs: packaging-config-js: strategy: matrix: include: - os: ubuntu-latest version: latest - os: macos-latest version: latest - os: windows-latest version: latest - os: ubuntu-latest version: default - os: macos-latest version: default - os: windows-latest version: default - os: ubuntu-latest version: nightly-latest - os: macos-latest version: nightly-latest - os: windows-latest version: nightly-latest name: 'Packaging: Config file' permissions: contents: read security-events: write timeout-minutes: 45 runs-on: ${{ matrix.os }} steps: - name: Setup Python on MacOS uses: actions/setup-python@v4 if: >- matrix.os == 'macos-latest' && ( matrix.version == 'stable-20220908' || matrix.version == 'stable-20221211' || matrix.version == 'stable-20230418' || matrix.version == 'stable-v2.13.5' || matrix.version == 'stable-v2.14.6') with: python-version: '3.11' - 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' - name: Set environment variable for Swift enablement if: >- runner.os != 'Windows' && ( matrix.version == '20220908' || matrix.version == '20221211' ) shell: bash run: echo "CODEQL_ENABLE_EXPERIMENTAL_FEATURES_SWIFT=true" >> $GITHUB_ENV - uses: ./../action/init with: config-file: .github/codeql/codeql-config-packaging.yml languages: javascript tools: ${{ steps.prepare-test.outputs.tools-url }} - name: Build code shell: bash run: ./build.sh - uses: ./../action/analyze with: output: ${{ runner.temp }}/results upload-database: false - name: Check results uses: ./../action/.github/actions/check-sarif with: sarif-file: ${{ runner.temp }}/results/javascript.sarif queries-run: javascript/example/empty-or-one-block,javascript/example/empty-or-one-block,javascript/example/other-query-block,javascript/example/two-block queries-not-run: foo,bar - 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