[WIP] feat: Config reference documentation autogeneration #8479
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: 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 | |
schedule: | |
- cron: '0 0,12 * * *' # Runs at 00:00 and 12:00 UTC daily | |
env: | |
GOTESTSUM_FORMAT: github-actions | |
jobs: | |
cleanups: | |
runs-on: | |
group: databricks-deco-testing-runner-group | |
labels: ubuntu-latest-deco | |
steps: | |
- name: Clean up cache if running on schedule | |
if: ${{ github.event_name == 'schedule' }} | |
env: | |
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
run: gh cache delete --all --repo databricks/cli || true | |
tests: | |
needs: cleanups | |
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/[email protected] | |
- name: Pull external libraries | |
run: | | |
make vendor | |
pip3 install wheel | |
- name: Run tests | |
run: make test | |
golangci: | |
needs: cleanups | |
name: lint | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-go@v5 | |
with: | |
go-version: 1.23.4 | |
# Use different schema from regular job, to avoid overwriting the same key | |
cache-dependency-path: | | |
go.sum | |
.golangci.yaml | |
- 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.4 | |
args: --timeout=15m | |
validate-bundle-schema: | |
needs: cleanups | |
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 | |
# Use different schema from regular job, to avoid overwriting the same key | |
cache-dependency-path: | | |
go.sum | |
bundle/internal/schema/*.* | |
- 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 [email protected] | |
# 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 |