3d40057509
Without the change `tests` eval fails as: $ nix build --no-link -f. spark.tests --arg config '{ allowAliases = false; }' error: attribute 'nixosTest' missing 12| }; 13| testSparkCluster = { sparkPackage, ... }: pkgs.nixosTest ({ | ^ 14| name = "spark"; Did you mean nixosTests? `nixosTest` is an alias defined as: pkgs/top-level/aliases.nix: nixosTest = testers.nixosTest; # Added 2022-05-05
49 lines
1.4 KiB
Nix
49 lines
1.4 KiB
Nix
{ pkgs, ... }:
|
|
|
|
let
|
|
inherit (pkgs) lib;
|
|
tests = {
|
|
default = testsForPackage { sparkPackage = pkgs.spark; };
|
|
};
|
|
|
|
testsForPackage = args: lib.recurseIntoAttrs {
|
|
sparkCluster = testSparkCluster args;
|
|
passthru.override = args': testsForPackage (args // args');
|
|
};
|
|
testSparkCluster = { sparkPackage, ... }: pkgs.testers.nixosTest ({
|
|
name = "spark";
|
|
|
|
nodes = {
|
|
worker = { nodes, pkgs, ... }: {
|
|
services.spark = {
|
|
package = sparkPackage;
|
|
worker = {
|
|
enable = true;
|
|
master = "master:7077";
|
|
};
|
|
};
|
|
virtualisation.memorySize = 2048;
|
|
};
|
|
master = { config, pkgs, ... }: {
|
|
services.spark = {
|
|
package = sparkPackage;
|
|
master = {
|
|
enable = true;
|
|
bind = "0.0.0.0";
|
|
};
|
|
};
|
|
networking.firewall.allowedTCPPorts = [ 22 7077 8080 ];
|
|
};
|
|
};
|
|
|
|
testScript = ''
|
|
master.wait_for_unit("spark-master.service")
|
|
worker.wait_for_unit("spark-worker.service")
|
|
worker.copy_from_host( "${./spark_sample.py}", "/spark_sample.py" )
|
|
assert "<title>Spark Master at spark://" in worker.succeed("curl -sSfkL http://master:8080/")
|
|
worker.succeed("spark-submit --version | systemd-cat")
|
|
worker.succeed("spark-submit --master spark://master:7077 --executor-memory 512m --executor-cores 1 /spark_sample.py")
|
|
'';
|
|
});
|
|
in tests
|