[DOP-30631] Add support for Iceberg REST Catalog + S3 delegated access #1758
Workflow file for this run
This file contains hidden or 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: Code analysis | |
| on: | |
| push: | |
| branches: | |
| - develop | |
| pull_request: | |
| branches-ignore: | |
| - master | |
| workflow_dispatch: | |
| concurrency: | |
| group: ${{ github.workflow }}-${{ github.head_ref || github.ref }} | |
| cancel-in-progress: true | |
| env: | |
| # flake8-commas is failing on Python 3.12 | |
| DEFAULT_PYTHON: '3.13' | |
| jobs: | |
| linters: | |
| name: Linters | |
| runs-on: ubuntu-latest | |
| permissions: | |
| actions: read | |
| contents: read | |
| security-events: write | |
| steps: | |
| - name: Checkout repository | |
| uses: actions/checkout@v5 | |
| - name: Set up Python ${{ env.DEFAULT_PYTHON }} | |
| uses: actions/setup-python@v6 | |
| with: | |
| python-version: ${{ env.DEFAULT_PYTHON }} | |
| - name: Install system dependencies | |
| run: | | |
| sudo apt-get update && \ | |
| sudo apt-get install -y --no-install-recommends \ | |
| openjdk-17-jdk-headless \ | |
| gcc \ | |
| make \ | |
| libffi-dev \ | |
| libkrb5-dev \ | |
| curl | |
| - name: Install poetry | |
| uses: snok/install-poetry@v1 | |
| - name: Cache poetry | |
| uses: actions/cache@v4 | |
| with: | |
| path: ~/.cache/pypoetry | |
| key: ${{ runner.os }}-python-${{ env.DEFAULT_PYTHON }}-codeql-${{ hashFiles('**/poetry.lock') }} | |
| restore-keys: | | |
| ${{ runner.os }}-python-${{ env.DEFAULT_PYTHON }}-codeql-${{ hashFiles('**/poetry.lock') }} | |
| ${{ runner.os }}-python-${{ env.DEFAULT_PYTHON }}-codeql- | |
| ${{ runner.os }}-python- | |
| - name: Install dependencies | |
| run: | | |
| poetry install --no-root --all-extras --with dev --without test | |
| - name: Run flake8 | |
| run: poetry run flake8 syncmaster/ | |
| - name: Run mypy | |
| run: poetry run mypy --config-file ./pyproject.toml ./syncmaster/server | |
| codeql: | |
| name: CodeQL | |
| runs-on: ubuntu-latest | |
| permissions: | |
| actions: read | |
| contents: read | |
| security-events: write | |
| steps: | |
| - name: Checkout repository | |
| uses: actions/checkout@v5 | |
| - name: Set up Python ${{ env.DEFAULT_PYTHON }} | |
| uses: actions/setup-python@v6 | |
| with: | |
| python-version: ${{ env.DEFAULT_PYTHON }} | |
| # Initializes the CodeQL tools for scanning. | |
| - name: Initialize CodeQL | |
| uses: github/codeql-action/init@v4 | |
| with: | |
| languages: python | |
| - name: Perform CodeQL Analysis | |
| uses: github/codeql-action/analyze@v4 | |
| with: | |
| category: /language:python |