Skip to content
This repository has been archived by the owner on Dec 12, 2024. It is now read-only.

Introduce spec implementation tests #30

Introduce spec implementation tests

Introduce spec implementation tests #30

name: Test Spec Implementation Repos
# Parse the CI output status and make a markdown summary
# TODO:
# - make the pipeline ignore failures so devs dont ignore the CI checks
# - add a step to add a comment summary with the failures in the PR, so PRs can act accordingly
# - add a step to automate issue creation for each failure (or update existing one)
on:
push:
branches:
- main
pull_request:
branches:
- main
schedule:
- cron: "0 5 * * *"
jobs:
test:
strategy:
fail-fast: false
matrix:
include:
- repo: tbdex-js
ci_file: integrity-check.yml
spec_path: tbdex
job_step: test-with-node;Run tests
- repo: tbdex-swift
ci_file: ci.yml
spec_path: Tests/tbDEXTestVectors/tbdex-spec
job_step: build-and-test;Run tests
- repo: tbdex-kt
ci_file: ci.yml
spec_path: tbdex
job_step: build-test-deploy-snapshot-ubuntu;Build, Test
- repo: tbdex-rs
ci_file: ci.yml
spec_path: tbdex
job_step: build-test-deploy-snapshot-ubuntu;Build, Test
outputs:
tbdex-js: ${{ steps.output.outputs.tbdex-js }}
tbdex-swift: ${{ steps.output.outputs.tbdex-swift }}
tbdex-kt: ${{ steps.output.outputs.tbdex-kt }}
tbdex-rs: ${{ steps.output.outputs.tbdex-rs }}
runs-on: ubuntu-latest
steps:
- name: Generate an access token to write to downstream repo
uses: actions/create-github-app-token@2986852ad836768dfea7781f31828eb3e17990fa # v1.6.2
id: app-token
with:
app-id: ${{ secrets.CICD_ROBOT_GITHUB_APP_ID }}
private-key: ${{ secrets.CICD_ROBOT_GITHUB_APP_PRIVATE_KEY }}
owner: TBD54566975
repositories: ${{ matrix.repo }}
- name: Checkout spec repository
uses: actions/checkout@v4
with:
token: ${{ steps.app-token.outputs.token }}
repository: TBD54566975/${{ matrix.repo }}
ref: main
submodules: true
# persist-credentials: false
- name: Setup Spec values
id: spec-vals
run: |
SHA="${{ github.event_name == 'pull_request' && github.event.pull_request.head.sha || github.sha }}"
echo "SPEC_SHORT_SHA=${SHA:0:7}" >> $GITHUB_OUTPUT
echo "SPEC_SHA=$SHA" >> $GITHUB_OUTPUT
echo "SPEC_REF=tbd-ci-cd-robot/spec-tests" >> $GITHUB_OUTPUT
- name: Update spec submodule in ${{ matrix.repo }}
env:
SPEC_SHORT_SHA: ${{ steps.spec-vals.outputs.SPEC_SHORT_SHA }}
SPEC_SHA: ${{ steps.spec-vals.outputs.SPEC_SHA }}
SPEC_REF: ${{ steps.spec-vals.outputs.SPEC_REF }}
run: |
REPO_ROOT=$(pwd)
cd ${{ matrix.spec_path }}
git fetch origin ${{ env.SPEC_SHA }}
git checkout ${{ env.SPEC_SHA }}
cd $REPO_ROOT
git checkout -b ${{ env.SPEC_REF }}
git add .
git config user.name "tbd-ci-cd-robot[bot]"
git config user.email "${{ secrets.CICD_ROBOT_GITHUB_APP_ID }}+tbd-ci-cd-robot[bot]@users.noreply.github.com"
git commit -m "Update tbdex spec to ${{ env.SPEC_SHORT_SHA }}"
git push origin ${{ env.SPEC_REF }} -f
- name: Trigger and wait for ${{ matrix.repo }} CI pipeline
uses: convictional/[email protected]
id: trigger-ci
with:
owner: TBD54566975
repo: ${{ matrix.repo }}
github_token: ${{ steps.app-token.outputs.token }}
workflow_file_name: ${{ matrix.ci_file }}
ref: ${{ steps.spec-vals.outputs.SPEC_REF }}
wait_interval: 10
propagate_failure: false
# client_payload: '{}'
# trigger_workflow: true
# wait_workflow: true
# Read CI status
- name: Read CI Job Status
uses: actions/github-script@v6
id: read-ci-status
env:
RUN_ID: ${{ steps.trigger-ci.outputs.workflow_id }}
with:
github-token: ${{ steps.app-token.outputs.token }}
script: |
const {data: run} = await github.rest.actions.getWorkflowRun({
owner: 'TBD54566975',
repo: '${{ matrix.repo }}',
run_id: ${{ env.RUN_ID }},
});
console.info({run})
return run.conclusion
- id: output
run: |
echo "${{ matrix.repo }}=${{ steps.read-ci-status.outputs.result }}" >> $GITHUB_OUTPUT
collect-results:
name: Collect Tests Results
needs: test
runs-on: ubuntu-latest
steps:
- name: Collect job results
run: |
get_status_emoji() {
if [ "$1" == "success" ]; then
echo "✅"
else
echo "❌"
fi
}
echo "## tbdex Spec Implementation SDKs Test Results" >> $GITHUB_STEP_SUMMARY
echo "| Repository | Status |" >> $GITHUB_STEP_SUMMARY
echo "|------------|--------|" >> $GITHUB_STEP_SUMMARY
echo "|tbdex-js|$(get_status_emoji ${{ needs.test.outputs.tbdex-js }}) (${{ needs.test.outputs.tbdex-js }})|" >> $GITHUB_STEP_SUMMARY
echo "|tbdex-swift|$(get_status_emoji ${{ needs.test.outputs.tbdex-swift }}) (${{ needs.test.outputs.tbdex-swift }})|" >> $GITHUB_STEP_SUMMARY
echo "|tbdex-kt|$(get_status_emoji ${{ needs.test.outputs.tbdex-kt }}) (${{ needs.test.outputs.tbdex-kt }})|" >> $GITHUB_STEP_SUMMARY
echo "|tbdex-rs|$(get_status_emoji ${{ needs.test.outputs.tbdex-rs }}) (${{ needs.test.outputs.tbdex-rs }})|" >> $GITHUB_STEP_SUMMARY
- name: Display job summary
run: cat $GITHUB_STEP_SUMMARY
- name: Upsert comment with job summary
uses: actions/github-script@v6
env:
GITHUB_STEP_SUMMARY: ${{ env.GITHUB_STEP_SUMMARY }}
with:
script: |
const summaryFile = process.env.GITHUB_STEP_SUMMARY
if (!summaryFile) {
throw new Error("GITHUB_STEP_SUMMARY is not set")
}
let githubSummary = '__This is an automated bot message__\n\n';
const execOptions = { listeners: { stdout: (data) => { githubSummary += data.toString() } } }
await exec.exec('cat', [summaryFile], execOptions);
const {data: comments} = await github.rest.issues.listComments({
owner: "TBD54566975",
repo: "tbdex",
issue_number: ${{ github.event.pull_request.number }},
});
const summaryComment = comments.find(comment => comment.body.includes("| Repository | Status |" && comment.user.type === "Bot"))
if (summaryComment) {
await github.rest.issues.updateComment({
comment_id: summaryComment.id,
body: githubSummary,
});
} else {
await github.rest.issues.createComment({
owner: "TBD54566975",
repo: "tbdex",
issue_number: ${{ github.event.pull_request.number }},
body: githubSummary,
});
}