From af60477c51950bce7c533a1232247bf21391600c Mon Sep 17 00:00:00 2001 From: Thomas S Date: Mon, 30 Dec 2024 23:38:52 +0100 Subject: [PATCH 1/2] ci: Refactor workflows so that they are usable by forks --- .github/workflows/backend.yml | 97 +++++++++++++++++++ .github/workflows/ci.yml | 69 ------------- .github/workflows/frontend.yml | 89 +++++++++++++++++ .github/workflows/lint.yml | 41 +++++--- ...dd-pr-assignee.yml => pr-add-assignee.yml} | 8 +- .github/workflows/pr-cleanup.yml | 79 +++++++++++++++ .../workflows/pr-display-backend-coverage.yml | 57 +++++++++++ .../pr-display-frontend-coverage.yml | 55 +++++++++++ .../{lint-pr-title.yml => pr-lint-title.yml} | 4 +- .../pr-serve-documentation-preview.yml | 71 ++++++++++++++ .github/workflows/release.yml | 2 +- .github/workflows/skore-ui.yml | 62 ------------ .github/workflows/skore.yml | 68 ------------- .github/workflows/sphinx.yml | 15 +-- 14 files changed, 495 insertions(+), 222 deletions(-) create mode 100644 .github/workflows/backend.yml delete mode 100644 .github/workflows/ci.yml create mode 100644 .github/workflows/frontend.yml rename .github/workflows/{add-pr-assignee.yml => pr-add-assignee.yml} (90%) create mode 100644 .github/workflows/pr-cleanup.yml create mode 100644 .github/workflows/pr-display-backend-coverage.yml create mode 100644 .github/workflows/pr-display-frontend-coverage.yml rename .github/workflows/{lint-pr-title.yml => pr-lint-title.yml} (96%) create mode 100644 .github/workflows/pr-serve-documentation-preview.yml delete mode 100644 .github/workflows/skore-ui.yml delete mode 100644 .github/workflows/skore.yml diff --git a/.github/workflows/backend.yml b/.github/workflows/backend.yml new file mode 100644 index 000000000..bceacb9b9 --- /dev/null +++ b/.github/workflows/backend.yml @@ -0,0 +1,97 @@ +name: backend + +on: + pull_request: + paths: + - 'skore/src/**' + - 'skore/tests/**' + - 'skore/pyproject.toml' + - 'skore/requirements*.txt' + - '.github/workflows/backend.yml' + push: + branches: + - main + +concurrency: + group: ${{ github.workflow }}-${{ github.ref }} + cancel-in-progress: true + +permissions: + contents: read + +defaults: + run: + shell: "bash" + +jobs: + backend-lint: + runs-on: "ubuntu-latest" + steps: + - name: Checkout code + uses: actions/checkout@v4 + + - name: Setup Python + uses: actions/setup-python@v5 + with: + python-version: "3.12" + cache: pip + + - name: Install dependencies + run: python -m pip install --upgrade pip pre-commit + + - name: Lint + working-directory: skore/ + run: pre-commit run --all-files ruff + + backend-test: + strategy: + fail-fast: true + matrix: + os: ["ubuntu-latest", "windows-latest"] + python: ["3.9", "3.10", "3.11", "3.12"] + include: + - os: "ubuntu-latest" + python: "3.12" + coverage: true + runs-on: ${{ matrix.os }} + steps: + - name: Checkout code + uses: actions/checkout@v4 + + - name: Setup Python + uses: actions/setup-python@v5 + with: + python-version: ${{ matrix.python }} + cache: pip + + - name: Install dependencies + run: python -m pip install --upgrade pip build + + - name: Build + working-directory: skore/ + run: python -m build + + - name: Install + working-directory: skore/ + run: wheel=(dist/*.whl); python -m pip install "${wheel}[test]" + + - name: Test without coverage + if: ${{ ! matrix.coverage }} + timeout-minutes: 10 + working-directory: skore/ + run: python -m pytest -n auto --no-cov src/ tests/ + + - name: Test with coverage + if: ${{ matrix.coverage }} + timeout-minutes: 10 + working-directory: skore/ + run: | + mkdir coverage + python -m pytest -n auto --junitxml=coverage/coverage.xml --cov=skore src/ tests/ | tee coverage/coverage.txt + + - name: Upload coverage reports + if: ${{ matrix.coverage && (github.event_name == 'pull_request') }} + uses: actions/upload-artifact@v4 + with: + name: backend-coverage + path: skore/coverage/ diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml deleted file mode 100644 index e3db1d26d..000000000 --- a/.github/workflows/ci.yml +++ /dev/null @@ -1,69 +0,0 @@ -name: CI - -on: - pull_request: - push: - branches: - - main - -concurrency: - group: ${{ github.workflow }}-${{ github.ref }} - cancel-in-progress: true - -jobs: - changes: - runs-on: ubuntu-latest - outputs: - skore: ${{ steps.filter.outputs.skore }} - skore-ui: ${{ steps.filter.outputs.skore-ui }} - permissions: - pull-requests: read - steps: - - uses: actions/checkout@v4 - - uses: dorny/paths-filter@v3 - id: filter - with: - filters: | - skore: - - 'skore/src/**' - - 'skore/tests/**' - - 'skore/pyproject.toml' - - 'skore/requirements*.txt' - - '.github/workflows/skore.yml' - skore-ui: - - 'skore-ui/**' - - '.github/workflows/skore-ui.yml' - - lint-all-files: - uses: ./.github/workflows/lint.yml - permissions: - contents: read - - lint-and-test-skore: - needs: [lint-all-files, changes] - if: ${{ (github.event_name == 'push' && github.ref == 'refs/heads/main') || (github.event_name == 'pull_request' && needs.changes.outputs.skore == 'true') }} - uses: ./.github/workflows/skore.yml - permissions: - contents: read - pull-requests: write - - lint-and-test-skore-ui: - needs: [lint-all-files, changes] - if: ${{ (github.event_name == 'push' && github.ref == 'refs/heads/main') || (github.event_name == 'pull_request' && needs.changes.outputs.skore-ui == 'true') }} - uses: ./.github/workflows/skore-ui.yml - permissions: - contents: read - pull-requests: write - - ci-all-green: - needs: - - changes - - lint-all-files - - lint-and-test-skore - - lint-and-test-skore-ui - if: ${{ always() }} - runs-on: Ubuntu-latest - steps: - - shell: bash - run: | - [[ ${{ contains(needs.*.result, 'failure') }} = false ]] diff --git a/.github/workflows/frontend.yml b/.github/workflows/frontend.yml new file mode 100644 index 000000000..641493bae --- /dev/null +++ b/.github/workflows/frontend.yml @@ -0,0 +1,89 @@ +name: frontend + +on: + pull_request: + paths: + - 'skore-ui/**' + - '.github/workflows/frontend.yml' + push: + branches: + - main + +concurrency: + group: ${{ github.workflow }}-${{ github.ref }} + cancel-in-progress: true + +permissions: + contents: read + +defaults: + run: + shell: "bash" + +jobs: + frontend-lint: + runs-on: ubuntu-latest + steps: + - name: Checkout code + uses: actions/checkout@v4 + + - name: Setup Node + uses: actions/setup-node@v4 + with: + node-version: '20' + cache: 'npm' + cache-dependency-path: skore-ui/package-lock.json + + - name: Lint + working-directory: skore-ui/ + run: | + npm install + npm run type-check + npm run lint + npm run format + npm run style-lint + + frontend-test: + runs-on: ubuntu-latest + steps: + - name: Checkout code + uses: actions/checkout@v4 + + - name: Setup Node + uses: actions/setup-node@v4 + with: + node-version: '20' + cache: 'npm' + cache-dependency-path: skore-ui/package-lock.json + + - name: Test with coverage + working-directory: skore-ui/ + run: | + npm install + npm run test:unit:coverage + + - name: Upload coverage reports + if: ${{ github.event_name == 'pull_request' }} + uses: actions/upload-artifact@v4 + with: + name: frontend-coverage + path: skore-ui/coverage/ + + frontend-build: + runs-on: ubuntu-latest + steps: + - name: Checkout code + uses: actions/checkout@v4 + + - name: Setup Node + uses: actions/setup-node@v4 + with: + node-version: '20' + cache: 'npm' + cache-dependency-path: skore-ui/package-lock.json + + - name: Build + working-directory: skore-ui/ + run: | + npm install + npm run build diff --git a/.github/workflows/lint.yml b/.github/workflows/lint.yml index 886506ca7..9d76ffc11 100644 --- a/.github/workflows/lint.yml +++ b/.github/workflows/lint.yml @@ -1,21 +1,40 @@ -name: Reusable lint workflow +name: lint -on: [workflow_call] +on: + pull_request: + push: + branches: + - main + +concurrency: + group: ${{ github.workflow }}-${{ github.ref }} + cancel-in-progress: true + +permissions: + contents: read + +defaults: + run: + shell: "bash" jobs: - lint-all-files: + lint: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v4 - - uses: actions/setup-python@v5 + - name: Checkout code + uses: actions/checkout@v4 + + - name: Setup Python + uses: actions/setup-python@v5 with: - python-version: '3.12' - cache: 'pip' - - name: Lint all files - run: | - python -m pip install --upgrade pip - python -m pip install --upgrade pre-commit + python-version: "3.12" + cache: pip + + - name: Install dependencies + run: python -m pip install --upgrade pip pre-commit + - name: Lint + run: | pre-commit run --all-files check-yaml pre-commit run --all-files check-toml pre-commit run --all-files check-added-large-files diff --git a/.github/workflows/add-pr-assignee.yml b/.github/workflows/pr-add-assignee.yml similarity index 90% rename from .github/workflows/add-pr-assignee.yml rename to .github/workflows/pr-add-assignee.yml index c6570c0aa..f5a673e1c 100644 --- a/.github/workflows/add-pr-assignee.yml +++ b/.github/workflows/pr-add-assignee.yml @@ -1,11 +1,13 @@ -name: Add PR assignee +name: add assignee in PR on: - pull_request: + pull_request_target: types: [opened] +permissions: {} + jobs: - add-pr-assignee: + add-assignee: runs-on: ubuntu-latest permissions: pull-requests: write diff --git a/.github/workflows/pr-cleanup.yml b/.github/workflows/pr-cleanup.yml new file mode 100644 index 000000000..585dec7c0 --- /dev/null +++ b/.github/workflows/pr-cleanup.yml @@ -0,0 +1,79 @@ +name: cleanup PR + +on: + pull_request_target: + types: [closed] + +permissions: {} + +defaults: + run: + shell: "bash" + +jobs: + clean-artifacts: + if: always() + runs-on: ubuntu-latest + permissions: + actions: write + steps: + - name: Clean artifacts + run: | + set -u + + ARTIFACTS=$( \ + gh api \ + --paginate \ + -H "Accept: application/vnd.github+json" \ + -H "X-GitHub-Api-Version: 2022-11-28" \ + /repos/probabl-ai/skore/actions/artifacts \ + | \ + jq -c " \ + .artifacts[] \ + | select((.workflow_run.head_branch == \"${HEAD_BRANCH}\") and (.workflow_run.head_repository_id == \"${HEAD_REPOSITORY_ID}\")) \ + | {id: .id, name: .name} \ + " \ + ) + + for ARTIFACT in $ARTIFACTS; do + ID=$(echo "${ARTIFACT}" | jq -r '.id') + NAME=$(echo "${ARTIFACT}" | jq -r '.name') + + echo "Deleting artifact (HEAD BRANCH: \"${HEAD_BRANCH}\", NAME: \"${NAME}\", ID: \"${ID}\")" + + gh api \ + --method DELETE \ + --silent \ + -H "Accept: application/vnd.github+json" \ + -H "X-GitHub-Api-Version: 2022-11-28" \ + /repos/${REPOSITORY_OWNER}/${REPOSITORY_NAME}/actions/artifacts/${ID} + done + env: + GH_TOKEN: ${{ github.token }} + REPOSITORY_OWNER: ${{ github.repository_owner }} + REPOSITORY_NAME: ${{ github.event.repository.name }} + HEAD_REPOSITORY_ID: ${{ github.event.pull_request.head.repo.id }} + HEAD_BRANCH: ${{ github.head_ref }} + + clean-documentation-preview: + if: always() + runs-on: ubuntu-latest + steps: + - name: Install `rclone` + shell: bash + run: | + sudo apt-get update + sudo apt-get install -y rclone + + - name: Copy configuration + shell: bash + run: echo "${CONFIGURATION}" > rclone.configuration + env: + CONFIGURATION: ${{ secrets.RCLONE_CONFIG_DOC_PREVIEW }} + + - name: Clean documentation preview + run: rclone --config rclone.configuration purge "${PROVIDER}:${BUCKET}/${PULL_REQUEST_NUMBER}" + env: + PROVIDER: scaleway + BUCKET: ${{ vars.DOCUMENTATION_PREVIEW_BUCKET }} + PULL_REQUEST_NUMBER: ${{ github.event.number }} diff --git a/.github/workflows/pr-display-backend-coverage.yml b/.github/workflows/pr-display-backend-coverage.yml new file mode 100644 index 000000000..a33c35e7f --- /dev/null +++ b/.github/workflows/pr-display-backend-coverage.yml @@ -0,0 +1,57 @@ +name: display backend coverage in PR + +on: + workflow_run: + workflows: [backend] + types: [completed] + +concurrency: + group: ${{ github.workflow }}-${{ github.ref }} + cancel-in-progress: true + +permissions: {} + +jobs: + acquire-pr-number: + if: ${{ github.event.workflow_run.event == 'pull_request' && github.event.workflow_run.conclusion == 'success' }} + runs-on: ubuntu-latest + outputs: + PR_NUMBER: ${{ steps.acquire-pr-number.outputs.number }} + permissions: + contents: read + steps: + - id: acquire-pr-number + run: gh pr view --repo "${REPOSITORY}" "${BRANCH}" --json 'number' --jq '"number=\(.number)"' >> "${GITHUB_OUTPUT}" + env: + GH_TOKEN: ${{ github.token }} + REPOSITORY: ${{ github.repository }} + BRANCH: |- + ${{ + (github.event.workflow_run.head_repository.fork == true) + && format('{0}:{1}', github.event.workflow_run.head_repository.owner.login, github.event.workflow_run.head_branch) + || github.event.workflow_run.head_branch + }} + + display-backend-coverage: + if: ${{ github.event.workflow_run.event == 'pull_request' && github.event.workflow_run.conclusion == 'success' }} + runs-on: ubuntu-latest + needs: [acquire-pr-number] + permissions: + actions: read + pull-requests: write + steps: + - name: Download coverage reports + uses: actions/download-artifact@v4 + with: + name: backend-coverage + path: coverage/ + github-token: ${{ github.token }} + run-id: ${{ github.event.workflow_run.id }} + + - name: Display coverage reports + uses: MishaKav/pytest-coverage-comment@main + with: + issue-number: ${{ needs.acquire-pr-number.outputs.PR_NUMBER }} + pytest-coverage-path: coverage/coverage.txt + junitxml-path: coverage/coverage.xml + title: Coverage Report for backend diff --git a/.github/workflows/pr-display-frontend-coverage.yml b/.github/workflows/pr-display-frontend-coverage.yml new file mode 100644 index 000000000..623263015 --- /dev/null +++ b/.github/workflows/pr-display-frontend-coverage.yml @@ -0,0 +1,55 @@ +name: display frontend coverage in PR + +on: + workflow_run: + workflows: [frontend] + types: [completed] + +concurrency: + group: ${{ github.workflow }}-${{ github.ref }} + cancel-in-progress: true + +permissions: {} + +jobs: + acquire-pr-number: + if: ${{ github.event.workflow_run.event == 'pull_request' && github.event.workflow_run.conclusion == 'success' }} + runs-on: ubuntu-latest + outputs: + PR_NUMBER: ${{ steps.acquire-pr-number.outputs.number }} + permissions: + contents: read + steps: + - id: acquire-pr-number + run: gh pr view --repo "${REPOSITORY}" "${BRANCH}" --json 'number' --jq '"number=\(.number)"' >> "${GITHUB_OUTPUT}" + env: + GH_TOKEN: ${{ github.token }} + REPOSITORY: ${{ github.repository }} + BRANCH: |- + ${{ + (github.event.workflow_run.head_repository.fork == true) + && format('{0}:{1}', github.event.workflow_run.head_repository.owner.login, github.event.workflow_run.head_branch) + || github.event.workflow_run.head_branch + }} + + display-frontend-coverage: + if: ${{ github.event.workflow_run.event == 'pull_request' && github.event.workflow_run.conclusion == 'success' }} + runs-on: ubuntu-latest + needs: [acquire-pr-number] + permissions: + actions: read + pull-requests: write + steps: + - name: Download coverage reports + uses: actions/download-artifact@v4 + with: + name: frontend-coverage + path: coverage/ + github-token: ${{ github.token }} + run-id: ${{ github.event.workflow_run.id }} + + - name: Display coverage reports + uses: davelosert/vitest-coverage-report-action@v2 + with: + pr-number: ${{ needs.acquire-pr-number.outputs.PR_NUMBER }} + name: frontend diff --git a/.github/workflows/lint-pr-title.yml b/.github/workflows/pr-lint-title.yml similarity index 96% rename from .github/workflows/lint-pr-title.yml rename to .github/workflows/pr-lint-title.yml index 0b1ea9944..d47f985d7 100644 --- a/.github/workflows/lint-pr-title.yml +++ b/.github/workflows/pr-lint-title.yml @@ -1,4 +1,4 @@ -name: Lint PR title +name: lint title in PR on: pull_request: @@ -8,7 +8,7 @@ permissions: pull-requests: read jobs: - lint-pr-title: + lint-title: runs-on: ubuntu-latest steps: - uses: actions/setup-node@v4 diff --git a/.github/workflows/pr-serve-documentation-preview.yml b/.github/workflows/pr-serve-documentation-preview.yml new file mode 100644 index 000000000..4362d3ec1 --- /dev/null +++ b/.github/workflows/pr-serve-documentation-preview.yml @@ -0,0 +1,71 @@ +name: serve documentation preview in PR + +on: + workflow_run: + workflows: [sphinx] + types: [completed] + +concurrency: + group: ${{ github.workflow }}-${{ github.ref }} + cancel-in-progress: true + +permissions: {} + +jobs: + acquire-pr-context: + if: ${{ github.event.workflow_run.event == 'pull_request' && github.event.workflow_run.conclusion == 'success' }} + runs-on: ubuntu-latest + outputs: + PR_NUMBER: ${{ steps.acquire-pr-context.outputs.number }} + PR_HEADSHA: ${{ steps.acquire-pr-context.outputs.headsha }} + permissions: + contents: read + steps: + - id: acquire-pr-context + run: gh pr view --repo "${REPOSITORY}" "${BRANCH}" --json 'number,headRefOid' --jq '"number=\(.number)\nheadsha=\(.headRefOid)"' >> "${GITHUB_OUTPUT}" + env: + GH_TOKEN: ${{ github.token }} + REPOSITORY: ${{ github.repository }} + BRANCH: |- + ${{ + (github.event.workflow_run.head_repository.fork == true) + && format('{0}:{1}', github.event.workflow_run.head_repository.owner.login, github.event.workflow_run.head_branch) + || github.event.workflow_run.head_branch + }} + + serve-documentation-preview: + if: ${{ github.event.workflow_run.event == 'pull_request' && github.event.workflow_run.conclusion == 'success' }} + runs-on: ubuntu-latest + needs: [acquire-pr-context] + permissions: + actions: read + contents: read + pull-requests: write + steps: + - name: Checkout code + uses: actions/checkout@v4 + + - name: Download HTML artifacts + uses: actions/download-artifact@v4 + with: + name: sphinx-html-artifact + path: html/ + github-token: ${{ github.token }} + run-id: ${{ github.event.workflow_run.id }} + + - name: Serve documentation preview + uses: ./.github/actions/sphinx/deploy + with: + CONFIGURATION: ${{ secrets.RCLONE_CONFIG_DOC_PREVIEW }} + BUCKET: ${{ vars.DOCUMENTATION_PREVIEW_BUCKET }} + SOURCE: html/ + DESTINATION: ${{ needs.acquire-pr-context.outputs.PR_NUMBER }}/ + + - name: Comment with documentation preview link + uses: marocchino/sticky-pull-request-comment@v2 + with: + number: ${{ needs.acquire-pr-context.outputs.PR_NUMBER }} + header: documentation-preview + message: >- + [Documentation preview](${{ vars.DOCUMENTATION_PREVIEW_URL }}/${{ needs.acquire-pr-context.outputs.PR_NUMBER }}) + @ ${{ needs.acquire-pr-context.outputs.PR_HEADSHA }} diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index f1f44d21f..768356c21 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -1,4 +1,4 @@ -name: Release +name: release on: release: diff --git a/.github/workflows/skore-ui.yml b/.github/workflows/skore-ui.yml deleted file mode 100644 index 6f1b63876..000000000 --- a/.github/workflows/skore-ui.yml +++ /dev/null @@ -1,62 +0,0 @@ -name: Reusable skore-ui workflow - -on: [workflow_call] - -defaults: - run: - shell: 'bash' - working-directory: './skore-ui' - -jobs: - lint-skore-ui: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v4 - - uses: actions/setup-node@v4 - with: - node-version: '20' - cache: 'npm' - cache-dependency-path: skore-ui/package-lock.json - - name: Lint skore-ui - run: | - npm install - npm run type-check - npm run lint - npm run format - npm run style-lint - - test-skore-ui: - runs-on: ubuntu-latest - needs: lint-skore-ui - steps: - - uses: actions/checkout@v4 - - uses: actions/setup-node@v4 - with: - node-version: '20' - cache: 'npm' - cache-dependency-path: skore-ui/package-lock.json - - name: Test skore-ui - run: | - npm install - npm run test:unit:coverage - - name: Report coverage - if: always() - uses: davelosert/vitest-coverage-report-action@v2 - with: - working-directory: ./skore-ui - pr-number: ${{ github.event.number }} - - build-skore-ui: - runs-on: ubuntu-latest - needs: test-skore-ui - steps: - - uses: actions/checkout@v4 - - uses: actions/setup-node@v4 - with: - node-version: '20' - cache: 'npm' - cache-dependency-path: skore-ui/package-lock.json - - name: Build skore-ui - run: | - npm install - npm run build diff --git a/.github/workflows/skore.yml b/.github/workflows/skore.yml deleted file mode 100644 index 8201a3aa7..000000000 --- a/.github/workflows/skore.yml +++ /dev/null @@ -1,68 +0,0 @@ -name: Reusable skore workflow - -on: [workflow_call] - -defaults: - run: - shell: "bash" - working-directory: "./skore" - -jobs: - test-skore: - strategy: - fail-fast: true - matrix: - os: ["ubuntu-latest", "windows-latest"] - python-version: ["3.9", "3.10", "3.11", "3.12"] - runs-on: ${{ matrix.os }} - steps: - - uses: actions/checkout@v4 - - uses: actions/setup-python@v5 - with: - python-version: ${{ matrix.python-version }} - cache: "pip" - - name: - timeout-minutes: 10 - run: | - # Install dependencies - python -m pip install --upgrade pip - python -m pip install --upgrade pre-commit - python -m pip install --upgrade build - - # Lint - pre-commit run --all-files ruff - - # Build - python -m build - - # Install - wheel=(dist/*.whl); python -m pip install "${wheel}[test]" - - # Test - python -m pytest --no-cov src/ tests/ -n auto - - coverage-skore: - runs-on: ubuntu-latest - if: ${{ github.event_name == 'pull_request' }} - steps: - - uses: actions/checkout@v4 - - uses: actions/setup-python@v5 - with: - python-version: 3.12 - cache: "pip" - - name: pytest coverage - run: | - # Install dependencies - python -m pip install --upgrade pip - python -m pip install --upgrade pre-commit - python -m pip install --upgrade build - python -m pip install -e .[test] - - # run coverage - python -m pytest -n auto --junitxml=coverage.xml --cov=skore src/ tests/ | tee pytest-coverage.txt - - name: Pytest coverage comment - uses: MishaKav/pytest-coverage-comment@main - with: - pytest-coverage-path: ./skore/pytest-coverage.txt - junitxml-path: ./skore/coverage.xml - title: pytest coverage report diff --git a/.github/workflows/sphinx.yml b/.github/workflows/sphinx.yml index 9b4be3374..a91976798 100644 --- a/.github/workflows/sphinx.yml +++ b/.github/workflows/sphinx.yml @@ -1,4 +1,4 @@ -name: Sphinx +name: sphinx # **How it works** @@ -116,8 +116,8 @@ jobs: path: sphinx/build/html/ sphinx-deploy-html: - runs-on: ubuntu-latest if: ${{ (github.event_name == 'release') || (github.event_name == 'push' && github.ref == 'refs/heads/main') }} + runs-on: ubuntu-latest needs: [sphinx-version, sphinx-build] steps: - uses: actions/checkout@v4 @@ -128,12 +128,13 @@ jobs: - uses: ./.github/actions/sphinx/deploy with: CONFIGURATION: ${{ secrets.RCLONE_CONFIG_DOCS }} + BUCKET: ${{ vars.DOCUMENTATION_BUCKET }} SOURCE: html/ DESTINATION: ${{ needs.sphinx-version.outputs.SPHINX_VERSION }}/ sphinx-deploy-root-files: - runs-on: ubuntu-latest if: ${{ github.event_name == 'release' }} + runs-on: ubuntu-latest needs: [sphinx-version, sphinx-build, sphinx-deploy-html] steps: - uses: actions/checkout@v4 @@ -144,7 +145,7 @@ jobs: import operator import json - url = "https://skore.probabl.ai" + url = os.environ["URL"] current = os.environ["CURRENT"] response = requests.get(f"{url}/versions.json") @@ -177,17 +178,19 @@ jobs: """ ) env: + URL: ${{ vars.DOCUMENTATION_URL }} CURRENT: ${{ needs.sphinx-version.outputs.SPHINX_VERSION }} - uses: ./.github/actions/sphinx/deploy with: CONFIGURATION: ${{ secrets.RCLONE_CONFIG_DOCS }} + BUCKET: ${{ vars.DOCUMENTATION_BUCKET }} ACTION: copy SOURCE: artifacts/ DESTINATION: - sphinx-clean: + sphinx-clean-artifacts: runs-on: ubuntu-latest - if: always() + if: ${{ always() && (github.event_name != 'pull_request') }} needs: [sphinx-version, sphinx-build, sphinx-deploy-html, sphinx-deploy-root-files] steps: - uses: geekyeggo/delete-artifact@v5 From b66f2c6ad0f7e82431dac0ad503700b8efb9f22e Mon Sep 17 00:00:00 2001 From: Thomas S Date: Mon, 30 Dec 2024 23:42:58 +0100 Subject: [PATCH 2/2] ci: Test based on #1027 --- skore-ui/README.md | 2 +- skore/pyproject.toml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/skore-ui/README.md b/skore-ui/README.md index 3cdba40d5..46eed7f3b 100644 --- a/skore-ui/README.md +++ b/skore-ui/README.md @@ -1,6 +1,6 @@ # Skore UI -This sub directory aims at creating a single page application supporting Skore. +This sub directory aims at creating a single page application supporting Skore! It should build as a SPA and as a library of web components. diff --git a/skore/pyproject.toml b/skore/pyproject.toml index 79d75541c..519d6d474 100644 --- a/skore/pyproject.toml +++ b/skore/pyproject.toml @@ -1,6 +1,6 @@ [project] name = "skore" -description = "The scikit-learn Modeling Companion" +description = "The scikit-learn Modeling Companion!" dynamic = ["license", "readme", "version"] requires-python = ">=3.9, <3.13" maintainers = [{ name = "skore developers", email = "skore@signal.probabl.ai" }]