diff options
author | Marek Mahut <marek.mahut@gmail.com> | 2019-08-23 11:07:49 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-08-23 11:07:49 +0200 |
commit | 882e5b0e059a469ab5d89d89a764d1399803f0db (patch) | |
tree | 3fe64f87610ea0509feb505c9060c3aa1c8df0c2 /nixos/tests | |
parent | a50b04168df055ad40823321e286d3f19b29ddd2 (diff) | |
parent | 8d0776be668b4e4e5b1f2984a649b21a7f9deac9 (diff) | |
download | nixpkgs-882e5b0e059a469ab5d89d89a764d1399803f0db.tar nixpkgs-882e5b0e059a469ab5d89d89a764d1399803f0db.tar.gz nixpkgs-882e5b0e059a469ab5d89d89a764d1399803f0db.tar.bz2 nixpkgs-882e5b0e059a469ab5d89d89a764d1399803f0db.tar.lz nixpkgs-882e5b0e059a469ab5d89d89a764d1399803f0db.tar.xz nixpkgs-882e5b0e059a469ab5d89d89a764d1399803f0db.tar.zst nixpkgs-882e5b0e059a469ab5d89d89a764d1399803f0db.zip |
Merge pull request #67213 from mmahut/jormungandr
nixos: adding jormungandr service
Diffstat (limited to 'nixos/tests')
-rw-r--r-- | nixos/tests/all-tests.nix | 1 | ||||
-rw-r--r-- | nixos/tests/jormungandr.nix | 49 |
2 files changed, 50 insertions, 0 deletions
diff --git a/nixos/tests/all-tests.nix b/nixos/tests/all-tests.nix index b6930cc3a70..7564fc9eafb 100644 --- a/nixos/tests/all-tests.nix +++ b/nixos/tests/all-tests.nix @@ -127,6 +127,7 @@ in jackett = handleTest ./jackett.nix {}; jellyfin = handleTest ./jellyfin.nix {}; jenkins = handleTest ./jenkins.nix {}; + jormungandr = handleTest ./jormungandr.nix {}; kafka = handleTest ./kafka.nix {}; kerberos = handleTest ./kerberos/default.nix {}; kernel-latest = handleTest ./kernel-latest.nix {}; diff --git a/nixos/tests/jormungandr.nix b/nixos/tests/jormungandr.nix new file mode 100644 index 00000000000..ab4edf0506a --- /dev/null +++ b/nixos/tests/jormungandr.nix @@ -0,0 +1,49 @@ +import ./make-test.nix ({ pkgs, ... }: { + name = "jormungandr"; + meta = with pkgs.stdenv.lib.maintainers; { + maintainers = [ mmahut ]; + }; + + nodes = { + bft = { ... }: { + environment.systemPackages = [ pkgs.jormungandr ]; + + services.jormungandr.enable = true; + services.jormungandr.genesisBlockFile = "/var/lib/jormungandr/block-0.bin"; + services.jormungandr.secretFile = "/etc/secrets/jormungandr.yaml"; + }; + }; + + testScript = '' + startAll; + + # Let's wait for the StateDirectory + $bft->waitForFile("/var/lib/jormungandr/"); + + # First, we generate the genesis file for our new blockchain + $bft->succeed("jcli genesis init > /root/genesis.yaml"); + + # We need to generate our secret key + $bft->succeed("jcli key generate --type=Ed25519 > /root/key.prv"); + + # We include the secret key into our services.jormungandr.secretFile + $bft->succeed("mkdir -p /etc/secrets"); + $bft->succeed("echo -e \"bft:\\n signing_key:\" \$(cat /root/key.prv) > /etc/secrets/jormungandr.yaml"); + + # After that, we generate our public key from it + $bft->succeed("cat /root/key.prv | jcli key to-public > /root/key.pub"); + + # We add our public key as a consensus leader in the genesis configration file + $bft->succeed("sed -ie \"s/ed25519_pk1vvwp2s0n5jl5f4xcjurp2e92sj2awehkrydrlas4vgqr7xzt33jsadha32/\$(cat /root/key.pub)/\" /root/genesis.yaml"); + + # Now we can generate the genesis block from it + $bft->succeed("jcli genesis encode --input /root/genesis.yaml --output /var/lib/jormungandr/block-0.bin"); + + # We should have everything to start the service now + $bft->succeed("systemctl restart jormungandr"); + $bft->waitForUnit("jormungandr.service"); + + # Now we can test if we are able to reach the REST API + $bft->waitUntilSucceeds("curl -L http://localhost:8607/api/v0/node/stats | grep uptime"); + ''; +}) |