Skip to content

Commit

Permalink
update workflow
Browse files Browse the repository at this point in the history
  • Loading branch information
ailrst committed Feb 1, 2024
1 parent c31cac6 commit d1564ba
Show file tree
Hide file tree
Showing 5 changed files with 245 additions and 9 deletions.
27 changes: 20 additions & 7 deletions .github/workflows/run-examples.yml
Original file line number Diff line number Diff line change
Expand Up @@ -8,12 +8,12 @@ on:
- main
workflow_dispatch:
jobs:
test:
CompileAndTest:
runs-on: ubuntu-latest
timeout-minutes: 10
container:
# Requires repo to have action access in package settings
image: ghcr.io/uq-pac/basil-nix-dev:latest
image: ghcr.io/uq-pac/basil-dev:latest
credentials:
username: ${{ github.actor }}
password: ${{ secrets.github_token }}
Expand All @@ -22,17 +22,30 @@ jobs:
uses: actions/checkout@v4

- name: Compile BASIL
run: ./mill compile
run: ./scripts/mill compile

- name: Bitvec Tests
run: ./mill test.testOnly BitVectorAnalysisTests
run: ./scripts/mill test.testOnly BitVectorAnalysisTests

- name: IntrusiveListTest
run: ./mill test.testOnly SystemTests IntrusiveListPublicInterfaceTests
run: ./scripts/mill test.testOnly IntrusiveListPublicInterfaceTests

- name: System Tests
run: ./mill test.testOnly *SystemTests -- -z basic_assign_increment/gcc_no_plt_no_pic -z basic_assign_increment/clang_no_plt_no_pic -z secret_write/gcc_no_plt_no_pic

run: ./scripts/mill test.testOnly *SystemTests -- -z basic_assign_increment/gcc_no_plt_no_pic -z basic_assign_increment/clang_no_plt_no_pic -z secret_write/gcc_no_plt_no_pic

SystemTests:
runs-on: ubuntu-latest
timeout-minutes: 10
container:
# Requires repo to have action access in package settings
image: ghcr.io/uq-pac/basil-dev:latest
credentials:
username: ${{ github.actor }}
password: ${{ secrets.github_token }}
steps:
- name: Checkout
uses: actions/checkout@v4

- name: System Tests
run: ./scripts/mill test.testOnly SystemTests || true && cat src/test/summary.csv >> "$GITHUB_OUTPUT" && echo "" >> "$GITHUB_OUTPUT" && src/test/testResults.csv >> "$GITHUB_OUTPUT"

2 changes: 1 addition & 1 deletion docker/asli.Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -115,7 +115,7 @@ USER root
FROM docker.io/ubuntu:23.04 AS scala
ENV PATH="$PATH:/root/.local/share/coursier/bin"
RUN apt-get update && apt-get install default-jre-headless curl git --yes \
&& curl -fL https://github.com/coursier/coursier/releases/latest/download/cs-x86_64-pc-linux.gz | gzip -d > cs && chmod +x cs && ./cs setup --yes \
&& curl -fL https://github.com/coursier/coursier/releases/latest/download/cs-x86_64-pc-linux.gz | gzip -d > cs && chmod +x cs && ./cs setup --yes && cs install mill \
&& apt-get autoremove --purge -y \
&& apt-get autoclean -y

Expand Down
5 changes: 4 additions & 1 deletion docker/nixdocker.Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -6,4 +6,7 @@ RUN nix profile install --impure 'github:katrinafyi/pac-nix#aslp'
RUN nix profile install --impure 'github:katrinafyi/pac-nix#bap-aslp'
RUN nix profile install --impure 'nixpkgs#boogie'
RUN nix profile install --impure 'nixpkgs#openjdk'
RUN nix profile install --impure 'nixpkgs#coursier' && cs setup --yes && cs install mill --yes
RUN nix profile install --impure 'nixpkgs#coursier' && cs setup --yes
RUN cs install mill
ENV PATH=$PATH:/root/.local/share/coursier/bin

File renamed without changes.
220 changes: 220 additions & 0 deletions scripts/mill.bat
Original file line number Diff line number Diff line change
@@ -0,0 +1,220 @@
@echo off

rem This is a wrapper script, that automatically download mill from GitHub release pages
rem You can give the required mill version with --mill-version parameter
rem If no version is given, it falls back to the value of DEFAULT_MILL_VERSION
rem
rem Project page: https://github.com/lefou/millw
rem Script Version: 0.4.11
rem
rem If you want to improve this script, please also contribute your changes back!
rem
rem Licensed under the Apache License, Version 2.0

rem setlocal seems to be unavailable on Windows 95/98/ME
rem but I don't think we need to support them in 2019
setlocal enabledelayedexpansion

if [!DEFAULT_MILL_VERSION!]==[] (
set "DEFAULT_MILL_VERSION=0.11.4"
)

if [!GITHUB_RELEASE_CDN!]==[] (
set "GITHUB_RELEASE_CDN="
)

if [!MILL_MAIN_CLI!]==[] (
set "MILL_MAIN_CLI=%~f0"
)

set "MILL_REPO_URL=https://github.com/com-lihaoyi/mill"

rem %~1% removes surrounding quotes
if [%~1%]==[--mill-version] (
if not [%~2%]==[] (
set MILL_VERSION=%~2%
rem shift command doesn't work within parentheses
set "STRIP_VERSION_PARAMS=true"
) else (
echo You specified --mill-version without a version. 1>&2
echo Please provide a version that matches one provided on 1>&2
echo %MILL_REPO_URL%/releases 1>&2
exit /b 1
)
)

if not defined STRIP_VERSION_PARAMS GOTO AfterStripVersionParams
rem strip the: --mill-version {version}
shift
shift
:AfterStripVersionParams

if [!MILL_VERSION!]==[] (
if exist .mill-version (
set /p MILL_VERSION=<.mill-version
) else (
if exist .config\mill-version (
set /p MILL_VERSION=<.config\mill-version
)
)
)

if [!MILL_VERSION!]==[] (
set MILL_VERSION=%DEFAULT_MILL_VERSION%
)

if [!MILL_DOWNLOAD_PATH!]==[] (
set MILL_DOWNLOAD_PATH=%USERPROFILE%\.mill\download
)

rem without bat file extension, cmd doesn't seem to be able to run it
set MILL=%MILL_DOWNLOAD_PATH%\!MILL_VERSION!.bat

if not exist "%MILL%" (
set VERSION_PREFIX=%MILL_VERSION:~0,4%
# Since 0.5.0
set DOWNLOAD_SUFFIX=-assembly
# Since 0.11.0
set DOWNLOAD_FROM_MAVEN=1
if [!VERSION_PREFIX!]==[0.0.] (
set DOWNLOAD_SUFFIX=
set DOWNLOAD_FROM_MAVEN=0
)
if [!VERSION_PREFIX!]==[0.1.] (
set DOWNLOAD_SUFFIX=
set DOWNLOAD_FROM_MAVEN=0
)
if [!VERSION_PREFIX!]==[0.2.] (
set DOWNLOAD_SUFFIX=
set DOWNLOAD_FROM_MAVEN=0
)
if [!VERSION_PREFIX!]==[0.3.] (
set DOWNLOAD_SUFFIX=
set DOWNLOAD_FROM_MAVEN=0
)
if [!VERSION_PREFIX!]==[0.4.] (
set DOWNLOAD_SUFFIX=
set DOWNLOAD_FROM_MAVEN=0
)
if [!VERSION_PREFIX!]==[0.5.] (
set DOWNLOAD_FROM_MAVEN=0
)
if [!VERSION_PREFIX!]==[0.6.] (
set DOWNLOAD_FROM_MAVEN=0
)
if [!VERSION_PREFIX!]==[0.7.] (
set DOWNLOAD_FROM_MAVEN=0
)
if [!VERSION_PREFIX!]==[0.8.] (
set DOWNLOAD_FROM_MAVEN=0
)
if [!VERSION_PREFIX!]==[0.9.] (
set DOWNLOAD_FROM_MAVEN=0
)
set VERSION_PREFIX=%MILL_VERSION:~0,5%
if [!VERSION_PREFIX!]==[0.10.] (
set DOWNLOAD_FROM_MAVEN=0
)
set VERSION_PREFIX=%MILL_VERSION:~0,8%
if [!VERSION_PREFIX!]==[0.11.0-M] (
set DOWNLOAD_FROM_MAVEN=0
)
set VERSION_PREFIX=

for /F "delims=- tokens=1" %%A in ("!MILL_VERSION!") do set MILL_VERSION_BASE=%%A
for /F "delims=- tokens=2" %%A in ("!MILL_VERSION!") do set MILL_VERSION_MILESTONE=%%A
set VERSION_MILESTONE_START=!MILL_VERSION_MILESTONE:~0,1!
if [!VERSION_MILESTONE_START!]==[M] (
set MILL_VERSION_TAG="!MILL_VERSION_BASE!-!MILL_VERSION_MILESTONE!"
) else (
set MILL_VERSION_TAG=!MILL_VERSION_BASE!
)

rem there seems to be no way to generate a unique temporary file path (on native Windows)
set DOWNLOAD_FILE=%MILL%.tmp

if [!DOWNLOAD_FROM_MAVEN!]==[1] (
set DOWNLOAD_URL=https://repo1.maven.org/maven2/com/lihaoyi/mill-dist/!MILL_VERSION!/mill-dist-!MILL_VERSION!.jar
) else (
set DOWNLOAD_URL=!GITHUB_RELEASE_CDN!%MILL_REPO_URL%/releases/download/!MILL_VERSION_TAG!/!MILL_VERSION!!DOWNLOAD_SUFFIX!
)

echo Downloading mill %MILL_VERSION% from !DOWNLOAD_URL! ... 1>&2

if not exist "%MILL_DOWNLOAD_PATH%" mkdir "%MILL_DOWNLOAD_PATH%"
rem curl is bundled with recent Windows 10
rem but I don't think we can expect all the users to have it in 2019
where /Q curl
if %ERRORLEVEL% EQU 0 (
curl -f -L "!DOWNLOAD_URL!" -o "!DOWNLOAD_FILE!"
) else (
rem bitsadmin seems to be available on Windows 7
rem without /dynamic, github returns 403
rem bitsadmin is sometimes needlessly slow but it looks better with /priority foreground
bitsadmin /transfer millDownloadJob /dynamic /priority foreground "!DOWNLOAD_URL!" "!DOWNLOAD_FILE!"
)
if not exist "!DOWNLOAD_FILE!" (
echo Could not download mill %MILL_VERSION% 1>&2
exit /b 1
)

move /y "!DOWNLOAD_FILE!" "%MILL%"

set DOWNLOAD_FILE=
set DOWNLOAD_SUFFIX=
)

set MILL_DOWNLOAD_PATH=
set MILL_VERSION=
set MILL_REPO_URL=

rem Need to preserve the first position of those listed options
set MILL_FIRST_ARG=
if [%~1%]==[--bsp] (
set MILL_FIRST_ARG=%1%
) else (
if [%~1%]==[-i] (
set MILL_FIRST_ARG=%1%
) else (
if [%~1%]==[--interactive] (
set MILL_FIRST_ARG=%1%
) else (
if [%~1%]==[--no-server] (
set MILL_FIRST_ARG=%1%
) else (
if [%~1%]==[--repl] (
set MILL_FIRST_ARG=%1%
) else (
if [%~1%]==[--help] (
set MILL_FIRST_ARG=%1%
)
)
)
)
)
)

set "MILL_PARAMS=%*%"

if not [!MILL_FIRST_ARG!]==[] (
if defined STRIP_VERSION_PARAMS (
for /f "tokens=1-3*" %%a in ("%*") do (
set "MILL_PARAMS=%%d"
)
) else (
for /f "tokens=1*" %%a in ("%*") do (
set "MILL_PARAMS=%%b"
)
)
) else (
if defined STRIP_VERSION_PARAMS (
for /f "tokens=1-2*" %%a in ("%*") do (
rem strip %%a - It's the "--mill-version" option.
rem strip %%b - it's the version number that comes after the option.
rem keep %%c - It's the remaining options.
set "MILL_PARAMS=%%c"
)
)
)

"%MILL%" %MILL_FIRST_ARG% -D "mill.main.cli=%MILL_MAIN_CLI%" %MILL_PARAMS%

0 comments on commit d1564ba

Please sign in to comment.