{
system ? builtins.currentSystem,
config ? { },
pkgs ? import ../../.. { inherit system config; },
lib ? pkgs.lib,
}:
let
inherit (import ./common.nix { inherit pkgs lib; }) mkTestName mariadbPackages;
replicateUser = "replicate";
replicatePassword = "secret";
makeTest = import ./../make-test-python.nix;
makeReplicationTest =
package,
name ? mkTestName package,
makeTest {
name = "${name}-replication";
meta = {
maintainers = lib.teams.helsinki-systems.members;
};
nodes = {
primary = {
services.mysql = {
inherit package;
enable = true;
replication.role = "master";
replication.slaveHost = "%";
replication.masterUser = replicateUser;
replication.masterPassword = replicatePassword;
initialDatabases = [
name = "testdb";
schema = ./testdb.sql;
}
];
networking.firewall.allowedTCPPorts = [ 3306 ];
secondary1 =
{ nodes, ... }:
replication.role = "slave";
replication.serverId = 2;
replication.masterHost = nodes.primary.networking.hostName;
secondary2 =
replication.serverId = 3;
testScript = ''
primary.start()
primary.wait_for_unit("mysql")
primary.wait_for_open_port(3306)
# Wait for testdb to be fully populated (5 rows).
primary.wait_until_succeeds(
"sudo -u mysql mysql -u mysql -D testdb -N -B -e 'select count(id) from tests' | grep -q 5"
)
secondary1.start()
secondary2.start()
secondary1.wait_for_unit("mysql")
secondary1.wait_for_open_port(3306)
secondary2.wait_for_unit("mysql")
secondary2.wait_for_open_port(3306)
# wait for replications to finish
secondary1.wait_until_succeeds(
secondary2.wait_until_succeeds(
secondary2.succeed("systemctl stop mysql")
primary.succeed(
"echo 'insert into testdb.tests values (123, 456);' | sudo -u mysql mysql -u mysql -N"
secondary2.succeed("systemctl start mysql")
"echo 'select * from testdb.tests where Id = 123;' | sudo -u mysql mysql -u mysql -N | grep 456"
'';
in
lib.mapAttrs (_: package: makeReplicationTest { inherit package; }) mariadbPackages