aboutsummaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authortomberek <tomberek@users.noreply.github.com>2023-08-11 08:50:22 -0500
committerGitHub <noreply@github.com>2023-08-11 08:50:22 -0500
commit010dc7958e23dd8acc72a154e40a6ce5761dccdf (patch)
tree1af486ab0e8b58ec7dc2d2fb89c3f086d67e4b62 /tests
parenta1fdc68c655e8d7ece51b6c84796d35203386c87 (diff)
parent60b7121d2c6d4322b7c2e8e7acfec7b701b2d3a1 (diff)
Merge pull request #8369 from obsidiansystems/inductive-derived-path
Make the Derived Path family of types inductive for dynamic derivations
Diffstat (limited to 'tests')
-rw-r--r--tests/build.sh2
-rw-r--r--tests/dyn-drv/build-built-drv.sh21
-rw-r--r--tests/dyn-drv/local.mk3
-rw-r--r--tests/test-libstoreconsumer/main.cc2
4 files changed, 25 insertions, 3 deletions
diff --git a/tests/build.sh b/tests/build.sh
index 8ae20f0df..7fbdb0f07 100644
--- a/tests/build.sh
+++ b/tests/build.sh
@@ -78,7 +78,7 @@ expectStderr 1 nix build --impure --expr 'with (import ./multiple-outputs.nix).e
| grepQuiet "has 2 entries in its context. It should only have exactly one entry"
nix build --impure --json --expr 'builtins.unsafeDiscardOutputDependency (import ./multiple-outputs.nix).e.a_a.drvPath' --no-link | jq --exit-status '
- (.[0] | .path | match(".*multiple-outputs-e.drv"))
+ (.[0] | match(".*multiple-outputs-e.drv"))
'
# Test building from raw store path to drv not expression.
diff --git a/tests/dyn-drv/build-built-drv.sh b/tests/dyn-drv/build-built-drv.sh
new file mode 100644
index 000000000..647be9457
--- /dev/null
+++ b/tests/dyn-drv/build-built-drv.sh
@@ -0,0 +1,21 @@
+#!/usr/bin/env bash
+
+source common.sh
+
+# In the corresponding nix file, we have two derivations: the first, named `hello`,
+# is a normal recursive derivation, while the second, named dependent, has the
+# new outputHashMode "text". Note that in "dependent", we don't refer to the
+# build output of `hello`, but only to the path of the drv file. For this reason,
+# we only need to:
+#
+# - instantiate `hello`
+# - build `producingDrv`
+# - check that the path of the output coincides with that of the original derivation
+
+out1=$(nix build -f ./text-hashed-output.nix hello --no-link)
+
+clearStore
+
+drvDep=$(nix-instantiate ./text-hashed-output.nix -A producingDrv)
+
+expectStderr 1 nix build "${drvDep}^out^out" --no-link | grepQuiet "Building dynamic derivations in one shot is not yet implemented"
diff --git a/tests/dyn-drv/local.mk b/tests/dyn-drv/local.mk
index f065a5627..b087ecd1c 100644
--- a/tests/dyn-drv/local.mk
+++ b/tests/dyn-drv/local.mk
@@ -1,6 +1,7 @@
dyn-drv-tests := \
$(d)/text-hashed-output.sh \
- $(d)/recursive-mod-json.sh
+ $(d)/recursive-mod-json.sh \
+ $(d)/build-built-drv.sh
install-tests-groups += dyn-drv
diff --git a/tests/test-libstoreconsumer/main.cc b/tests/test-libstoreconsumer/main.cc
index 31b6d8ef1..c61489af6 100644
--- a/tests/test-libstoreconsumer/main.cc
+++ b/tests/test-libstoreconsumer/main.cc
@@ -23,7 +23,7 @@ int main (int argc, char **argv)
std::vector<DerivedPath> paths {
DerivedPath::Built {
- .drvPath = store->parseStorePath(drvPath),
+ .drvPath = makeConstantStorePathRef(store->parseStorePath(drvPath)),
.outputs = OutputsSpec::Names{"out"}
}
};