feat: Create NetStandard 2.0 library #2936
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
# The jobs in this workflow are necessary because they are configured as | |
# required checks on PRs. Github does not currently support configuring required | |
# checks per workflow. A PR that only triggers codegen-ci.yml jobs will only | |
# report back with the "Codegen Tests" check. But because there is only a global | |
# option for required PR checks, that PR would otherwise never satisfy the | |
# "Typescript/Python/APIX Tests" checks without these noop jobs. | |
# | |
# References: | |
# https://github.community/t/github-actions-and-required-checks-in-a-monorepo-using-paths-to-limit-execution/16586 | |
# https://github.community/t/feature-request-conditional-required-checks/16761/6 | |
# | |
# Each job actually has a corresponding "real" job | |
# definition in a different workflow file: | |
# | |
# codegen-ci.yml: Codegen Tests | |
# tssdk-ci.yml: Typescript SDK Tests | |
# python-ci.yml: Python SDK Tests | |
# apix-ci.yml: APIX Tests | |
# go-ci.yml: Go SDK Tests | |
# | |
name: Required Checks Hack | |
on: | |
pull_request: | |
push: | |
branches: | |
- main | |
permissions: | |
checks: write | |
jobs: | |
satisfy-required-checks: | |
name: Satisfy Required Checks | |
runs-on: ubuntu-latest | |
steps: | |
- name: Repo Checkout | |
uses: actions/checkout@v4 | |
- uses: tony84727/changed-file-filter@v0.2.3 | |
id: filter | |
with: | |
filters: | | |
apix: | |
- 'package.json' | |
- 'packages/code-editor/**/*' | |
- 'packages/run-it/**/*' | |
- 'packages/api-explorer/**/*' | |
- 'packages/extension-api-explorer/**/*' | |
- 'packages/extension-utils/**/*' | |
- '.github/workflows/apix-ci.yml' | |
- 'yarn.lock' | |
codegen: | |
- 'package.json' | |
- 'packages/sdk-codegen/**/*' | |
- 'packages/sdk-codegen-utils/**/*' | |
- 'packages/sdk-codegen-scripts/**/*' | |
- '.github/workflows/codegen-ci.yml' | |
- 'yarn.lock' | |
hackathon: | |
- 'package.json' | |
- 'packages/wholly-sheet/**/*' | |
- 'packages/hackathon/**/*' | |
- '.github/workflows/hackathon-ci.yml' | |
- 'yarn.lock' | |
python: | |
- 'Pipfile' | |
- 'Pipfile.lock' | |
- 'python/**/*' | |
- '.github/workflows/python-ci.yml' | |
resources: | |
- 'bin/looker-resources-index/**/*' | |
- 'docs/resources/**/*' | |
- '.github/workflows/resources-ci.yml' | |
tssdk: | |
- 'package.json' | |
- 'packages/sdk/**/*' | |
- 'packages/sdk-rtl/**/*' | |
- 'packages/sdk-node/**/*' | |
- 'packages/extension-sdk/**/*' | |
- 'packages/extension-sdk-react/**/*' | |
- 'packages/extension-utils/**/*' | |
- '.github/workflows/tssdk-ci.yml' | |
- 'yarn.lock' | |
gosdk: | |
- 'packages/go/**/*' | |
- '.github/workflows/go-ci.yml' | |
- name: Debug info | |
run: | | |
echo "${{ toJSON(steps.filter.outputs) }}" | |
echo "apix: ${{ steps.filter.outputs.apix }}" | |
echo "codegen: ${{ steps.filter.outputs.codegen }}" | |
echo "hackathon: ${{ steps.filter.outputs.hackathon }}" | |
echo "python: ${{ steps.filter.outputs.python }}" | |
echo "resources: ${{ steps.filter.outputs.resources }}" | |
echo "tssdk: ${{ steps.filter.outputs.tssdk }}" | |
echo "gosdk: ${{ steps.filter.outputs.gosdk }}" | |
- name: Create Codegen check | |
if: steps.filter.outputs.codegen == 'false' | |
run: | | |
curl --request POST \ | |
--url https://api.github.com/repos/looker-open-source/sdk-codegen/check-runs \ | |
--header "authorization: token ${{ secrets.GITHUB_TOKEN }}" \ | |
--header "content-type: application/json" \ | |
--header "Accept: application/vnd.github.v3+json" \ | |
--data '{ | |
"name": "Codegen Tests", | |
"head_sha": "${{ github.event.pull_request.head.sha || github.sha }}", | |
"output": { | |
"title": "Required Checks Hack / Codegen Tests", | |
"summary": "Associated files have not been changed so this can be skipped" | |
}, | |
"conclusion": "success" | |
}' \ | |
--fail | |
- name: Create Typescript check | |
if: steps.filter.outputs.tssdk == 'false' | |
run: | | |
curl --request POST \ | |
--url https://api.github.com/repos/looker-open-source/sdk-codegen/check-runs \ | |
--header "authorization: token ${{ secrets.GITHUB_TOKEN }}" \ | |
--header "content-type: application/json" \ | |
--header "Accept: application/vnd.github.v3+json" \ | |
--data '{ | |
"name": "Typescript Tests", | |
"head_sha": "${{ github.event.pull_request.head.sha || github.sha }}", | |
"output": { | |
"title": "Required Checks Hack / Typescript Tests", | |
"summary": "Associated files have not been changed so this can be skipped" | |
}, | |
"conclusion": "success" | |
}' \ | |
--fail | |
- name: Create Python check | |
if: steps.filter.outputs.python == 'false' | |
run: | | |
curl --request POST \ | |
--url https://api.github.com/repos/looker-open-source/sdk-codegen/check-runs \ | |
--header "authorization: token ${{ secrets.GITHUB_TOKEN }}" \ | |
--header "content-type: application/json" \ | |
--header "Accept: application/vnd.github.v3+json" \ | |
--data '{ | |
"name": "Python Tests", | |
"head_sha": "${{ github.event.pull_request.head.sha || github.sha }}", | |
"output": { | |
"title": "Required Checks Hack / Python Tests", | |
"summary": "Associated files have not been changed so this can be skipped" | |
}, | |
"conclusion": "success" | |
}' \ | |
--fail | |
- name: Create APIX check | |
if: steps.filter.outputs.apix == 'false' | |
run: | | |
curl --request POST \ | |
--url https://api.github.com/repos/looker-open-source/sdk-codegen/check-runs \ | |
--header "authorization: token ${{ secrets.GITHUB_TOKEN }}" \ | |
--header "content-type: application/json" \ | |
--header "Accept: application/vnd.github.v3+json" \ | |
--data '{ | |
"name": "APIX Tests", | |
"head_sha": "${{ github.event.pull_request.head.sha || github.sha }}", | |
"output": { | |
"title": "Required Checks Hack / APIX Tests", | |
"summary": "Associated files have not been changed so this can be skipped" | |
}, | |
"conclusion": "success" | |
}' \ | |
--fail | |
- name: Create Go check | |
if: steps.filter.outputs.gosdk == 'false' | |
run: | | |
curl --request POST \ | |
--url https://api.github.com/repos/looker-open-source/sdk-codegen/check-runs \ | |
--header "authorization: token ${{ secrets.GITHUB_TOKEN }}" \ | |
--header "content-type: application/json" \ | |
--header "Accept: application/vnd.github.v3+json" \ | |
--data '{ | |
"name": "Go Tests", | |
"head_sha": "${{ github.event.pull_request.head.sha || github.sha }}", | |
"output": { | |
"title": "Required Checks Hack / Go Tests", | |
"summary": "Associated files have not been changed so this can be skipped" | |
}, | |
"conclusion": "success" | |
}' \ | |
--fail |