Decouple the session loader into reader and writer over the cache #12320
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: Testing | |
| defaults: | |
| run: | |
| shell: bash | |
| # See: https://docs.github.com/en/actions/reference/workflow-syntax-for-github-actions#concurrency. | |
| concurrency: | |
| group: ${{ github.head_ref }}-${{ github.workflow }} | |
| cancel-in-progress: true | |
| on: | |
| pull_request: | |
| branches: | |
| - '**' | |
| jobs: | |
| pre_job: | |
| runs-on: ubuntu-latest | |
| outputs: | |
| should_skip: ${{ steps.skip_check.outputs.should_skip }} | |
| should_skip_ghcide: ${{ steps.skip_ghcide_check.outputs.should_skip }} | |
| ghcs: ${{ steps.ghcs.outputs.ghcs }} | |
| steps: | |
| # Need the repo checked out in order to read the file | |
| - uses: actions/checkout@v3 | |
| - id: ghcs | |
| run: echo "ghcs=$(cat ./.github/workflows/supported-ghc-versions.json)" >> $GITHUB_OUTPUT | |
| - id: skip_check | |
| uses: fkirc/[email protected] | |
| with: | |
| cancel_others: false | |
| paths_ignore: '[ "**/docs/**" | |
| , "**.md" | |
| , "**/LICENSE" | |
| , "**.nix" | |
| , "flake.lock" | |
| , "**/README.md" | |
| , "FUNDING.yml" | |
| , ".circleci/**" | |
| , "**/stack*.yaml" | |
| , ".gitlab-ci.yaml" | |
| , ".gitlab/**" | |
| , "CODEOWNERS" | |
| ]' | |
| # If we only change ghcide downstream packages we have not test ghcide itself | |
| - id: skip_ghcide_check | |
| uses: fkirc/[email protected] | |
| with: | |
| cancel_others: false | |
| paths_ignore: '[ "hls-test-utils/**" | |
| , "plugins/**" | |
| , "src/**" | |
| , "exe/**" | |
| , "test/**" | |
| , "shake-bench/**" | |
| ]' | |
| test: | |
| if: needs.pre_job.outputs.should_skip != 'true' | |
| needs: | |
| - pre_job | |
| runs-on: ${{ matrix.os }} | |
| strategy: | |
| # We don't want to fail fast. | |
| # We used to fail fast, to avoid caches of failing PRs to overpopulate the CI | |
| # caches, evicting known good build caches. | |
| # However, PRs do not cache anything any more, and can only use the caches from current master. | |
| # See 'caching.yml' for our caching set up. | |
| fail-fast: false | |
| matrix: | |
| ghc: ${{ fromJSON(needs.pre_job.outputs.ghcs) }} | |
| os: | |
| - ubuntu-latest | |
| - macOS-latest | |
| - windows-latest | |
| test: | |
| - true | |
| - false | |
| exclude: | |
| # Exclude the test configuration on macos, it's sufficiently similar to other OSs | |
| # that it mostly just burns CI time. Buiding is still useful since it catches | |
| # solver issues. | |
| - os: macOS-latest | |
| test: true | |
| # Exclude the build-only configurations for windows and ubuntu | |
| - os: windows-latest | |
| test: false | |
| - os: ubuntu-latest | |
| test: false | |
| steps: | |
| - uses: actions/checkout@v3 | |
| - uses: ./.github/actions/setup-build | |
| with: | |
| ghc: ${{ matrix.ghc }} | |
| os: ${{ runner.os }} | |
| - name: Build | |
| run: cabal build all | |
| - name: Set test options | |
| # See https://github.com/ocharles/tasty-rerun/issues/22 for why we need | |
| # to include 'new' in the filters, since many of our test suites are in the | |
| # same package. | |
| run: | | |
| cabal configure --test-options="--rerun-update --rerun-filter failures,exceptions,new" | |
| - if: matrix.test | |
| name: Test hls-graph | |
| run: cabal test hls-graph | |
| - if: needs.pre_job.outputs.should_skip_ghcide != 'true' && matrix.test | |
| name: Test ghcide | |
| # run the tests without parallelism to avoid running out of memory | |
| run: cabal test ghcide-tests || cabal test ghcide-tests | |
| - if: matrix.test | |
| name: Test hls-plugin-api | |
| run: cabal test hls-plugin-api || cabal test hls-plugin-api | |
| - if: matrix.test | |
| name: Test func-test suite | |
| env: | |
| HLS_TEST_EXE: hls | |
| HLS_WRAPPER_TEST_EXE: hls-wrapper | |
| run: cabal test func-test || cabal test func-test | |
| - if: matrix.test | |
| name: Test wrapper-test suite | |
| env: | |
| HLS_TEST_EXE: hls | |
| HLS_WRAPPER_TEST_EXE: hls-wrapper | |
| run: cabal test wrapper-test | |
| - if: matrix.test | |
| name: Test hls-refactor-plugin | |
| run: cabal test hls-refactor-plugin-tests || cabal test hls-refactor-plugin-tests | |
| # TODO enable when it supports 9.10 | |
| - if: matrix.test && matrix.ghc != '9.10' && matrix.ghc != '9.12' | |
| name: Test hls-floskell-plugin | |
| run: cabal test hls-floskell-plugin-tests || cabal test hls-floskell-plugin-tests | |
| - if: matrix.test | |
| name: Test hls-class-plugin | |
| run: cabal test hls-class-plugin-tests || cabal test hls-class-plugin-tests | |
| - if: matrix.test | |
| name: Test hls-pragmas-plugin | |
| run: cabal test hls-pragmas-plugin-tests || cabal test hls-pragmas-plugin-tests | |
| - if: matrix.test | |
| name: Test hls-eval-plugin | |
| run: cabal test hls-eval-plugin-tests || cabal test hls-eval-plugin-tests | |
| # TODO enable when it supports 9.10 | |
| - if: matrix.test && matrix.ghc != '9.10' && matrix.ghc != '9.12' | |
| name: Test hls-splice-plugin | |
| run: cabal test hls-splice-plugin-tests || cabal test hls-splice-plugin-tests | |
| - if: matrix.test && matrix.ghc != '9.12' | |
| name: Test hls-stan-plugin | |
| run: cabal test hls-stan-plugin-tests || cabal test hls-stan-plugin-tests | |
| - if: matrix.test | |
| name: Test hls-stylish-haskell-plugin | |
| run: cabal test hls-stylish-haskell-plugin-tests || cabal test hls-stylish-haskell-plugin-tests | |
| - if: matrix.test | |
| name: Test hls-ormolu-plugin | |
| run: cabal test hls-ormolu-plugin-tests || cabal test hls-ormolu-plugin-tests | |
| - if: matrix.test | |
| name: Test hls-fourmolu-plugin | |
| run: cabal test hls-fourmolu-plugin-tests || cabal test hls-fourmolu-plugin-tests | |
| - if: matrix.test | |
| name: Test hls-explicit-imports-plugin test suite | |
| run: cabal test hls-explicit-imports-plugin-tests || cabal test hls-explicit-imports-plugin-tests | |
| - if: matrix.test | |
| name: Test hls-call-hierarchy-plugin test suite | |
| run: cabal test hls-call-hierarchy-plugin-tests || cabal test hls-call-hierarchy-plugin-tests | |
| - if: matrix.test && matrix.os != 'windows-latest' | |
| name: Test hls-rename-plugin test suite | |
| run: cabal test hls-rename-plugin-tests || cabal test hls-rename-plugin-tests | |
| # TODO enable when it supports 9.10 | |
| - if: matrix.test && matrix.ghc != '9.10' | |
| name: Test hls-hlint-plugin test suite | |
| run: cabal test hls-hlint-plugin-tests || cabal test hls-hlint-plugin-tests | |
| - if: matrix.test | |
| name: Test hls-module-name-plugin test suite | |
| run: cabal test hls-module-name-plugin-tests || cabal test hls-module-name-plugin-tests | |
| - if: matrix.test | |
| name: Test hls-alternate-number-format-plugin test suite | |
| run: cabal test hls-alternate-number-format-plugin-tests || cabal test hls-alternate-number-format-plugin-tests | |
| - if: matrix.test | |
| name: Test hls-qualify-imported-names-plugin test suite | |
| run: cabal test hls-qualify-imported-names-plugin-tests || cabal test hls-qualify-imported-names-plugin-tests | |
| - if: matrix.test | |
| name: Test hls-code-range-plugin test suite | |
| run: cabal test hls-code-range-plugin-tests || cabal test hls-code-range-plugin-tests | |
| - if: matrix.test | |
| name: Test hls-change-type-signature test suite | |
| run: cabal test hls-change-type-signature-plugin-tests || cabal test hls-change-type-signature-plugin-tests | |
| - if: matrix.test | |
| name: Test hls-gadt-plugin test suit | |
| run: cabal test hls-gadt-plugin-tests || cabal test hls-gadt-plugin-tests | |
| - if: matrix.test | |
| name: Test hls-explicit-fixity-plugin test suite | |
| run: cabal test hls-explicit-fixity-plugin-tests || cabal test hls-explicit-fixity-plugin-tests | |
| - if: matrix.test | |
| name: Test hls-explicit-record-fields-plugin test suite | |
| run: cabal test hls-explicit-record-fields-plugin-tests || cabal test hls-explicit-record-fields-plugin-tests | |
| # versions need to be limited since the tests depend on cabal-fmt which only builds with ghc <9.10 | |
| - if: matrix.test && matrix.ghc != '9.10' && matrix.ghc != '9.12' | |
| name: Test hls-cabal-fmt-plugin test suite | |
| run: cabal test hls-cabal-fmt-plugin-tests --flag=isolateCabalfmtTests || cabal test hls-cabal-fmt-plugin-tests --flag=isolateCabalfmtTests | |
| - if: matrix.test && matrix.ghc != '9.12' | |
| name: Test hls-cabal-gild-plugin test suite | |
| run: cabal test hls-cabal-gild-plugin-tests --flag=isolateCabalGildTests || cabal test hls-cabal-gild-plugin-tests --flag=isolateCabalGildTests | |
| - if: matrix.test | |
| name: Test hls-cabal-plugin test suite | |
| run: cabal test hls-cabal-plugin-tests || cabal test hls-cabal-plugin-tests | |
| # TODO enable when it supports 9.10 | |
| - if: matrix.test && matrix.ghc != '9.10' && matrix.ghc != '9.12' | |
| name: Test hls-retrie-plugin test suite | |
| run: cabal test hls-retrie-plugin-tests || cabal test hls-retrie-plugin-tests | |
| - if: matrix.test | |
| name: Test hls-overloaded-record-dot-plugin test suite | |
| run: cabal test hls-overloaded-record-dot-plugin-tests || cabal test hls-overloaded-record-dot-plugin-tests | |
| - if: matrix.test | |
| name: Test hls-semantic-tokens-plugin test suite | |
| run: cabal test hls-semantic-tokens-plugin-tests || cabal test hls-semantic-tokens-plugin-tests | |
| - if: matrix.test | |
| name: Test hls-notes-plugin test suite | |
| run: cabal test hls-notes-plugin-tests || cabal test hls-notes-plugin-tests | |
| # The plugin tutorial is only compatible with 9.6 and 9.8. | |
| # No particular reason, just to avoid excessive CPP. | |
| - if: matrix.test && matrix.ghc != '9.4' && matrix.ghc != '9.10' && matrix.ghc != '9.12' | |
| name: Compile the plugin-tutorial | |
| run: cabal build plugin-tutorial | |
| test_post_job: | |
| if: always() | |
| runs-on: ubuntu-latest | |
| needs: [pre_job, test] | |
| steps: | |
| - run: | | |
| echo "jobs info: ${{ toJSON(needs) }}" | |
| - if: contains(needs.*.result, 'failure') | |
| run: exit 1 | |
| - if: contains(needs.*.result, 'cancelled') && needs.pre_job.outputs.should_skip != 'true' | |
| run: exit 1 |