Merge main into releases/v3 #3973
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 ruamel.yaml@0.17.31 && python3 sync.py) | |
# to regenerate this file. | |
name: PR Check - Use a custom `checkout_path` | |
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 | |
schedule: | |
- cron: '0 5 * * *' | |
workflow_dispatch: {} | |
jobs: | |
with-checkout-path: | |
strategy: | |
matrix: | |
include: | |
- os: ubuntu-latest | |
version: latest | |
- os: macos-latest | |
version: latest | |
- os: windows-latest | |
version: latest | |
name: Use a custom `checkout_path` | |
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-20230403' || | |
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: Delete original checkout | |
shell: bash | |
run: | | |
# delete the original checkout so we don't accidentally use it. | |
# Actions does not support deleting the current working directory, so we | |
# delete the contents of the directory instead. | |
rm -rf ./* .github .git | |
# Check out the actions repo again, but at a different location. | |
# choose an arbitrary SHA so that we can later test that the commit_oid is not from main | |
- uses: actions/checkout@v4 | |
with: | |
ref: 474bbf07f9247ffe1856c6a0f94aeeb10e7afee6 | |
path: x/y/z/some-path | |
- uses: ./../action/init | |
with: | |
tools: ${{ steps.prepare-test.outputs.tools-url }} | |
# it's enough to test one compiled language and one interpreted language | |
languages: csharp,javascript | |
source-root: x/y/z/some-path/tests/multi-language-repo | |
- name: Build code | |
shell: bash | |
working-directory: x/y/z/some-path/tests/multi-language-repo | |
run: | | |
./build.sh | |
- uses: ./../action/analyze | |
with: | |
checkout_path: x/y/z/some-path/tests/multi-language-repo | |
ref: v1.1.0 | |
sha: 474bbf07f9247ffe1856c6a0f94aeeb10e7afee6 | |
upload: never | |
upload-database: false | |
- uses: ./../action/upload-sarif | |
with: | |
ref: v1.1.0 | |
sha: 474bbf07f9247ffe1856c6a0f94aeeb10e7afee6 | |
checkout_path: x/y/z/some-path/tests/multi-language-repo | |
- name: Verify SARIF after upload | |
shell: bash | |
run: | | |
EXPECTED_COMMIT_OID="474bbf07f9247ffe1856c6a0f94aeeb10e7afee6" | |
EXPECTED_REF="v1.1.0" | |
EXPECTED_CHECKOUT_URI_SUFFIX="/x/y/z/some-path/tests/multi-language-repo" | |
ACTUAL_COMMIT_OID="$(cat "$RUNNER_TEMP/payload.json" | jq -r .commit_oid)" | |
ACTUAL_REF="$(cat "$RUNNER_TEMP/payload.json" | jq -r .ref)" | |
ACTUAL_CHECKOUT_URI="$(cat "$RUNNER_TEMP/payload.json" | jq -r .checkout_uri)" | |
if [[ "$EXPECTED_COMMIT_OID" != "$ACTUAL_COMMIT_OID" ]]; then | |
echo "::error Invalid commit oid. Expected: $EXPECTED_COMMIT_OID Actual: $ACTUAL_COMMIT_OID" | |
echo "$RUNNER_TEMP/payload.json" | |
exit 1 | |
fi | |
if [[ "$EXPECTED_REF" != "$ACTUAL_REF" ]]; then | |
echo "::error Invalid ref. Expected: '$EXPECTED_REF' Actual: '$ACTUAL_REF'" | |
echo "$RUNNER_TEMP/payload.json" | |
exit 1 | |
fi | |
if [[ "$ACTUAL_CHECKOUT_URI" != *$EXPECTED_CHECKOUT_URI_SUFFIX ]]; then | |
echo "::error Invalid checkout URI suffix. Expected suffix: $EXPECTED_CHECKOUT_URI_SUFFIX Actual uri: $ACTUAL_CHECKOUT_URI" | |
echo "$RUNNER_TEMP/payload.json" | |
exit 1 | |
fi | |
env: | |
CODEQL_ACTION_TEST_MODE: true |