Skip to content

schema package: Build a python package with the schema #39

schema package: Build a python package with the schema

schema package: Build a python package with the schema #39

Workflow file for this run

# SPDX-License-Identifier: Apache-2.0
name: Lint
on:
push:
branches:
- "main"
paths:
- '**.py'
- 'pyproject.toml'
- 'tox.ini'
- 'scripts/**'
- 'src/instructlab/schema/v*/**/*.json'
- '.github/workflows/lint.yml' # This workflow
pull_request:
branches:
- "main"
paths:
- '**.py'
- 'pyproject.toml'
- 'tox.ini'
- 'scripts/**'
- 'src/instructlab/schema/v*/**/*.json'
- '.github/workflows/lint.yml' # This workflow
env:
LC_ALL: en_US.UTF-8
defaults:
run:
shell: bash
permissions:
contents: read
jobs:
jsonschema:
runs-on: ubuntu-latest
steps:
- name: "Harden Runner"
uses: step-security/harden-runner@f086349bfa2bd1361f7909c78558e816508cdc10 # v2.8.0
with:
egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs
- name: "Checkout"
uses: actions/checkout@a5ac7e51b41094c92402da3b24376905380afc29 # v4.1.6
with:
fetch-depth: 0
- name: "Setup tox"
uses: ./.github/actions/python
with:
python-version: "3.11"
python-packages: "tox"
- name: "JSON schema validation"
run: |
# shellcheck disable=SC2046
tox -e jsonschema -- $(find src/instructlab/schema/v* -name "*.json")
ruff:
runs-on: ubuntu-latest
steps:
- name: "Harden Runner"
uses: step-security/harden-runner@f086349bfa2bd1361f7909c78558e816508cdc10 # v2.8.0
with:
egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs
- name: "Checkout"
uses: actions/checkout@a5ac7e51b41094c92402da3b24376905380afc29 # v4.1.6
with:
fetch-depth: 0
- name: "Setup tox"
uses: ./.github/actions/python
with:
python-version: "3.11"
python-packages: "tox"
- name: "Ruff"
run: |
tox -e ruff -- check
env:
RUFF_OUTPUT_FORMAT: github
pylint:
runs-on: ubuntu-latest
steps:
- name: "Harden Runner"
uses: step-security/harden-runner@f086349bfa2bd1361f7909c78558e816508cdc10 # v2.8.0
with:
egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs
- name: "Checkout"
uses: actions/checkout@a5ac7e51b41094c92402da3b24376905380afc29 # v4.1.6
with:
fetch-depth: 0
- name: "Setup tox"
uses: ./.github/actions/python
with:
python-version: "3.11"
python-packages: "tox"
- name: "Pylint"
run: |
echo "::add-matcher::.github/workflows/matchers/pylint.json"
tox -e lint
mypy:
runs-on: ubuntu-latest
steps:
- name: "Harden Runner"
uses: step-security/harden-runner@f086349bfa2bd1361f7909c78558e816508cdc10 # v2.8.0
with:
egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs
- name: "Checkout"
uses: actions/checkout@a5ac7e51b41094c92402da3b24376905380afc29 # v4.1.6
with:
fetch-depth: 0
- name: "Setup tox"
uses: ./.github/actions/python
with:
python-version: "3.11"
python-packages: "tox"
- name: "mypy"
run: |
echo "::add-matcher::.github/workflows/matchers/mypy.json"
tox -e mypy