mirror of
https://gitlab.com/TECHNOFAB/nix-gitlab-ci.git
synced 2025-12-12 02:00:13 +01:00
Compare commits
No commits in common. "524bdf9cdcfb8008c08d7e54a95992ebf05331d5" and "fa33f6e0b71d0a2d733c5ad08c2ea9a99a2b7374" have entirely different histories.
524bdf9cdc
...
fa33f6e0b7
3 changed files with 13 additions and 15 deletions
|
|
@ -1 +1 @@
|
||||||
3.0.1
|
3.0.0
|
||||||
|
|
|
||||||
|
|
@ -637,12 +637,12 @@ in rec {
|
||||||
// gitlabOptions;
|
// gitlabOptions;
|
||||||
config = let
|
config = let
|
||||||
attrsToKeep = builtins.attrNames gitlabOptions;
|
attrsToKeep = builtins.attrNames gitlabOptions;
|
||||||
job = filterUnset (filterAttrs (n: _v: builtins.elem n attrsToKeep) config);
|
|
||||||
in {
|
in {
|
||||||
finalConfig = cilib.mkJobPatched {
|
finalConfig = cilib.mkJobPatched {
|
||||||
key = name;
|
key = name;
|
||||||
|
job = filterUnset (filterAttrs (n: _v: builtins.elem n attrsToKeep) config);
|
||||||
nixConfig = config.nix;
|
nixConfig = config.nix;
|
||||||
inherit job pipelineName;
|
inherit pipelineName;
|
||||||
};
|
};
|
||||||
depsDrv = cilib.mkJobDeps {
|
depsDrv = cilib.mkJobDeps {
|
||||||
key = name;
|
key = name;
|
||||||
|
|
@ -651,8 +651,8 @@ in rec {
|
||||||
};
|
};
|
||||||
runnerDrv = cilib.mkJobRun {
|
runnerDrv = cilib.mkJobRun {
|
||||||
key = name;
|
key = name;
|
||||||
|
job = config.finalConfig;
|
||||||
jobDeps = config.depsDrv;
|
jobDeps = config.depsDrv;
|
||||||
inherit job;
|
|
||||||
};
|
};
|
||||||
packages = {
|
packages = {
|
||||||
"gitlab-ci:pipeline:${pipelineName}:job-deps:${name}" = config.depsDrv;
|
"gitlab-ci:pipeline:${pipelineName}:job-deps:${name}" = config.depsDrv;
|
||||||
|
|
|
||||||
|
|
@ -28,19 +28,18 @@ while [[ $# -gt 0 ]]; do
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
echo "Unknown option: $1" >&2
|
echo "Unknown option: $1" >&2
|
||||||
echo "use --include-dirty, --no-sandbox, --keep-tmp and --keep-env <ENV>" >&2
|
|
||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
if [ $NO_SANDBOX = false ]; then
|
if [ "$NO_SANDBOX" = false ]; then
|
||||||
echo "Running with simple sandboxing"
|
echo "Running with simple sandboxing"
|
||||||
NGCI_TMPDIR=$(mktemp -dt "nix-gitlab-ci.XXX")
|
TMPDIR=$(mktemp -dt "nix-gitlab-ci.XXX")
|
||||||
if [ $KEEP_TMP = false ]; then
|
if [ "$KEEP_TMP" = false ]; then
|
||||||
trap "rm -rf '$NGCI_TMPDIR'" EXIT
|
trap "rm -rf '$TMPDIR'" EXIT
|
||||||
else
|
else
|
||||||
echo "Temp dir will be preserved at: $NGCI_TMPDIR"
|
echo "Temp dir will be preserved at: $TMPDIR"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# check if dirty
|
# check if dirty
|
||||||
|
|
@ -51,15 +50,14 @@ if [ $NO_SANDBOX = false ]; then
|
||||||
git diff --staged > "$DIRTY_PATCH"
|
git diff --staged > "$DIRTY_PATCH"
|
||||||
trap "rm -f '$DIRTY_PATCH'" EXIT
|
trap "rm -f '$DIRTY_PATCH'" EXIT
|
||||||
fi
|
fi
|
||||||
git clone . $NGCI_TMPDIR
|
git clone . $TMPDIR
|
||||||
pushd $NGCI_TMPDIR >/dev/null
|
pushd $TMPDIR >/dev/null
|
||||||
if [[ ! -z "$DIRTY_PATCH" && $INCLUDE_DIRTY = true ]]; then
|
if [[ ! -z "$DIRTY_PATCH" && "$INCLUDE_DIRTY" = true ]]; then
|
||||||
echo "Copying dirty changes..."
|
echo "Copying dirty changes..."
|
||||||
git apply "$DIRTY_PATCH" 2>/dev/null || echo "Failed to copy dirty changes"
|
git apply "$DIRTY_PATCH" 2>/dev/null || echo "Failed to copy dirty changes"
|
||||||
git add . # required so the files are staged again
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "Running job in $NGCI_TMPDIR"
|
echo "Running job in $TMPDIR"
|
||||||
env -i $(
|
env -i $(
|
||||||
if [[ -n "$KEEP_ENV" ]]; then
|
if [[ -n "$KEEP_ENV" ]]; then
|
||||||
IFS=',' read -ra VARS <<< "$KEEP_ENV"
|
IFS=',' read -ra VARS <<< "$KEEP_ENV"
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue