use ../cli/swarm.nu * use ../cli/dragoon.nu use ../cli/network_builder.nu * use std assert use ../help_func/exit_func.nu exit_on_error # No need to modify for remote tests def main [--ssh-addr-file: path] { # define variables let test_file: path = "tests/assets/dragoon_32/dragoon_32x32.png" let res_filename = "reconstructed_file.png" let dragoonfly_root = "~/.share/dragoonfly" | path expand print $"Removing ($dragoonfly_root) if it was there from a previous test\n" try { rm -r $dragoonfly_root } # create the nodes const connection_list = [ [1, 2], [0], [0] ] # create the network topology let SWARM = build_network --no-shell --replace-file-dir $connection_list --ssh-addr-file=$ssh_addr_file --storage-space [10, 3, 1] --unit-list [G, K, K] try { # Encode the file into blocks, put them to a directory named blocks next to the file print "Node 0 encodes the file into blocks" let encode_res = dragoon encode-file --node $SWARM.0.ip_port $test_file let block_hashes = $encode_res.1 | from json #! This is a string not a list, need to convert let file_hash = $encode_res.0 print $"The file got cut into blocks, block hashes are" print $block_hashes print $"The hash of the file is: ($file_hash)" print "\nNode 0 sends the blocks to node 1 and 2" dragoon send-block-list --node $SWARM.0.ip_port $file_hash $block_hashes print "Node 0 finished sending blocks to node 1 and 2\n" print "Killing the swarm" swarm kill --no-shell $SWARM error make --unspanned {msg: "Send block list should have returned an error because node 1 doesn't have enough storage space to accept blocks"} } catch { |e| print "Killing the swarm" swarm kill --no-shell $SWARM if ($e.msg | str contains '"No more peers to send but blocks are left"') { return # test successful, we got the error we expected } else { error make --unspanned {msg: $"Test failed: ($e)"} } } }