Skip to content

Commit

Permalink
ci: use switch-based installation/build process for server
Browse files Browse the repository at this point in the history
  • Loading branch information
samcowger committed Nov 12, 2024
1 parent 9688218 commit febc36d
Showing 1 changed file with 17 additions and 15 deletions.
32 changes: 17 additions & 15 deletions .github/workflows/server-ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -31,34 +31,36 @@ jobs:
with:
ocaml-compiler: ${{ matrix.ocaml-version }}

- name: Link lockfile
working-directory: cn-lsp/server
run: ln -s cnlsp.opam.locked-${{ matrix.ocaml-version }} cnlsp.opam.locked

- name: Restore `_opam`
id: cache-opam-restore
uses: actions/cache/restore@v4
with:
path: _opam
key: ${{ matrix.ocaml-version }}
path: cn-lsp/server/_opam
key: ${{ matrix.ocaml-version }}-${{ hashFiles('cn-lsp/server/cnlsp.opam.locked') }}

- name: Install server dependencies
working-directory: ./cn-lsp/server
run: |
eval $(opam env)
opam install . --deps-only --locked -y
working-directory: cn-lsp/server
# If we restored a `_opam` directory here, we need not (and should not)
# try to create a switch. The presence of `_opam` seems basically
# isomorphic to the presence of a switch, and opam will fail to `create`
# a new switch if one is already present.
run: ls _opam || opam switch create . ocaml.${{ matrix.ocaml-version }} --deps-only --locked -y

- name: Cache `_opam`
if: steps.cache-opam-restore.outputs.cache-hit != 'true'
uses: actions/cache/save@v4
with:
path: _opam
path: cn-lsp/server/_opam
key: ${{ steps.cache-opam-restore.outputs.cache-primary-key }}

- name: Build server
working-directory: ./cn-lsp/server
run: |
eval $(opam env)
dune build
working-directory: cn-lsp/server
run: eval $(opam env) && dune build

- name: Run server tests
working-directory: ./cn-lsp/server
run: |
eval $(opam env)
dune test
working-directory: cn-lsp/server
run: eval $(opam env) && dune test

0 comments on commit febc36d

Please sign in to comment.