diff --git a/.github/workflows/nightly.yml b/.github/workflows/nightly.yml index 6af0189..30c80bb 100644 --- a/.github/workflows/nightly.yml +++ b/.github/workflows/nightly.yml @@ -2,42 +2,143 @@ on: schedule: - cron: '0 0 * * *' workflow_dispatch: + inputs: + hax: + description: "Hax" + type: "string" + default: "main" + charon: + description: "Charon" + type: "string" + default: "main" + eurydice: + description: "Eurydice" + type: "string" + default: "main" + libcrux: + description: "Libcrux" + type: "string" + default: "main" + bertie: + description: "Bertie" + type: "string" + default: "main" + push: + branches-ignore: + - main + +# Cancel previous versions of this job that are still running. +concurrency: + group: nightly + cancel-in-progress: true jobs: - nightly: + update-flake: runs-on: [self-hosted, linux, nix] steps: - name: checkout uses: actions/checkout@v4 - name: update + env: + HAX_BRANCH: ${{ inputs.hax }} + CHARON_BRANCH: ${{ inputs.charon }} + EURYDICE_BRANCH: ${{ inputs.eurydice }} + LIBCRUX_BRANCH: ${{ inputs.libcrux }} + BERTIE_BRANCH: ${{ inputs.bertie }} run: ./update.sh + # Commit the update onto a new branch - name: commit run: | [[ $(git diff) != "" ]] || exit 0 git config --local user.name "Prosecco" git config --local user.email "prosecco@inria.fr" + git checkout -b nightly git commit -am "nightly update" + git push origin --force nightly:nightly + + # This would be nicer as a matrix, but that hits limits of what github actions can currenctly express. See e.g.: + # - https://github.com/orgs/community/discussions/17245 + # - https://github.com/orgs/community/discussions/26640 + # - https://github.com/actions/runner/pull/2477 + hax: + needs: update-flake + runs-on: [self-hosted, linux, nix] + steps: + - name: checkout + uses: actions/checkout@v4 + with: + ref: nightly + - run: nix build -L --no-link ".#hax" + + charon: + needs: update-flake + runs-on: [self-hosted, linux, nix] + steps: + - name: checkout + uses: actions/checkout@v4 + with: + ref: nightly + - run: nix build -L --no-link ".#charon" + + eurydice: + needs: update-flake + runs-on: [self-hosted, linux, nix] + steps: + - name: checkout + uses: actions/checkout@v4 + with: + ref: nightly + - run: nix build -L --no-link ".#eurydice" - - name: push - uses: ad-m/github-push-action@master + ml-kem: + needs: update-flake + runs-on: [self-hosted, linux, nix] + steps: + - name: checkout with: - branch: main + ref: nightly + uses: actions/checkout@v4 + - run: nix build -L --no-link ".#ml-kem" + + bertie: + needs: update-flake + runs-on: [self-hosted, linux, nix] + steps: + - name: checkout + with: + ref: nightly + uses: actions/checkout@v4 + - run: nix build -L --no-link ".#bertie" + + message_zulip: + needs: [hax, charon, eurydice, ml-kem, bertie] + runs-on: [self-hosted, linux, nix] + if: ${{ success() || failure() }} # Will always run unless canceled + steps: + - name: checkout + uses: actions/checkout@v4 + with: + ref: nightly + fetch-depth: 0 # deep clone in order to get access to other commits - name: generate zulip message + env: + RUN: ${{ github.run_id }} + RESULTS: ${{ toJSON(needs) }} run: | + echo "$RESULTS" > results.json + nix shell nixpkgs#jq --command ./message.sh | tee message.txt { echo 'MSG<> "$GITHUB_ENV" - env: - RUN: ${{ github.run_id }} - name: send zulip info message uses: slackapi/slack-github-action@v1.25.0 + if: ${{ github.event_name == 'schedule' || github.event_name == 'workflow_dispatch' }} with: payload: | { "text": ${{ toJSON(env.MSG) }} } @@ -45,10 +146,23 @@ jobs: SLACK_WEBHOOK_URL: ${{ secrets.ZULIP_WEBHOOK_URL }} - name: send zulip error message - if: ${{ failure() }} + if: ${{ failure() && (github.event_name == 'schedule' || github.event_name == 'workflow_dispatch') }} uses: slackapi/slack-github-action@v1.25.0 with: payload: | { "text": "Unexpected Error: ${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}" } env: SLACK_WEBHOOK_URL: ${{ secrets.ZULIP_WEBHOOK_URL }} + + push_to_main: + needs: [hax, charon, eurydice, ml-kem, bertie, message_zulip] + runs-on: [self-hosted, linux, nix] + if: ${{ github.event_name == 'schedule' || github.event_name == 'workflow_dispatch' }} + steps: + - name: checkout + uses: actions/checkout@v4 + with: + ref: nightly + + - name: push to main + run: git push origin HEAD:main diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml deleted file mode 100644 index 86c9f75..0000000 --- a/.github/workflows/test.yml +++ /dev/null @@ -1,67 +0,0 @@ -on: - workflow_dispatch: - inputs: - hax: - description: "Hax" - type: "string" - default: "main" - charon: - description: "Charon" - type: "string" - default: "main" - eurydice: - description: "Eurydice" - type: "string" - default: "main" - libcrux: - description: "Libcrux" - type: "string" - default: "main" - bertie: - description: "Bertie" - type: "string" - default: "main" - -jobs: - test: - runs-on: [self-hosted, linux, nix] - steps: - - name: checkout - uses: actions/checkout@v4 - - - name: update - run: ./update.sh - env: - HAX_BRANCH: ${{ inputs.hax }} - CHARON_BRANCH: ${{ inputs.charon }} - EURYDICE_BRANCH: ${{ inputs.eurydice }} - LIBCRUX_BRANCH: ${{ inputs.libcrux }} - BERTIE_BRANCH: ${{ inputs.bertie }} - - - name: generate zulip message - run: | - { - echo 'MSG<> "$GITHUB_ENV" - env: - RUN: ${{ github.run_id }} - - - name: send zulip info message - uses: slackapi/slack-github-action@v1.25.0 - with: - payload: | - { "text": ${{ toJSON(env.MSG) }} } - env: - SLACK_WEBHOOK_URL: ${{ secrets.ZULIP_WEBHOOK_URL }} - - - name: send zulip error message - if: ${{ failure() }} - uses: slackapi/slack-github-action@v1.25.0 - with: - payload: | - { "text": "Unexpected Error: ${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}" } - env: - SLACK_WEBHOOK_URL: ${{ secrets.ZULIP_WEBHOOK_URL }} diff --git a/STATUS.txt b/STATUS.txt deleted file mode 100644 index e83c9e8..0000000 --- a/STATUS.txt +++ /dev/null @@ -1,5 +0,0 @@ -✅ hax (main) -✅ charon (main) -✅ eurydice (main) -✅ ml-kem (main) -✅ bertie (main) diff --git a/good.lock b/good.lock deleted file mode 100644 index 4b7d212..0000000 --- a/good.lock +++ /dev/null @@ -1,753 +0,0 @@ -{ - "nodes": { - "bertie": { - "inputs": { - "crane": "crane", - "flake-utils": "flake-utils", - "hax": [ - "hax" - ], - "nixpkgs": "nixpkgs" - }, - "locked": { - "lastModified": 1719997219, - "narHash": "sha256-PfGKfH5AoJ3ctAZwHICVbWalS+9FxDVb8EEcD9j+/Ss=", - "owner": "cryspen", - "repo": "bertie", - "rev": "b5775ee9f2d58cd2180b4ee32937abb9103f4087", - "type": "github" - }, - "original": { - "owner": "cryspen", - "repo": "bertie", - "type": "github" - } - }, - "charon": { - "inputs": { - "crane": "crane_2", - "flake-compat": "flake-compat", - "flake-utils": "flake-utils_2", - "nixpkgs": [ - "eurydice", - "nixpkgs" - ], - "rust-overlay": "rust-overlay" - }, - "locked": { - "lastModified": 1731500951, - "narHash": "sha256-bITTJFxjrq6XfBNUnqFn15f7V6+ypILm2BTu2cxd+iI=", - "owner": "aeneasverif", - "repo": "charon", - "rev": "454078ebdb4a607e2b21dc115e1ca99b516e436f", - "type": "github" - }, - "original": { - "owner": "aeneasverif", - "repo": "charon", - "type": "github" - } - }, - "crane": { - "inputs": { - "nixpkgs": [ - "bertie", - "nixpkgs" - ] - }, - "locked": { - "lastModified": 1717386774, - "narHash": "sha256-YYMGHDo4f+tu7k2q6hWNiI5C8gAN5eksb3g3EbKFf4k=", - "owner": "ipetkov", - "repo": "crane", - "rev": "ad21f86e47a2751faa99aecd0d494be70411d5e9", - "type": "github" - }, - "original": { - "owner": "ipetkov", - "repo": "crane", - "type": "github" - } - }, - "crane_2": { - "locked": { - "lastModified": 1727316705, - "narHash": "sha256-/mumx8AQ5xFuCJqxCIOFCHTVlxHkMT21idpbgbm/TIE=", - "owner": "ipetkov", - "repo": "crane", - "rev": "5b03654ce046b5167e7b0bccbd8244cb56c16f0e", - "type": "github" - }, - "original": { - "owner": "ipetkov", - "repo": "crane", - "type": "github" - } - }, - "crane_3": { - "inputs": { - "nixpkgs": [ - "hax", - "nixpkgs" - ] - }, - "locked": { - "lastModified": 1717386774, - "narHash": "sha256-YYMGHDo4f+tu7k2q6hWNiI5C8gAN5eksb3g3EbKFf4k=", - "owner": "ipetkov", - "repo": "crane", - "rev": "ad21f86e47a2751faa99aecd0d494be70411d5e9", - "type": "github" - }, - "original": { - "owner": "ipetkov", - "repo": "crane", - "type": "github" - } - }, - "crane_4": { - "inputs": { - "nixpkgs": [ - "libcrux", - "nixpkgs" - ] - }, - "locked": { - "lastModified": 1718078026, - "narHash": "sha256-LbQabH6h86ZzTvDnaZHmMwedRZNB2jYtUQzmoqWQoJ8=", - "owner": "ipetkov", - "repo": "crane", - "rev": "a3f0c63eed74a516298932b9b1627dd80b9c3892", - "type": "github" - }, - "original": { - "owner": "ipetkov", - "repo": "crane", - "type": "github" - } - }, - "eurydice": { - "inputs": { - "charon": [ - "charon" - ], - "flake-utils": "flake-utils_3", - "fstar": "fstar", - "karamel": "karamel", - "nixpkgs": [ - "eurydice", - "karamel", - "nixpkgs" - ] - }, - "locked": { - "lastModified": 1731504425, - "narHash": "sha256-v51ze2+yq/rkyQrjBoGQEhzpy8fxtkgCfL9WuQJgHXg=", - "owner": "aeneasverif", - "repo": "eurydice", - "rev": "7d686376ec943225ff89942978c6c3028bac689c", - "type": "github" - }, - "original": { - "owner": "aeneasverif", - "repo": "eurydice", - "type": "github" - } - }, - "flake-compat": { - "locked": { - "lastModified": 1717312683, - "narHash": "sha256-FrlieJH50AuvagamEvWMIE6D2OAnERuDboFDYAED/dE=", - "owner": "nix-community", - "repo": "flake-compat", - "rev": "38fd3954cf65ce6faf3d0d45cd26059e059f07ea", - "type": "github" - }, - "original": { - "owner": "nix-community", - "repo": "flake-compat", - "type": "github" - } - }, - "flake-utils": { - "inputs": { - "systems": "systems" - }, - "locked": { - "lastModified": 1710146030, - "narHash": "sha256-SZ5L6eA7HJ/nmkzGG7/ISclqe6oZdOZTNoesiInkXPQ=", - "owner": "numtide", - "repo": "flake-utils", - "rev": "b1d9ab70662946ef0850d488da1c9019f3a9752a", - "type": "github" - }, - "original": { - "owner": "numtide", - "repo": "flake-utils", - "type": "github" - } - }, - "flake-utils_2": { - "inputs": { - "systems": "systems_2" - }, - "locked": { - "lastModified": 1726560853, - "narHash": "sha256-X6rJYSESBVr3hBoH0WbKE5KvhPU5bloyZ2L4K60/fPQ=", - "owner": "numtide", - "repo": "flake-utils", - "rev": "c1dfcf08411b08f6b8615f7d8971a2bfa81d5e8a", - "type": "github" - }, - "original": { - "owner": "numtide", - "repo": "flake-utils", - "type": "github" - } - }, - "flake-utils_3": { - "inputs": { - "systems": "systems_3" - }, - "locked": { - "lastModified": 1726560853, - "narHash": "sha256-X6rJYSESBVr3hBoH0WbKE5KvhPU5bloyZ2L4K60/fPQ=", - "owner": "numtide", - "repo": "flake-utils", - "rev": "c1dfcf08411b08f6b8615f7d8971a2bfa81d5e8a", - "type": "github" - }, - "original": { - "owner": "numtide", - "repo": "flake-utils", - "type": "github" - } - }, - "flake-utils_4": { - "inputs": { - "systems": "systems_4" - }, - "locked": { - "lastModified": 1692799911, - "narHash": "sha256-3eihraek4qL744EvQXsK1Ha6C3CR7nnT8X2qWap4RNk=", - "owner": "numtide", - "repo": "flake-utils", - "rev": "f9e7cf818399d17d347f847525c5a5a8032e4e44", - "type": "github" - }, - "original": { - "id": "flake-utils", - "type": "indirect" - } - }, - "flake-utils_5": { - "inputs": { - "systems": "systems_5" - }, - "locked": { - "lastModified": 1692799911, - "narHash": "sha256-3eihraek4qL744EvQXsK1Ha6C3CR7nnT8X2qWap4RNk=", - "owner": "numtide", - "repo": "flake-utils", - "rev": "f9e7cf818399d17d347f847525c5a5a8032e4e44", - "type": "github" - }, - "original": { - "id": "flake-utils", - "type": "indirect" - } - }, - "flake-utils_6": { - "inputs": { - "systems": "systems_6" - }, - "locked": { - "lastModified": 1731533236, - "narHash": "sha256-l0KFg5HjrsfsO/JpG+r7fRrqm12kzFHyUHqHCVpMMbI=", - "owner": "numtide", - "repo": "flake-utils", - "rev": "11707dc2f618dd54ca8739b309ec4fc024de578b", - "type": "github" - }, - "original": { - "owner": "numtide", - "repo": "flake-utils", - "type": "github" - } - }, - "flake-utils_7": { - "inputs": { - "systems": "systems_7" - }, - "locked": { - "lastModified": 1710146030, - "narHash": "sha256-SZ5L6eA7HJ/nmkzGG7/ISclqe6oZdOZTNoesiInkXPQ=", - "owner": "numtide", - "repo": "flake-utils", - "rev": "b1d9ab70662946ef0850d488da1c9019f3a9752a", - "type": "github" - }, - "original": { - "owner": "numtide", - "repo": "flake-utils", - "type": "github" - } - }, - "flake-utils_8": { - "inputs": { - "systems": "systems_8" - }, - "locked": { - "lastModified": 1710146030, - "narHash": "sha256-SZ5L6eA7HJ/nmkzGG7/ISclqe6oZdOZTNoesiInkXPQ=", - "owner": "numtide", - "repo": "flake-utils", - "rev": "b1d9ab70662946ef0850d488da1c9019f3a9752a", - "type": "github" - }, - "original": { - "owner": "numtide", - "repo": "flake-utils", - "type": "github" - } - }, - "fstar": { - "inputs": { - "flake-utils": "flake-utils_4", - "nixpkgs": "nixpkgs_2" - }, - "locked": { - "lastModified": 1731120038, - "narHash": "sha256-KfKaTvgjxGe+Z5KU+9rW/1Wr0SH4QOWIAm0UYL1FcBI=", - "owner": "FStarLang", - "repo": "fstar", - "rev": "668e45909b2a485e0b5152d016ddec93f470d24d", - "type": "github" - }, - "original": { - "owner": "FStarLang", - "repo": "fstar", - "type": "github" - } - }, - "fstar_2": { - "inputs": { - "flake-utils": "flake-utils_5", - "nixpkgs": "nixpkgs_3" - }, - "locked": { - "lastModified": 1731120038, - "narHash": "sha256-KfKaTvgjxGe+Z5KU+9rW/1Wr0SH4QOWIAm0UYL1FcBI=", - "owner": "fstarlang", - "repo": "fstar", - "rev": "668e45909b2a485e0b5152d016ddec93f470d24d", - "type": "github" - }, - "original": { - "owner": "fstarlang", - "repo": "fstar", - "type": "github" - } - }, - "fstar_3": { - "inputs": { - "flake-utils": [ - "hax", - "flake-utils" - ], - "nixpkgs": [ - "hax", - "nixpkgs" - ] - }, - "locked": { - "lastModified": 1705191588, - "narHash": "sha256-xjSWDP8mSjLcn+0hsRpEdzsBgBR+mKCZB8yLmHl+WqE=", - "owner": "FStarLang", - "repo": "FStar", - "rev": "a32b316e521fa4f239b610ec8f1d15e78d62cbe8", - "type": "github" - }, - "original": { - "owner": "FStarLang", - "ref": "v2024.01.13", - "repo": "FStar", - "type": "github" - } - }, - "hacl-star": { - "flake": false, - "locked": { - "lastModified": 1716379562, - "narHash": "sha256-42dF8kPEiveSPgHoicxZG/CCu3IhwJhtfvVNfrLczu8=", - "owner": "hacl-star", - "repo": "hacl-star", - "rev": "9149b0c26b06a8e06a0920a07c33ddd18d94c519", - "type": "github" - }, - "original": { - "owner": "hacl-star", - "repo": "hacl-star", - "type": "github" - } - }, - "hax": { - "inputs": { - "crane": "crane_3", - "flake-utils": "flake-utils_7", - "fstar": "fstar_3", - "hacl-star": "hacl-star", - "nixpkgs": "nixpkgs_4", - "rust-by-examples": "rust-by-examples", - "rust-overlay": "rust-overlay_2" - }, - "locked": { - "lastModified": 1731505152, - "narHash": "sha256-QrKZJwAjz7cc/OIfrD4sxQnkpf8m81WDu2QXYoJCHCU=", - "owner": "hacspec", - "repo": "hax", - "rev": "3ca3bde25951b1be5224ea45c96dc506ad803320", - "type": "github" - }, - "original": { - "owner": "hacspec", - "repo": "hax", - "type": "github" - } - }, - "karamel": { - "inputs": { - "flake-utils": [ - "eurydice", - "karamel", - "fstar", - "flake-utils" - ], - "fstar": "fstar_2", - "nixpkgs": [ - "eurydice", - "karamel", - "fstar", - "nixpkgs" - ] - }, - "locked": { - "lastModified": 1730490029, - "narHash": "sha256-PDOd0tW7DDZfXlozrcTZ33mgWAukR/UH4Ilt5ew8oPw=", - "owner": "FStarLang", - "repo": "karamel", - "rev": "5f7e9be838ba8ec0ed3323132e6beb6276f6acf2", - "type": "github" - }, - "original": { - "owner": "FStarLang", - "repo": "karamel", - "type": "github" - } - }, - "libcrux": { - "inputs": { - "charon": [ - "charon" - ], - "crane": "crane_4", - "eurydice": [ - "eurydice" - ], - "flake-utils": "flake-utils_8", - "fstar": [ - "eurydice", - "fstar" - ], - "hax": [ - "hax" - ], - "karamel": [ - "eurydice", - "karamel" - ], - "nixpkgs": "nixpkgs_5" - }, - "locked": { - "lastModified": 1731527192, - "narHash": "sha256-FbFb9W8FSth/qnlQzSrJvhKQ5sFFChPx5g8BFsLi0Us=", - "owner": "cryspen", - "repo": "libcrux", - "rev": "9b4b79912a7dd564c0afa457b1d36e94ae3fef48", - "type": "github" - }, - "original": { - "owner": "cryspen", - "repo": "libcrux", - "type": "github" - } - }, - "nixpkgs": { - "locked": { - "lastModified": 1717196966, - "narHash": "sha256-yZKhxVIKd2lsbOqYd5iDoUIwsRZFqE87smE2Vzf6Ck0=", - "owner": "nixos", - "repo": "nixpkgs", - "rev": "57610d2f8f0937f39dbd72251e9614b1561942d8", - "type": "github" - }, - "original": { - "owner": "nixos", - "ref": "nixos-unstable", - "repo": "nixpkgs", - "type": "github" - } - }, - "nixpkgs_2": { - "locked": { - "lastModified": 1693158576, - "narHash": "sha256-aRTTXkYvhXosGx535iAFUaoFboUrZSYb1Ooih/auGp0=", - "owner": "NixOS", - "repo": "nixpkgs", - "rev": "a999c1cc0c9eb2095729d5aa03e0d8f7ed256780", - "type": "github" - }, - "original": { - "id": "nixpkgs", - "ref": "nixos-unstable", - "type": "indirect" - } - }, - "nixpkgs_3": { - "locked": { - "lastModified": 1693158576, - "narHash": "sha256-aRTTXkYvhXosGx535iAFUaoFboUrZSYb1Ooih/auGp0=", - "owner": "NixOS", - "repo": "nixpkgs", - "rev": "a999c1cc0c9eb2095729d5aa03e0d8f7ed256780", - "type": "github" - }, - "original": { - "id": "nixpkgs", - "ref": "nixos-unstable", - "type": "indirect" - } - }, - "nixpkgs_4": { - "locked": { - "lastModified": 1717402443, - "narHash": "sha256-KlFiT8xFAVy29iYJU9nBwvkC7WTfUC/jak5jNFz5wHM=", - "owner": "nixos", - "repo": "nixpkgs", - "rev": "c149b8818b982d612f519c7e73449d355206a89a", - "type": "github" - }, - "original": { - "owner": "nixos", - "repo": "nixpkgs", - "type": "github" - } - }, - "nixpkgs_5": { - "locked": { - "lastModified": 1717974879, - "narHash": "sha256-GTO3C88+5DX171F/gVS3Qga/hOs/eRMxPFpiHq2t+D8=", - "owner": "nixos", - "repo": "nixpkgs", - "rev": "c7b821ba2e1e635ba5a76d299af62821cbcb09f3", - "type": "github" - }, - "original": { - "owner": "nixos", - "ref": "nixos-unstable", - "repo": "nixpkgs", - "type": "github" - } - }, - "root": { - "inputs": { - "bertie": "bertie", - "charon": "charon", - "eurydice": "eurydice", - "flake-utils": "flake-utils_6", - "hax": "hax", - "libcrux": "libcrux" - } - }, - "rust-by-examples": { - "flake": false, - "locked": { - "lastModified": 1729958822, - "narHash": "sha256-/X1dI2MPYSfOdqOOxpNFCykoJtVetQCOo7WfBa7XAyU=", - "owner": "rust-lang", - "repo": "rust-by-example", - "rev": "4e3881e0cb1b690158acca3c16e271fdadf736da", - "type": "github" - }, - "original": { - "owner": "rust-lang", - "repo": "rust-by-example", - "type": "github" - } - }, - "rust-overlay": { - "inputs": { - "nixpkgs": [ - "charon", - "nixpkgs" - ] - }, - "locked": { - "lastModified": 1729736953, - "narHash": "sha256-Rb6JUop7NRklg0uzcre+A+Ebrn/ZiQPkm4QdKg6/3pw=", - "owner": "oxalica", - "repo": "rust-overlay", - "rev": "29b1275740d9283467b8117499ec8cbb35250584", - "type": "github" - }, - "original": { - "owner": "oxalica", - "repo": "rust-overlay", - "type": "github" - } - }, - "rust-overlay_2": { - "inputs": { - "nixpkgs": [ - "hax", - "nixpkgs" - ] - }, - "locked": { - "lastModified": 1729736953, - "narHash": "sha256-Rb6JUop7NRklg0uzcre+A+Ebrn/ZiQPkm4QdKg6/3pw=", - "owner": "oxalica", - "repo": "rust-overlay", - "rev": "29b1275740d9283467b8117499ec8cbb35250584", - "type": "github" - }, - "original": { - "owner": "oxalica", - "repo": "rust-overlay", - "type": "github" - } - }, - "systems": { - "locked": { - "lastModified": 1681028828, - "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", - "owner": "nix-systems", - "repo": "default", - "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", - "type": "github" - }, - "original": { - "owner": "nix-systems", - "repo": "default", - "type": "github" - } - }, - "systems_2": { - "locked": { - "lastModified": 1681028828, - "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", - "owner": "nix-systems", - "repo": "default", - "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", - "type": "github" - }, - "original": { - "owner": "nix-systems", - "repo": "default", - "type": "github" - } - }, - "systems_3": { - "locked": { - "lastModified": 1681028828, - "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", - "owner": "nix-systems", - "repo": "default", - "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", - "type": "github" - }, - "original": { - "owner": "nix-systems", - "repo": "default", - "type": "github" - } - }, - "systems_4": { - "locked": { - "lastModified": 1681028828, - "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", - "owner": "nix-systems", - "repo": "default", - "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", - "type": "github" - }, - "original": { - "owner": "nix-systems", - "repo": "default", - "type": "github" - } - }, - "systems_5": { - "locked": { - "lastModified": 1681028828, - "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", - "owner": "nix-systems", - "repo": "default", - "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", - "type": "github" - }, - "original": { - "owner": "nix-systems", - "repo": "default", - "type": "github" - } - }, - "systems_6": { - "locked": { - "lastModified": 1681028828, - "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", - "owner": "nix-systems", - "repo": "default", - "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", - "type": "github" - }, - "original": { - "owner": "nix-systems", - "repo": "default", - "type": "github" - } - }, - "systems_7": { - "locked": { - "lastModified": 1681028828, - "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", - "owner": "nix-systems", - "repo": "default", - "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", - "type": "github" - }, - "original": { - "owner": "nix-systems", - "repo": "default", - "type": "github" - } - }, - "systems_8": { - "locked": { - "lastModified": 1681028828, - "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", - "owner": "nix-systems", - "repo": "default", - "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", - "type": "github" - }, - "original": { - "owner": "nix-systems", - "repo": "default", - "type": "github" - } - } - }, - "root": "root", - "version": 7 -} diff --git a/message.sh b/message.sh index aab4012..e42c272 100755 --- a/message.sh +++ b/message.sh @@ -1,19 +1,36 @@ #!/usr/bin/env bash -cat STATUS.txt | grep '❌' > /dev/null && echo '❌❌❌' || echo '✅✅✅' +echo "*Nightly update*" +if [[ "$(jq 'map(.result == "success") | all' results.json)" == "true" ]]; then + echo '✅✅✅' +else + echo '❌❌❌' +fi echo "" + echo "*Links:*" -echo "commit: https://github.com/inria-prosecco/circus-green/commit/$(git show-ref --hash refs/heads/main)" +COMMIT="$(git rev-parse HEAD)" +echo "commit: https://github.com/inria-prosecco/circus-green/commit/$COMMIT" echo "run: https://github.com/inria-prosecco/circus-green/actions/runs/$RUN" echo "" + echo "*Statuses:*" -cat STATUS.txt +for project in hax charon eurydice ml-kem bertie; do + status="$(jq -r 'if .["'"$project"'"].result == "success" then "✅" else "❌" end' results.json)" + echo "$status $project (main)" +done echo "" + echo "*Tried to update:*" +git show origin/main:flake.lock > good.lock cat flake.lock good.lock | jq -s -r ' map( .nodes | [ .fstar, .karamel, .hax, .charon, .eurydice, .libcrux, .bertie ] | map( .locked ) - ) | transpose | map(select(.[0].rev != .[1].rev)) | .[] | - (.[0].repo + ": [" + .[1].rev[0:8] + ".." + .[0].rev[0:8] + "](https://github.com/" + .[0].owner + "/" + .[0].repo + "/compare/" + .[1].rev[0:8] + "..." + .[0].rev[0:8] + ")") + ) + | transpose + | .[] + | select(.[0].rev != .[1].rev) + | "\(.[1].rev[0:8])..\(.[0].rev[0:8])" as $range + | "\(.[0].repo): [\($range)](https://github.com/\(.[0].owner)/\(.[0].repo)/compare/\($range))" ' diff --git a/update.sh b/update.sh index e916745..f670812 100755 --- a/update.sh +++ b/update.sh @@ -6,29 +6,10 @@ EURYDICE_BRANCH="${EURYDICE_BRANCH:-main}" LIBCRUX_BRANCH="${LIBCRUX_BRANCH:-main}" BERTIE_BRANCH="${BERTE_BRANCH:-main}" -# update `flake.lock` +# Update `flake.lock` nix flake update \ --override-input hax "github:hacspec/hax?ref=$HAX_BRANCH" \ --override-input charon "github:aeneasverif/charon?ref=$CHARON_BRANCH" \ --override-input eurydice "github:aeneasverif/eurydice?ref=$EURYDICE_BRANCH" \ --override-input libcrux "github:cryspen/libcrux?ref=$LIBCRUX_BRANCH" \ --override-input bertie "github:cryspen/bertie?ref=$BERTIE_BRANCH" - -# update `STATUS.txt` -check () { - echo "##[group]$1" - STATUS=$(nix build -L --no-link ".#$1" && echo ✅ || echo ❌) - echo "##[endgroup]" - echo "$STATUS $1 ($2)" >> STATUS.txt -} -rm -f STATUS.txt -check "hax" "$HAX_BRANCH" -check "charon" "$CHARON_BRANCH" -check "eurydice" "$EURYDICE_BRANCH" -check "ml-kem" "$LIBCRUX_BRANCH" -check "bertie" "$BERTIE_BRANCH" - -if ! cat STATUS.txt | grep -q ❌ -then - cp flake.lock good.lock -fi