fix: persist inputs between the upload action and its post step #3799
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# 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 [email protected] && python3 sync.py) | |
# to regenerate this file. | |
name: PR Check - Export file baseline information | |
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: | |
export-file-baseline-information: | |
strategy: | |
fail-fast: false | |
matrix: | |
include: | |
- os: ubuntu-latest | |
version: nightly-latest | |
- os: macos-latest | |
version: nightly-latest | |
- os: windows-latest | |
version: nightly-latest | |
name: Export file baseline information | |
permissions: | |
contents: read | |
security-events: write | |
timeout-minutes: 45 | |
runs-on: ${{ matrix.os }} | |
steps: | |
- name: Setup Python on MacOS | |
uses: actions/setup-python@v5 | |
if: runner.os == 'macOS' && 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' | |
setup-kotlin: 'true' | |
- uses: ./../action/init | |
id: init | |
with: | |
languages: javascript | |
tools: ${{ steps.prepare-test.outputs.tools-url }} | |
- uses: ./../action/.github/actions/setup-swift | |
with: | |
codeql-path: ${{ steps.init.outputs.codeql-path }} | |
- name: Build code | |
shell: bash | |
run: ./build.sh | |
- uses: ./../action/analyze | |
with: | |
output: ${{ runner.temp }}/results | |
- name: Upload SARIF | |
uses: actions/upload-artifact@v3 | |
with: | |
name: with-baseline-information-${{ matrix.os }}-${{ matrix.version }}.sarif.json | |
path: ${{ runner.temp }}/results/javascript.sarif | |
retention-days: 7 | |
- name: Check results | |
shell: bash | |
run: | | |
cd "$RUNNER_TEMP/results" | |
expected_baseline_languages="c csharp go java kotlin javascript python ruby" | |
if [[ $RUNNER_OS == "macOS" ]]; then | |
expected_baseline_languages+=" swift" | |
fi | |
for lang in ${expected_baseline_languages}; do | |
rule_name="cli/expected-extracted-files/${lang}" | |
found_notification=$(jq --arg rule_name "${rule_name}" '[.runs[0].tool.driver.notifications | | |
select(. != null) | flatten | .[].id] | any(. == $rule_name)' javascript.sarif) | |
if [[ "${found_notification}" != "true" ]]; then | |
echo "Expected SARIF output to contain notification '${rule_name}', but found no such notification." | |
exit 1 | |
else | |
echo "Found notification '${rule_name}'." | |
fi | |
done | |
env: | |
CODEQL_ACTION_SUBLANGUAGE_FILE_COVERAGE: true | |
CODEQL_ACTION_TEST_MODE: true |