name: build on: pull_request: types: [opened, synchronize] merge_group: types: [checks_requested] push: # Always run on push to main. The build cache can only be reused # if it was saved by a run from the repository's default branch. # The run result will be identical to that from the merge queue # because the commit is identical, yet we need to perform it to # seed the build cache. branches: - main jobs: tests: runs-on: ${{ matrix.os }} strategy: fail-fast: false matrix: os: - macos-latest - ubuntu-latest - windows-latest steps: - name: Checkout repository and submodules uses: actions/checkout@v4 - name: Setup Go uses: actions/setup-go@v5 with: go-version: 1.23.4 - name: Setup Python uses: actions/setup-python@v5 with: python-version: '3.9' - name: Install uv uses: astral-sh/setup-uv@v4 - name: Set go env run: | echo "GOPATH=$(go env GOPATH)" >> $GITHUB_ENV echo "$(go env GOPATH)/bin" >> $GITHUB_PATH go install gotest.tools/gotestsum@v1.12.0 - name: Pull external libraries run: | make vendor pip3 install wheel - name: Run tests run: make testonly golangci: name: lint runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - uses: actions/setup-go@v5 with: go-version: 1.23.4 - name: Run go mod tidy run: | go mod tidy - name: Fail on differences run: | # Exit with status code 1 if there are differences (i.e. unformatted files) git diff --exit-code - name: golangci-lint uses: golangci/golangci-lint-action@v6 with: version: v1.63.1 args: --timeout=15m validate-bundle-schema: runs-on: ubuntu-latest steps: - name: Checkout uses: actions/checkout@v4 - name: Setup Go uses: actions/setup-go@v5 with: go-version: 1.23.4 - name: Verify that the schema is up to date run: | if ! ( make schema && git diff --exit-code ); then echo "The schema is not up to date. Please run 'make schema' and commit the changes." exit 1 fi # Github repo: https://github.com/ajv-validator/ajv-cli - name: Install ajv-cli run: npm install -g ajv-cli@5.0.0 # Assert that the generated bundle schema is a valid JSON schema by using # ajv-cli to validate it against bundle configuration files. # By default the ajv-cli runs in strict mode which will fail if the schema # itself is not valid. Strict mode is more strict than the JSON schema # specification. See for details: https://ajv.js.org/options.html#strict-mode-options # The ajv-cli is configured to use the markdownDescription keyword which is not part of the JSON schema specification, # but is used in editors like VSCode to render markdown in the description field - name: Validate bundle schema run: | go run main.go bundle schema > schema.json # Add markdownDescription keyword to ajv echo "module.exports=function(a){a.addKeyword('markdownDescription')}" >> keywords.js for file in ./bundle/internal/schema/testdata/pass/*.yml; do ajv test -s schema.json -d $file --valid -c=./keywords.js done for file in ./bundle/internal/schema/testdata/fail/*.yml; do ajv test -s schema.json -d $file --invalid -c=./keywords.js done