blob: afbeb80b65a41237eba0e220978a737cd68aed9a (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
|
{ pkgs, runExeclineLocal, getBins, drvSeqL }:
let
bins = getBins pkgs.coreutils [ "ln" "ls" "touch" ];
writeRustSimple = name: args: srcFile:
linkTo name "${writeRustSimpleBin name args srcFile}/bin/${name}";
linkTo = name: path: runExeclineLocal name {} [
"importas" "out" "out"
bins.ln "-sT" path "$out"
];
writeRustSimpleBin = name: { dependencies ? [], ... }@args: srcFile: pkgs.buildRustCrate ({
pname = name;
version = "1.0.0";
crateName = name;
crateBin = [ name ];
dependencies = dependencies;
src = pkgs.runCommandLocal "write-main.rs" {} ''
mkdir -p $out/src/bin
cp ${srcFile} $out/src/bin/${name}.rs
find $out
'';
} // args);
writeRustSimpleLib = name: { dependencies ? [], ... }@args: srcFile: pkgs.buildRustCrate ({
pname = name;
version = "1.0.0";
crateName = name;
dependencies = dependencies;
src = pkgs.runCommandLocal "write-lib.rs" {} ''
mkdir -p $out/src
cp ${srcFile} $out/src/lib.rs
find $out
'';
} // args);
/* Takes a `buildRustCrate` derivation as an input,
* builds it with `{ buildTests = true; }` and runs
* all tests found in its `tests` dir. If they are
* all successful, `$out` will point to the crate
* built with `{ buildTests = false; }`, otherwise
* it will fail to build.
*
* See also the documentation on `drvSeqL` which is
* used to implement this behavior.
*/
testRustSimple = rustDrv:
let
crate = buildTests: rustDrv.override { inherit buildTests; };
tests = runExeclineLocal "${rustDrv.name}-tests-run" {} [
"importas" "out" "out"
"if" [
"pipeline" [ bins.ls "${crate true}/tests" ]
"forstdin" "test"
"importas" "test" "test"
"${crate true}/tests/$test"
]
bins.touch "$out"
];
in drvSeqL [ tests ] (crate false);
in {
inherit
writeRustSimple
writeRustSimpleBin
writeRustSimpleLib
testRustSimple
;
}
|