This repository has been archived by the owner on Dec 12, 2024. It is now read-only.
Introduce spec implementation tests #47
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: 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 | |
# id: summarize-results | |
# run: | | |
# get_status_emoji() { | |
# if [ "$1" == "success" ]; then | |
# echo "✅" | |
# else | |
# echo "❌" | |
# fi | |
# } | |
# touch summary.md | |
# echo "## tbdex Spec Implementation SDKs Test Results" >> summary.md | |
# echo "| Repository | Status |" >> summary.md | |
# echo "|------------|--------|" >> summary.md | |
# echo "|tbdex-js|$(get_status_emoji ${{ needs.test.outputs.tbdex-js }}) (${{ needs.test.outputs.tbdex-js }})|" >> summary.md | |
# echo "|tbdex-swift|$(get_status_emoji ${{ needs.test.outputs.tbdex-swift }}) (${{ needs.test.outputs.tbdex-swift }})|" >> summary.md | |
# echo "|tbdex-kt|$(get_status_emoji ${{ needs.test.outputs.tbdex-kt }}) (${{ needs.test.outputs.tbdex-kt }})|" >> summary.md | |
# echo "|tbdex-rs|$(get_status_emoji ${{ needs.test.outputs.tbdex-rs }}) (${{ needs.test.outputs.tbdex-rs }})|" >> summary.md | |
# SUMMARY=$(cat summary.md) | |
# echo "SUMMARY<<EOF" >> $GITHUB_OUTPUT | |
# echo "$SUMMARY" >> $GITHUB_OUTPUT | |
# echo "EOF" >> $GITHUB_OUTPUT | |
# echo $SUMMARY >> $GITHUB_STEP_SUMMARY | |
# - name: Display job summary | |
# env: | |
# SUMMARY: ${{ steps.summarize-results.outputs.SUMMARY }} | |
# run: echo $SUMMARY | |
# - name: Generate an access token to write to downstream repo | |
# uses: actions/create-github-app-token@2986852ad836768dfea7781f31828eb3e17990fa # v1.6.2 | |
# id: app-token | |
# if: ${{ github.event_name == 'pull_request' }} | |
# with: | |
# app-id: ${{ secrets.CICD_ROBOT_GITHUB_APP_ID }} | |
# private-key: ${{ secrets.CICD_ROBOT_GITHUB_APP_PRIVATE_KEY }} | |
# owner: TBD54566975 | |
# repositories: tbdex | |
# - name: Upsert comment with job summary | |
# uses: actions/github-script@v6 | |
# if: ${{ github.event_name == 'pull_request' }} | |
# env: | |
# SUMMARY: ${{ steps.summarize-results.outputs.SUMMARY }} | |
# with: | |
# github-token: ${{ steps.app-token.outputs.token }} | |
# script: | | |
# const summaryFile = `${{ env.SUMMARY }}` | |
# if (!summaryFile) { | |
# throw new Error("SUMMARY is not set") | |
# } | |
# const suffixFooter = 'This is an automated CI report' | |
# let githubSummary = `${summaryFile}\n\n---\n_${suffixFooter}_`; | |
# const {data: comments} = await github.rest.issues.listComments({ | |
# owner: "TBD54566975", | |
# repo: "tbdex", | |
# issue_number: ${{ github.event.pull_request.number }}, | |
# }); | |
# const summaryComment = comments.find(({user, body}) => user.type === "Bot" && user.login === "tbd-ci-cd-robot[bot]" && body.includes(suffixFooter)) | |
# 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, | |
# }); | |
# } |