Skip to content

Commit

Permalink
Use docker-coq action for running Coq
Browse files Browse the repository at this point in the history
This will hopefully make it easier to maintain moving forwards, and make
it easier to work around the native compiler issue by moving to the dev
versions of older Coq versions with
coq-community/docker-coq#49
  • Loading branch information
JasonGross committed Jul 1, 2022
1 parent ae678c9 commit 87ccbd3
Show file tree
Hide file tree
Showing 3 changed files with 85 additions and 99 deletions.
74 changes: 30 additions & 44 deletions .github/workflows/coq.yml
Original file line number Diff line number Diff line change
Expand Up @@ -15,31 +15,17 @@ jobs:
fail-fast: false
matrix:
# N.B. The update-README makefile target pulls information
# about Coq versions from this file, so be careful about
# ordering of the env and about the presence of COQ_VERSION
# immediately followed by : in this file
env:
- { COQ_VERSION: "master", COQ_PACKAGE: "coq libcoq-ocaml-dev" , PPA: "ppa:jgross-h/coq-master-daily" , TIMED: "1" }
- { COQ_VERSION: "8.15.0", COQ_PACKAGE: "coq-8.15.0 libcoq-8.15.0-ocaml-dev", PPA: "ppa:jgross-h/many-coq-versions-ocaml-4-08" , TIMED: "1" }
- { COQ_VERSION: "8.14.1", COQ_PACKAGE: "coq-8.14.1 libcoq-8.14.1-ocaml-dev", PPA: "ppa:jgross-h/many-coq-versions-ocaml-4-08" , TIMED: "1" }
- { COQ_VERSION: "8.13.2", COQ_PACKAGE: "coq-8.13.2 libcoq-8.13.2-ocaml-dev", PPA: "ppa:jgross-h/many-coq-versions-ocaml-4-05" , TIMED: "1" }
- { COQ_VERSION: "8.12.2", COQ_PACKAGE: "coq-8.12.2 libcoq-8.12.2-ocaml-dev", PPA: "ppa:jgross-h/many-coq-versions-ocaml-4-05" , TIMED: "1" }
- { COQ_VERSION: "8.11.2", COQ_PACKAGE: "coq-8.11.2 libcoq-8.11.2-ocaml-dev", PPA: "ppa:jgross-h/many-coq-versions-ocaml-4-05" , TIMED: "1" }
- { COQ_VERSION: "8.10.2", COQ_PACKAGE: "coq-8.10.2 libcoq-8.10.2-ocaml-dev", PPA: "ppa:jgross-h/many-coq-versions-ocaml-4-05" , TIMED: "1" }
- { COQ_VERSION: "8.9.1" , COQ_PACKAGE: "coq-8.9.1 libcoq-8.9.1-ocaml-dev" , PPA: "ppa:jgross-h/many-coq-versions" , TIMED: "1" }
- { COQ_VERSION: "8.8.2" , COQ_PACKAGE: "coq-8.8.2 libcoq-8.8.2-ocaml-dev" , PPA: "ppa:jgross-h/many-coq-versions" , TIMED: "1" }

env: ${{ matrix.env }}
# about Coq versions from this file, so be careful about the
# presence of COQ_VERSION immediately followed by : in this
# file and about the ordering of the list
COQ_VERSION: ["dev", "8.15", "8.14", "8.13", "8.12", "8.11", "8.10", "8.9", "8.8"]

steps:
- name: install Coq and deps
- uses: actions/checkout@v3
- name: install deps
run: |
if [ ! -z "$PPA" ]; then sudo add-apt-repository "$PPA" -y; fi
sudo apt-get -o Acquire::Retries=30 update -q
sudo apt-get -o Acquire::Retries=30 install -y --allow-unauthenticated \
ocaml-findlib \
$COQ_PACKAGE \
apt-show-versions \
texlive \
texlive-latex-extra \
texlive-bibtex-extra \
Expand All @@ -56,7 +42,6 @@ jobs:
pdf2svg \
python \
python-pygments
- uses: actions/checkout@v3
- name: echo build params
run: |
echo "::group::lscpu"
Expand All @@ -71,34 +56,35 @@ jobs:
echo "::group::etc/machine.sh"
etc/machine.sh
echo "::endgroup::"
echo "::group::ocamlc -config"
ocamlc -config
echo "::endgroup::"
echo "::group::coqc --config"
coqc --config
echo "::endgroup::"
echo "::group::coqc --version"
coqc --version
echo "::endgroup::"
echo "::group::echo | coqtop"
true | coqtop
echo "::endgroup::"
echo "::group::apt-show-versions $COQ_PACKAGE"
apt-show-versions $COQ_PACKAGE
echo "::endgroup::"
- run: make -j2 TiMED=1
- run: make perf
- run: make validate -j2
- run: sudo make install install-perf
- uses: coq-community/docker-coq-action@v1
with:
coq_version: ${{ matrix.COQ_VERSION }}
ocaml_version: default
custom_script: |
sudo chmod -R a+rw .
echo '::group::make -j2 TIMED=1'
make -j2 TIMED=1
echo '::endgroup::'
echo '::group::make perf TIMED=1'
make perf TIMED=1
echo '::endgroup::'
echo '::group::make validate -j2'
make validate -j2
echo '::endgroup::'
echo '::group::sudo make install install-perf'
sudo make install install-perf
echo '::endgroup::'
echo '::group::make copy-perf OUTPUT="doc-build/${{ matrix.COQ_VERSION }}"'
make copy-perf OUTPUT="doc-build/${{ matrix.COQ_VERSION }}"
echo '::endgroup::'
- run: make pdf
- run: make doc
- run: make copy-pdf copy-doc copy-perf OUTPUT="doc-build/${COQ_VERSION}"
- run: apt-show-versions $COQ_PACKAGE > doc-build/${COQ_VERSION}/.apt-show-versions
- run: make copy-pdf copy-doc OUTPUT="doc-build/${{ matrix.COQ_VERSION }}"
- name: Upload artifact
uses: actions/upload-artifact@v2
with:
name: ${{ matrix.env.COQ_VERSION }}
path: doc-build/${{ matrix.env.COQ_VERSION }}
name: ${{ matrix.COQ_VERSION }}
path: doc-build/${{ matrix.COQ_VERSION }}

deploy:

Expand Down
2 changes: 1 addition & 1 deletion PerformanceExperiments/gen-listing.sh
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ stems="$@"
stems="$(echo "$stems" | tr ' ' '\n' | sed 's/\.v$//g' | tr '\n' ' ')"
extra_bar=""
extra_bar_space=""
coq_versions="$(grep -o 'COQ_VERSION:\s*[^, ]*' .github/workflows/coq.yml | sed 's/COQ_VERSION://g; s/[ "]//g')"
coq_versions="$(grep -o 'COQ_VERSION:.*$' .github/workflows/coq.yml | sed 's/COQ_VERSION://g; s/\[//g; s/\]//g; s/[ "'"'"']//g; s/,/ /g')"
for stem in $stems; do
stem_dash="$(echo "$stem" | sed 's,[_/],-,g')"
echo
Expand Down
Loading

0 comments on commit 87ccbd3

Please sign in to comment.