test(controllers): Add missing methods for controllers #7708
  
    
      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: Run tests | |
| on: | |
| workflow_dispatch: | |
| push: | |
| branches: ["main", "rc-*"] | |
| pull_request: | |
| types: [opened, synchronize, reopened, ready_for_review] | |
| release: | |
| types: [published] | |
| schedule: | |
| - cron: "0 8 * * *" | |
| jobs: | |
| check: | |
| runs-on: ${{ matrix.os }} | |
| strategy: | |
| matrix: | |
| # "3.10" must be a string; otherwise it is interpreted as 3.1. | |
| python-version: ["3.13", "3.12", "3.11", "3.10", "3.9"] | |
| os: [ubuntu-latest, windows-latest, macOS-latest] | |
| exclude: | |
| - python-version: ${{ github.event.pull_request.draft && '3.12' }} | |
| - python-version: ${{ github.event.pull_request.draft && '3.11' }} | |
| - python-version: ${{ github.event.pull_request.draft && '3.10' }} | |
| - python-version: ${{ github.event.pull_request.draft && '3.9' }} | |
| - os: ${{ github.event.pull_request.draft && 'windows-latest' }} | |
| - os: ${{ github.event.pull_request.draft && 'macOS-latest' }} | |
| fail-fast: false | |
| steps: | |
| - uses: actions/checkout@v4 | |
| with: | |
| fetch-depth: 0 | |
| - name: Setup py-shiny | |
| id: install | |
| uses: ./.github/py-shiny/setup | |
| with: | |
| python-version: ${{ matrix.python-version }} | |
| - name: Run unit tests | |
| if: steps.install.outcome == 'success' && (success() || failure()) | |
| run: | | |
| make check-tests | |
| - name: Type check | |
| if: steps.install.outcome == 'success' && (success() || failure()) | |
| run: | | |
| make check-types | |
| - name: Lint code | |
| if: steps.install.outcome == 'success' && (success() || failure()) | |
| run: | | |
| make check-lint | |
| - name: Verify code formatting | |
| if: steps.install.outcome == 'success' && (success() || failure()) | |
| run: | | |
| make check-format | |
| - name: Verify code can run with mypy (not Windows) | |
| if: steps.install.outcome == 'success' && (success() || failure()) && matrix.os != 'windows-latest' | |
| run: | | |
| make ci-check-mypy-can-run | |
| pypi: | |
| name: "Deploy to PyPI" | |
| runs-on: ubuntu-latest | |
| if: github.event_name == 'release' | |
| needs: [check] | |
| steps: | |
| - uses: actions/checkout@v4 | |
| with: | |
| fetch-depth: 0 | |
| - name: "Set up Python 3.10" | |
| uses: actions/setup-python@v5 | |
| with: | |
| python-version: "3.10" | |
| - name: Install dependencies | |
| run: | | |
| python -m pip install --upgrade pip | |
| make install-deps | |
| make install | |
| - name: "Build Package" | |
| run: | | |
| make dist | |
| # test deploy ---- | |
| - name: "Test Deploy to PyPI" | |
| uses: pypa/gh-action-pypi-publish@release/v1 | |
| if: startsWith(github.event.release.name, 'TEST') | |
| with: | |
| user: __token__ | |
| password: ${{ secrets.PYPI_TEST_API_TOKEN }} | |
| repository-url: https://test.pypi.org/legacy/ | |
| ## prod deploy ---- | |
| - name: "Deploy to PyPI" | |
| uses: pypa/gh-action-pypi-publish@release/v1 | |
| if: startsWith(github.event.release.name, 'shiny') | |
| with: | |
| user: __token__ | |
| password: ${{ secrets.PYPI_API_TOKEN }} | |
| playwright-shiny: | |
| if: github.event_name != 'release' | |
| runs-on: ubuntu-latest | |
| strategy: | |
| matrix: | |
| python-version: ["3.13", "3.12", "3.11", "3.10", "3.9"] | |
| browser: ["chromium", "firefox", "webkit"] | |
| exclude: | |
| - python-version: ${{ github.event.pull_request.draft && '3.12' }} | |
| - python-version: ${{ github.event.pull_request.draft && '3.11' }} | |
| - python-version: ${{ github.event.pull_request.draft && '3.10' }} | |
| - python-version: ${{ github.event.pull_request.draft && '3.9' }} | |
| - browser: ${{ github.event.pull_request.draft && 'firefox' }} | |
| - browser: ${{ github.event.pull_request.draft && 'webkit' }} | |
| # There are many unexplained tests that fail on webkit w/ python 3.8, 3.9 | |
| # Given the more recent versions of python work, we will exclude this combination | |
| - browser: "webkit" | |
| python-version: "3.9" | |
| fail-fast: false | |
| steps: | |
| - uses: actions/checkout@v4 | |
| with: | |
| fetch-depth: 0 | |
| - name: Setup py-shiny | |
| uses: ./.github/py-shiny/setup | |
| with: | |
| python-version: ${{ matrix.python-version }} | |
| - name: Determine browsers for testing | |
| uses: ./.github/py-shiny/pytest-browsers | |
| id: browsers | |
| with: | |
| browser: ${{ matrix.browser }} | |
| # If anything other than `true`, it will heavily reduce webkit performance | |
| # Related: https://github.com/microsoft/playwright/issues/18119 | |
| disable-playwright-diagnostics: ${{ matrix.browser == 'webkit' || matrix.browser == 'firefox' }} | |
| - name: Run End-to-End tests | |
| timeout-minutes: 60 | |
| run: | | |
| make playwright-shiny SUB_FILE=". --numprocesses 3 ${{ steps.browsers.outputs.playwright-diagnostic-args }}" ${{ steps.browsers.outputs.browsers }} | |
| - uses: actions/upload-artifact@v4 | |
| if: failure() && steps.browsers.outputs.has-playwright-diagnostics | |
| with: | |
| name: "playright-shiny-${{ runner.os }}-${{ matrix.python-version }}-${{ matrix.browser }}-results" | |
| path: test-results/ | |
| retention-days: 5 | |
| playwright-examples: | |
| if: github.event_name != 'release' | |
| runs-on: ubuntu-latest | |
| strategy: | |
| matrix: | |
| python-version: ["3.13", "3.12", "3.11", "3.10", "3.9"] | |
| browser: ["chromium", "firefox", "webkit"] | |
| exclude: | |
| - python-version: ${{ github.event.pull_request.draft && '3.12' }} | |
| - python-version: ${{ github.event.pull_request.draft && '3.11' }} | |
| - python-version: ${{ github.event.pull_request.draft && '3.10' }} | |
| - python-version: ${{ github.event.pull_request.draft && '3.9' }} | |
| - browser: ${{ github.event.pull_request.draft && 'firefox' }} | |
| - browser: ${{ github.event.pull_request.draft && 'webkit' }} | |
| fail-fast: false | |
| steps: | |
| - uses: actions/checkout@v4 | |
| with: | |
| fetch-depth: 0 | |
| - name: Setup py-shiny | |
| uses: ./.github/py-shiny/setup | |
| with: | |
| python-version: ${{ matrix.python-version }} | |
| - name: Determine browsers for testing | |
| uses: ./.github/py-shiny/pytest-browsers | |
| id: browsers | |
| with: | |
| browser: ${{ matrix.browser }} | |
| # If anything other than `true`, it will heavily reduce webkit performance | |
| # Related: https://github.com/microsoft/playwright/issues/18119 | |
| disable-playwright-diagnostics: ${{ matrix.browser == 'webkit' || matrix.browser == 'firefox' }} | |
| - name: Install node.js | |
| uses: actions/setup-node@v4 | |
| with: | |
| cache: npm | |
| cache-dependency-path: examples/brownian/shinymediapipe/package-lock.json | |
| - name: Install node.js package | |
| working-directory: examples/brownian/shinymediapipe | |
| run: | | |
| npm ci | |
| - name: Checkout py-shiny-templates repository | |
| uses: actions/checkout@v4 | |
| with: | |
| repository: posit-dev/py-shiny-templates | |
| path: py-shiny-templates | |
| - name: Install py-shiny-templates dependencies | |
| if: matrix.python-version != '3.9' | |
| # Scikit-learn 1.7.0+ requires Python 3.10+ | |
| run: | | |
| make ci-install-py-shiny-templates-deps | |
| - name: Run example app tests | |
| timeout-minutes: 60 | |
| run: | | |
| make playwright-examples SUB_FILE=". --numprocesses 3 ${{ steps.browsers.outputs.playwright-diagnostic-args }}" ${{ steps.browsers.outputs.browsers }} | |
| - uses: actions/upload-artifact@v4 | |
| if: failure() && steps.browsers.outputs.has-playwright-diagnostics | |
| with: | |
| name: "playright-examples-${{ runner.os }}-${{ matrix.python-version }}-${{ matrix.browser }}-results" | |
| path: test-results/ | |
| retention-days: 5 | |
| playwright-ai: | |
| if: github.event_name != 'release' | |
| runs-on: ubuntu-latest | |
| strategy: | |
| matrix: | |
| python-version: ["3.13", "3.12", "3.11", "3.10", "3.9"] | |
| browser: ["chromium", "firefox", "webkit"] | |
| exclude: | |
| - python-version: ${{ github.event.pull_request.draft && '3.12' }} | |
| - python-version: ${{ github.event.pull_request.draft && '3.11' }} | |
| - python-version: ${{ github.event.pull_request.draft && '3.10' }} | |
| - python-version: ${{ github.event.pull_request.draft && '3.9' }} | |
| - browser: ${{ github.event.pull_request.draft && 'firefox' }} | |
| - browser: ${{ github.event.pull_request.draft && 'webkit' }} | |
| fail-fast: false | |
| steps: | |
| - uses: actions/checkout@v4 | |
| with: | |
| fetch-depth: 0 | |
| - name: Setup py-shiny | |
| uses: ./.github/py-shiny/setup | |
| with: | |
| python-version: ${{ matrix.python-version }} | |
| - name: Determine browsers for testing | |
| uses: ./.github/py-shiny/pytest-browsers | |
| id: browsers | |
| with: | |
| browser: ${{ matrix.browser }} | |
| # If anything other than `true`, it will heavily reduce webkit performance | |
| # Related: https://github.com/microsoft/playwright/issues/18119 | |
| disable-playwright-diagnostics: ${{ matrix.browser == 'webkit' || matrix.browser == 'firefox' }} | |
| - name: Run playwright tests for AI generated apps | |
| timeout-minutes: 60 | |
| run: | | |
| make playwright-ai SUB_FILE=". --numprocesses 3 ${{ steps.browsers.outputs.playwright-diagnostic-args }}" ${{ steps.browsers.outputs.browsers }} | |
| - uses: actions/upload-artifact@v4 | |
| if: failure() && steps.browsers.outputs.has-playwright-diagnostics | |
| with: | |
| name: "playright-ai-${{ runner.os }}-${{ matrix.python-version }}-${{ matrix.browser }}-results" | |
| path: test-results/ | |
| retention-days: 5 | |
| playwright-deploys-precheck: | |
| if: github.event_name != 'release' | |
| runs-on: ubuntu-latest | |
| strategy: | |
| matrix: | |
| # Matches deploy server python version | |
| python-version: ["3.10"] | |
| fail-fast: false | |
| steps: | |
| - uses: actions/checkout@v4 | |
| with: | |
| fetch-depth: 0 | |
| - name: Setup py-shiny | |
| uses: ./.github/py-shiny/setup | |
| with: | |
| python-version: ${{ matrix.python-version }} | |
| - name: Determine browsers for testing | |
| uses: ./.github/py-shiny/pytest-browsers | |
| id: browsers | |
| with: | |
| all-browsers: ${{ ! github.event.pull_request.draft }} | |
| - name: Test that deployable example apps work | |
| timeout-minutes: 5 # ~10s locally | |
| env: | |
| DEPLOY_APPS: "false" | |
| run: | | |
| make playwright-deploys | |
| - uses: actions/upload-artifact@v4 | |
| if: failure() | |
| with: | |
| name: "playright-examples-${{ runner.os }}-${{ matrix.python-version }}-results" | |
| path: test-results/ | |
| retention-days: 5 | |
| test-narwhals-integration: | |
| runs-on: ubuntu-latest | |
| steps: | |
| - uses: actions/checkout@v4 | |
| with: | |
| fetch-depth: 0 | |
| - name: Setup py-shiny | |
| id: install | |
| uses: ./.github/py-shiny/setup | |
| - name: Run test commands | |
| env: | |
| UV_SYSTEM_PYTHON: 1 | |
| run: | | |
| make narwhals-install-shiny | |
| make narwhals-test-integration |