TT-Buda-Demos Updates for TT-Buda Release (8/30) #75
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
name: Check SPDX Licenses | |
on: | |
workflow_dispatch: | |
workflow_call: | |
pull_request: | |
branches: | |
- "main" | |
types: | |
- opened | |
- reopened | |
- synchronize | |
- assigned | |
- review_requested | |
jobs: | |
check-spdx-licenses: | |
runs-on: ubuntu-20.04 | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/[email protected] | |
with: | |
cache: "pip" | |
python-version: "3.8" | |
- name: Install copyright check tool | |
run: pip install git+https://github.com/espressif/check-copyright.git@master | |
- name: Check SPDX licenses | |
id: check_spdx_licenses | |
run: | | |
set +e | |
output=$(python -m check_copyright --verbose --dry-run --config ./check_copyright_config.yaml . 2>&1) | |
exit_code=$? | |
clean_output=$(echo "$output" | sed 's/\x1b\[[0-9;]*m//g') | |
echo "CLEAN_OUTPUT<<EOF" >> $GITHUB_ENV | |
echo "$clean_output" >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "EXIT_CODE=$exit_code" >> $GITHUB_ENV | |
exit 0 | |
- name: Debug Extracted Files | |
run: | | |
echo "Extracted Files:" | |
echo "$CLEAN_OUTPUT" | |
- name: Extract Files | |
id: extract_files | |
run: | | |
set +e | |
files=$(echo "$CLEAN_OUTPUT" | awk ' | |
/Files which failed the copyright check:/, /Additional information about this hook and copyright headers may be found here:/ { | |
if ($0 !~ /Files which failed the copyright check:/ && $0 !~ /Additional information about this hook and copyright headers may be found here:/) print | |
} | |
/Some files are without a copyright note and a license header needs to be added:/, /Additional information about this hook and copyright headers may be found here:/ { | |
if ($0 !~ /Some files are without a copyright note and a license header needs to be added:/ && $0 !~ /Additional information about this hook and copyright headers may be found here:/) print | |
}' | sed 's/^ *//' | sed '/^$/d' | grep '^.') | |
echo "FILES<<EOF" >> $GITHUB_ENV | |
echo "$files" >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "Extracted Files: $files" | |
exit 0 | |
- name: Debug Extracted Files | |
run: | | |
echo "Extracted Files:" | |
echo "$FILES" | |
- name: Extract File Paths | |
if: env.FILES != '' | |
run: | | |
# Extract lines starting with './' but ignore any paths following "Modified files:" until a stop marker | |
files_clean=$(echo "$FILES" | awk '/^Modified files:/ {ignore = 1} /^Above is a list of files/ {ignore = 0} !ignore && /^\.\// {print}' | sort | uniq) | |
# Save the cleaned files into a new environment variable 'FILES_CLEAN' | |
echo "FILES_CLEAN<<EOF" >> $GITHUB_ENV | |
echo "$files_clean" >> $GITHUB_ENV | |
echo "EOF" >> $GITHUB_ENV | |
echo "Extracted Paths: $files_clean" | |
- name: Debug Extracted Paths | |
run: | | |
echo "Extracted Paths:" | |
echo "$FILES_CLEAN" | |
echo "---------------------------------" | |
- name: Comment on PR or Issue | |
if: env.FILES_CLEAN != '' | |
uses: actions/github-script@v7 | |
with: | |
script: | | |
const formattedOutput = process.env.FILES_CLEAN; | |
const issueNumber = context.issue.number || context.payload.pull_request.number; | |
const owner = context.repo.owner; | |
const repo = context.repo.repo; | |
if (formattedOutput) { | |
const commentBody = `Our automated SPDX license verification process has discovered that the following files are missing a license header:\n\`\`\`\n${formattedOutput}\n\`\`\`\nPlease ensure each indicated file includes a valid SPDX license identifier. This is essential for maintaining licensing compliance. Your attention and cooperation in updating these files are greatly appreciated. Thank you.`; | |
await github.rest.issues.createComment({ | |
issue_number: issueNumber, | |
owner: owner, | |
repo: repo, | |
body: commentBody | |
}); | |
core.setFailed("SPDX license issues found."); | |
} else { | |
console.log("No SPDX license issues found."); | |
} |