Skip to content

Commit

Permalink
Merge pull request #296 from CohenCyril/error-message
Browse files Browse the repository at this point in the history
Using Enrico's patch for the action to report errors properly
  • Loading branch information
proux01 authored Jan 18, 2025
2 parents 82da08d + f344a08 commit 546bb99
Show file tree
Hide file tree
Showing 8 changed files with 7,000 additions and 3,178 deletions.
1,600 changes: 1,100 additions & 500 deletions .github/workflows/nix-action-8.16-mathcomp2.yml

Large diffs are not rendered by default.

1,776 changes: 1,221 additions & 555 deletions .github/workflows/nix-action-8.16.yml

Large diffs are not rendered by default.

1,760 changes: 1,210 additions & 550 deletions .github/workflows/nix-action-8.17.yml

Large diffs are not rendered by default.

1,776 changes: 1,221 additions & 555 deletions .github/workflows/nix-action-8.18.yml

Large diffs are not rendered by default.

1,712 changes: 1,177 additions & 535 deletions .github/workflows/nix-action-8.19.yml

Large diffs are not rendered by default.

1,488 changes: 1,023 additions & 465 deletions .github/workflows/nix-action-8.20.yml

Large diffs are not rendered by default.

32 changes: 22 additions & 10 deletions .github/workflows/nix-action-master.yml
Original file line number Diff line number Diff line change
Expand Up @@ -36,12 +36,18 @@ jobs:
authToken: ${{ secrets.CACHIX_AUTH_TOKEN }}
extraPullNames: coq, math-comp
name: coq-community
- id: stepGetDerivation
name: Getting derivation for current job (coq)
run: "NIXPKGS_ALLOW_UNFREE=1 nix-build --no-out-link \\\n --argstr bundle
\"master\" --argstr job \"coq\" \\\n --dry-run 2> err > out || (touch fail;
true)\n"
- name: Error reporting
run: "echo \"out=\"; cat out\necho \"err=\"; cat err\n"
- name: Failure check
run: if [ -e fail ]; then exit 1; else exit 0; fi;
- id: stepCheck
name: Checking presence of CI target coq
run: "nb_dry_run=$(NIXPKGS_ALLOW_UNFREE=1 nix-build --no-out-link \\\n --argstr
bundle \"master\" --argstr job \"coq\" \\\n --dry-run 2>&1 > /dev/null)\n
echo $nb_dry_run\necho status=$(echo $nb_dry_run | grep \"built:\" | sed \"\
s/.*/built/\") >> $GITHUB_OUTPUT\n"
name: Checking presence of CI target for current job
run: (echo -n status=; cat out | grep "built:" | sed "s/.*/built/") >> $GITHUB_OUTPUT
- if: steps.stepCheck.outputs.status == 'built'
name: Building/fetching current CI target
run: NIXPKGS_ALLOW_UNFREE=1 nix-build --no-out-link --argstr bundle "master"
Expand Down Expand Up @@ -84,12 +90,18 @@ jobs:
authToken: ${{ secrets.CACHIX_AUTH_TOKEN }}
extraPullNames: coq, math-comp
name: coq-community
- id: stepGetDerivation
name: Getting derivation for current job (coq-shell)
run: "NIXPKGS_ALLOW_UNFREE=1 nix-build --no-out-link \\\n --argstr bundle
\"master\" --argstr job \"coq-shell\" \\\n --dry-run 2> err > out || (touch
fail; true)\n"
- name: Error reporting
run: "echo \"out=\"; cat out\necho \"err=\"; cat err\n"
- name: Failure check
run: if [ -e fail ]; then exit 1; else exit 0; fi;
- id: stepCheck
name: Checking presence of CI target coq-shell
run: "nb_dry_run=$(NIXPKGS_ALLOW_UNFREE=1 nix-build --no-out-link \\\n --argstr
bundle \"master\" --argstr job \"coq-shell\" \\\n --dry-run 2>&1 > /dev/null)\n
echo $nb_dry_run\necho status=$(echo $nb_dry_run | grep \"built:\" | sed \"\
s/.*/built/\") >> $GITHUB_OUTPUT\n"
name: Checking presence of CI target for current job
run: (echo -n status=; cat out | grep "built:" | sed "s/.*/built/") >> $GITHUB_OUTPUT
- if: steps.stepCheck.outputs.status == 'built'
name: 'Building/fetching previous CI target: coq'
run: NIXPKGS_ALLOW_UNFREE=1 nix-build --no-out-link --argstr bundle "master"
Expand Down
34 changes: 26 additions & 8 deletions action.nix
Original file line number Diff line number Diff line change
Expand Up @@ -76,19 +76,36 @@ with builtins; with lib; let
extraPullNames = map (v: v.name) (tail reordered);
})) ];

stepCheck = { job, bundles ? [] }:
stepGetDerivation = { job, bundles ? [] }:
let bundlestr = if isList bundles then "\${{ matrix.bundle }}" else bundles; in {
name = "Checking presence of CI target ${job}";
id = "stepCheck";
name = "Getting derivation for current job (${job})";
id = "stepGetDerivation";
run = ''
nb_dry_run=$(NIXPKGS_ALLOW_UNFREE=1 nix-build --no-out-link \
NIXPKGS_ALLOW_UNFREE=1 nix-build --no-out-link \
--argstr bundle "${bundlestr}" --argstr job "${job}" \
--dry-run 2>&1 > /dev/null)
echo $nb_dry_run
echo status=$(echo $nb_dry_run | grep "built:" | sed "s/.*/built/") >> $GITHUB_OUTPUT
--dry-run 2> err > out || (touch fail; true)
'';
};

stepErrorReporting = {
name = "Error reporting";
run = ''
echo "out="; cat out
echo "err="; cat err
'';
};

stepFailureCheck = {
name = "Failure check";
run = "if [ -e fail ]; then exit 1; else exit 0; fi;";
};

stepCheck = {
name = "Checking presence of CI target for current job";
id = "stepCheck";
run = "(echo -n status=; cat out | grep \"built:\" | sed \"s/.*/built/\") >> $GITHUB_OUTPUT";
};

stepBuild = {job, bundles ? [], current ? false}:
let bundlestr = if isList bundles then "\${{ matrix.bundle }}" else bundles; in {
name = if current then "Building/fetching current CI target"
Expand All @@ -108,7 +125,8 @@ with builtins; with lib; let
steps = [ stepCommitToInitiallyCheckout stepCheckout1
stepCommitToTest stepCheckout2 stepCachixInstall ]
++ (stepCachixUseAll cachix)
++ [ (stepCheck { inherit job bundles; }) ]
++ [ (stepGetDerivation { inherit job bundles; })
stepErrorReporting stepFailureCheck stepCheck ]
++ (map (job: stepBuild { inherit job bundles; }) jdeps)
++ [ (stepBuild { inherit job bundles; current = true; }) ];
} // (optionalAttrs (isList bundles) {strategy.matrix.bundle = bundles;});
Expand Down

0 comments on commit 546bb99

Please sign in to comment.