2023-10-22 12:46:20 +00:00
|
|
|
{ pkgs, ... }:
|
2021-09-17 17:01:01 +00:00
|
|
|
|
2023-10-22 12:46:20 +00:00
|
|
|
let
|
|
|
|
inherit (pkgs) lib;
|
|
|
|
tests = {
|
|
|
|
default = testsForPackage { sparkPackage = pkgs.spark; };
|
|
|
|
};
|
|
|
|
|
|
|
|
testsForPackage =
|
|
|
|
args:
|
|
|
|
lib.recurseIntoAttrs {
|
|
|
|
sparkCluster = testSparkCluster args;
|
|
|
|
passthru.override = args': testsForPackage (args // args');
|
|
|
|
};
|
2023-12-31 22:47:55 +00:00
|
|
|
testSparkCluster =
|
|
|
|
{ sparkPackage, ... }:
|
|
|
|
pkgs.testers.nixosTest ({
|
2023-10-22 12:46:20 +00:00
|
|
|
name = "spark";
|
|
|
|
|
|
|
|
nodes = {
|
|
|
|
worker =
|
|
|
|
{ nodes, pkgs, ... }:
|
|
|
|
{
|
|
|
|
services.spark = {
|
|
|
|
package = sparkPackage;
|
|
|
|
worker = {
|
|
|
|
enable = true;
|
|
|
|
master = "master:7077";
|
2024-12-10 19:26:33 +00:00
|
|
|
};
|
|
|
|
};
|
2023-10-22 12:46:20 +00:00
|
|
|
virtualisation.memorySize = 2048;
|
|
|
|
};
|
|
|
|
master =
|
|
|
|
{ config, pkgs, ... }:
|
|
|
|
{
|
|
|
|
services.spark = {
|
|
|
|
package = sparkPackage;
|
|
|
|
master = {
|
|
|
|
enable = true;
|
|
|
|
bind = "0.0.0.0";
|
2024-12-10 19:26:33 +00:00
|
|
|
};
|
|
|
|
};
|
2023-10-22 12:46:20 +00:00
|
|
|
networking.firewall.allowedTCPPorts = [
|
2024-12-10 19:26:33 +00:00
|
|
|
22
|
|
|
|
7077
|
|
|
|
8080
|
|
|
|
];
|
2023-10-22 12:46:20 +00:00
|
|
|
};
|
2021-09-17 17:01:01 +00:00
|
|
|
};
|
|
|
|
|
2023-10-22 12:46:20 +00:00
|
|
|
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/")
|
2023-11-04 07:31:45 +00:00
|
|
|
worker.succeed("spark-submit --version | systemd-cat")
|
2023-10-22 12:46:20 +00:00
|
|
|
worker.succeed("spark-submit --master spark://master:7077 --executor-memory 512m --executor-cores 1 /spark_sample.py")
|
|
|
|
'';
|
|
|
|
});
|
|
|
|
in
|
|
|
|
tests
|