[INFO] fetching crate airmux 0.2.3... [INFO] testing airmux-0.2.3 against try#8de4c7234dd9b97c9d76b58671343fdbbc9a433e+target=x86_64-unknown-linux-musl for musl_upgrade_1_2_5_with_libc_patch_0 [INFO] extracting crate airmux 0.2.3 into /workspace/builds/worker-7-tc1/source [INFO] started tweaking crates.io crate airmux 0.2.3 [INFO] finished tweaking crates.io crate airmux 0.2.3 [INFO] tweaked toml for crates.io crate airmux 0.2.3 written to /workspace/builds/worker-7-tc1/source/Cargo.toml [INFO] validating manifest of crates.io crate airmux 0.2.3 on toolchain 8de4c7234dd9b97c9d76b58671343fdbbc9a433e [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+8de4c7234dd9b97c9d76b58671343fdbbc9a433e" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate crates.io crate airmux 0.2.3 already has a lockfile, it will not be regenerated [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+8de4c7234dd9b97c9d76b58671343fdbbc9a433e" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded snafu-derive v0.6.10 [INFO] [stderr] Downloaded shell-words v1.0.0 [INFO] [stderr] Downloaded console v0.13.0 [INFO] [stderr] Downloaded snafu v0.6.10 [INFO] [stderr] Downloaded ole32-sys v0.2.0 [INFO] [stderr] Downloaded dirs-sys-next v0.1.1 [INFO] [stderr] Downloaded shell32-sys v0.1.2 [INFO] [stderr] Downloaded app_dirs v1.2.1 [INFO] [stderr] Downloaded terminal_size v0.1.15 [INFO] [stderr] Downloaded main_error v0.1.1 [INFO] [stderr] Downloaded mkdirp v1.0.0 [INFO] [stderr] Downloaded syn v1.0.55 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:90999bfc7ae267e83380e433d8e61a7c072ca6729e92edbae886d3423b3a6f4c" "/opt/rustwide/cargo-home/bin/cargo" "+8de4c7234dd9b97c9d76b58671343fdbbc9a433e" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] d6bfd71dbbf03d449bac969f420a1fa1f27e08ed3c676b97b06df5c5f5267fdb [INFO] running `Command { std: "docker" "start" "-a" "d6bfd71dbbf03d449bac969f420a1fa1f27e08ed3c676b97b06df5c5f5267fdb", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "d6bfd71dbbf03d449bac969f420a1fa1f27e08ed3c676b97b06df5c5f5267fdb", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "d6bfd71dbbf03d449bac969f420a1fa1f27e08ed3c676b97b06df5c5f5267fdb", kill_on_drop: false }` [INFO] [stdout] d6bfd71dbbf03d449bac969f420a1fa1f27e08ed3c676b97b06df5c5f5267fdb [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:90999bfc7ae267e83380e433d8e61a7c072ca6729e92edbae886d3423b3a6f4c" "/opt/rustwide/cargo-home/bin/cargo" "+8de4c7234dd9b97c9d76b58671343fdbbc9a433e" "build" "--frozen" "--message-format=json" "--target" "x86_64-unknown-linux-musl", kill_on_drop: false }` [INFO] [stdout] 68348bbdc8283d4b70a8e7f20d589e46add535d71ad0adf6bcb204428e44e59b [INFO] running `Command { std: "docker" "start" "-a" "68348bbdc8283d4b70a8e7f20d589e46add535d71ad0adf6bcb204428e44e59b", kill_on_drop: false }` [INFO] [stderr] Compiling libc v0.2.81 [INFO] [stderr] Compiling proc-macro2 v1.0.24 [INFO] [stderr] Compiling unicode-xid v0.2.1 [INFO] [stderr] Compiling syn v1.0.55 [INFO] [stderr] Compiling getrandom v0.1.15 [INFO] [stderr] Compiling serde_derive v1.0.118 [INFO] [stderr] Compiling serde v1.0.118 [INFO] [stderr] Compiling ryu v1.0.5 [INFO] [stderr] Compiling ppv-lite86 v0.2.10 [INFO] [stderr] Compiling doc-comment v0.3.3 [INFO] [stderr] Compiling unicode-width v0.1.8 [INFO] [stderr] Compiling serde_json v1.0.60 [INFO] [stderr] Compiling regex-syntax v0.6.21 [INFO] [stderr] Compiling linked-hash-map v0.5.3 [INFO] [stderr] Compiling dtoa v0.4.6 [INFO] [stderr] Compiling xdg v2.2.0 [INFO] [stderr] Compiling itoa v0.4.6 [INFO] [stderr] Compiling textwrap v0.11.0 [INFO] [stderr] Compiling vec_map v0.8.2 [INFO] [stderr] Compiling remove_dir_all v0.5.3 [INFO] [stderr] Compiling shell-words v1.0.0 [INFO] [stderr] Compiling main_error v0.1.1 [INFO] [stderr] Compiling yaml-rust v0.4.4 [INFO] [stderr] Compiling mkdirp v1.0.0 [INFO] [stderr] Compiling app_dirs v1.2.1 [INFO] [stderr] Compiling dirs-sys-next v0.1.1 [INFO] [stderr] Compiling terminal_size v0.1.15 [INFO] [stderr] Compiling atty v0.2.14 [INFO] [stderr] Compiling clap v2.33.3 [INFO] [stderr] Compiling quote v1.0.8 [INFO] [stderr] Compiling dirs-next v2.0.0 [INFO] [stderr] Compiling rand_core v0.5.1 [INFO] [stderr] Compiling shellexpand v2.1.0 [INFO] [stderr] Compiling rand_chacha v0.2.2 [INFO] [stderr] Compiling regex v1.4.2 [INFO] [stderr] Compiling rand v0.7.3 [INFO] [stderr] Compiling console v0.13.0 [INFO] [stderr] Compiling tempfile v3.1.0 [INFO] [stderr] Compiling snafu-derive v0.6.10 [INFO] [stderr] Compiling snafu v0.6.10 [INFO] [stderr] Compiling serde_yaml v0.8.14 [INFO] [stderr] Compiling airmux v0.2.3 (/opt/rustwide/workdir) [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/actions.rs:1009:30 [INFO] [stdout] | [INFO] [stdout] 1009 | pub fn new(project: &'a Project) -> Result> { [INFO] [stdout] | ^^ ---------------- the lifetime gets resolved as `'a` [INFO] [stdout] | | [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default [INFO] [stdout] help: one option is to consistently use `'a` [INFO] [stdout] | [INFO] [stdout] 1009 | pub fn new(project: &'a Project) -> Result, Box> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 18.11s [INFO] running `Command { std: "docker" "inspect" "68348bbdc8283d4b70a8e7f20d589e46add535d71ad0adf6bcb204428e44e59b", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "68348bbdc8283d4b70a8e7f20d589e46add535d71ad0adf6bcb204428e44e59b", kill_on_drop: false }` [INFO] [stdout] 68348bbdc8283d4b70a8e7f20d589e46add535d71ad0adf6bcb204428e44e59b [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:90999bfc7ae267e83380e433d8e61a7c072ca6729e92edbae886d3423b3a6f4c" "/opt/rustwide/cargo-home/bin/cargo" "+8de4c7234dd9b97c9d76b58671343fdbbc9a433e" "test" "--frozen" "--no-run" "--message-format=json" "--target" "x86_64-unknown-linux-musl", kill_on_drop: false }` [INFO] [stdout] 0cf2b6461643db822711ba5de777d596e9dc77cfdee57e6fa8c439fa77fb11fa [INFO] running `Command { std: "docker" "start" "-a" "0cf2b6461643db822711ba5de777d596e9dc77cfdee57e6fa8c439fa77fb11fa", kill_on_drop: false }` [INFO] [stderr] Compiling airmux v0.2.3 (/opt/rustwide/workdir) [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/actions.rs:1009:30 [INFO] [stdout] | [INFO] [stdout] 1009 | pub fn new(project: &'a Project) -> Result> { [INFO] [stdout] | ^^ ---------------- the lifetime gets resolved as `'a` [INFO] [stdout] | | [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default [INFO] [stdout] help: one option is to consistently use `'a` [INFO] [stdout] | [INFO] [stdout] 1009 | pub fn new(project: &'a Project) -> Result, Box> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/actions.rs:1009:30 [INFO] [stdout] | [INFO] [stdout] 1009 | pub fn new(project: &'a Project) -> Result> { [INFO] [stdout] | ^^ ---------------- the lifetime gets resolved as `'a` [INFO] [stdout] | | [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default [INFO] [stdout] help: one option is to consistently use `'a` [INFO] [stdout] | [INFO] [stdout] 1009 | pub fn new(project: &'a Project) -> Result, Box> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 4.09s [INFO] running `Command { std: "docker" "inspect" "0cf2b6461643db822711ba5de777d596e9dc77cfdee57e6fa8c439fa77fb11fa", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "0cf2b6461643db822711ba5de777d596e9dc77cfdee57e6fa8c439fa77fb11fa", kill_on_drop: false }` [INFO] [stdout] 0cf2b6461643db822711ba5de777d596e9dc77cfdee57e6fa8c439fa77fb11fa [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:90999bfc7ae267e83380e433d8e61a7c072ca6729e92edbae886d3423b3a6f4c" "/opt/rustwide/cargo-home/bin/cargo" "+8de4c7234dd9b97c9d76b58671343fdbbc9a433e" "test" "--frozen" "--target" "x86_64-unknown-linux-musl", kill_on_drop: false }` [INFO] [stdout] ddc0552765393f7c451ec36f8197eeb501d48d520e1ecbcef762562193b5de28 [INFO] running `Command { std: "docker" "start" "-a" "ddc0552765393f7c451ec36f8197eeb501d48d520e1ecbcef762562193b5de28", kill_on_drop: false }` [INFO] [stderr] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stderr] --> src/actions.rs:1009:30 [INFO] [stderr] | [INFO] [stderr] 1009 | pub fn new(project: &'a Project) -> Result> { [INFO] [stderr] | ^^ ---------------- the lifetime gets resolved as `'a` [INFO] [stderr] | | [INFO] [stderr] | this lifetime flows to the output [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default [INFO] [stderr] help: one option is to consistently use `'a` [INFO] [stderr] | [INFO] [stderr] 1009 | pub fn new(project: &'a Project) -> Result, Box> { [INFO] [stderr] | ++++ [INFO] [stderr] [INFO] [stderr] warning: `airmux` (lib) generated 1 warning (run `cargo fix --lib -p airmux` to apply 1 suggestion) [INFO] [stderr] warning: `airmux` (lib test) generated 1 warning (1 duplicate) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.12s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/x86_64-unknown-linux-musl/debug/deps/airmux-c86f72d3e15ef521) [INFO] [stdout] [INFO] [stdout] running 179 tests [INFO] [stdout] test actions::tests::edit_project_fails_if_extension_is_not_supported ... ok [INFO] [stdout] test actions::tests::edit_project_fails_when_editor_is_empty ... ok [INFO] [stdout] test actions::tests::env_context_returns_none_if_out_of_bounds ... ok [INFO] [stdout] test actions::tests::get_filename_extracts_project_name_from_project_file ... ok [INFO] [stdout] test actions::tests::get_filename_fails_if_path_does_not_contain_a_filename ... ok [INFO] [stdout] test actions::tests::get_filename_fails_if_project_file_is_single_dash_and_project_name_is_empty ... ok [INFO] [stdout] test actions::tests::env_context_returns_positional_vars_if_in_bounds ... ok [INFO] [stdout] test actions::tests::get_filename_fails_if_project_file_is_single_dash_and_project_name_is_none ... ok [INFO] [stdout] test actions::tests::get_filename_returns_empty_filepath_if_project_file_is_single_dash ... ok [INFO] [stdout] test actions::tests::edit_project_project_name_cannot_be_empty ... ok [INFO] [stdout] test actions::tests::edit_project_creates_sub_directories_as_needed ... ok [INFO] [stdout] test command::tests::process_command_escapes_pounds ... ok [INFO] [stdout] test actions::tests::edit_project_fails_when_project_path_is_directory ... ok [INFO] [stdout] test command::tests::process_command_removes_line_carriages ... ok [INFO] [stdout] test actions::tests::edit_project_succeeds_when_project_file_does_not_exist ... ok [INFO] [stdout] test actions::tests::remove_project_fails_if_project_does_not_exist ... ok [INFO] [stdout] test actions::tests::remove_project_project_name_cannot_be_empty ... ok [INFO] [stdout] test actions::tests::edit_project_succeeds_when_project_file_exists ... ok [INFO] [stdout] test config::tests::from_args_matches_commands_correctly ... ok [INFO] [stdout] test config::tests::check_fails_when_config_dir_is_a_file ... ok [INFO] [stdout] test config::tests::check_attemps_to_make_the_directory ... ok [INFO] [stdout] test config::tests::get_config_dir_fails_if_app_name_is_empty_and_config_dir_is_none ... ok [INFO] [stdout] test config::tests::get_config_dir_returns_correct_path ... ok [INFO] [stdout] test config::tests::get_tmux_command_splits_commands_correctly ... ok [INFO] [stdout] test actions::tests::edit_project_creates_file_locally ... ok [INFO] [stdout] test config::tests::check_fails_when_app_name_is_empty ... ok [INFO] [stdout] test pane::tests::pane_1st_form_deserializes_correctly_with_null_key_name ... ok [INFO] [stdout] test pane::tests::pane_1st_form_deserializes_correctly ... ok [INFO] [stdout] test config::tests::get_projects_dir_returns_correct_subdir_path ... ok [INFO] [stdout] test config::tests::get_projects_dir_returns_correct_path ... ok [INFO] [stdout] test config::tests::check_fails_when_author_name_is_empty ... ok [INFO] [stdout] test actions::tests::remove_project_removes_existing_project ... ok [INFO] [stdout] test pane::tests::pane_1st_form_deserializes_correctly_with_key_name ... ok [INFO] [stdout] test pane::tests::pane_1st_form_deserializes_from_null ... ok [INFO] [stdout] test actions::tests::remove_project_removes_parent_subdirectories_if_empty ... ok [INFO] [stdout] test pane::tests::pane_1st_form_deserializes_split_h ... ok [INFO] [stdout] test actions::tests::list_follows_symlinks ... ok [INFO] [stdout] test actions::tests::remove_project_does_not_remove_parent_subdirs_if_not_empty ... ok [INFO] [stdout] test pane::tests::pane_1st_form_deserializes_split_horizontal ... ok [INFO] [stdout] test actions::tests::remove_project_removes_local_project ... ok [INFO] [stdout] test actions::tests::get_project_list_returns_projects_without_extensions ... ok [INFO] [stdout] test config::tests::get_config_dir_returns_correct_subdir_path ... ok [INFO] [stdout] test pane::tests::pane_1st_form_deserializes_split_size_string ... ok [INFO] [stdout] test pane::tests::pane_1st_form_deserializes_split_v ... ok [INFO] [stdout] test pane::tests::pane_1st_form_deserializes_split_vertical ... ok [INFO] [stdout] test pane::tests::pane_1st_form_deserializes_split_size_null ... ok [INFO] [stdout] test pane::tests::pane_1st_form_deserializes_split_size_number ... ok [INFO] [stdout] test pane::tests::pane_1st_form_fails_when_a_field_does_not_accept_a_command_list ... ok [INFO] [stdout] test actions::tests::list_detects_symlink_loops ... ok [INFO] [stdout] test actions::tests::list_project_does_not_fail ... ok [INFO] [stdout] test pane::tests::pane_1st_form_fails_when_a_field_does_not_accept_a_pane_definition_with_name ... ok [INFO] [stdout] test pane::tests::pane_1st_form_fails_when_a_field_does_not_accept_a_string ... ok [INFO] [stdout] test pane::tests::pane_1st_form_deserializes_working_dir_from_number ... ok [INFO] [stdout] test pane::tests::pane_1st_form_fails_when_null_key_name_is_not_first_line ... ok [INFO] [stdout] test pane::tests::pane_1st_form_raises_error_on_invalid_split_size_value ... ok [INFO] [stdout] test pane::tests::pane_1st_form_fails_when_key_name_is_not_first_line ... ok [INFO] [stdout] test pane::tests::pane_1st_form_fails_when_a_field_does_not_accept_a_pane_definition_without_name ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_deserializes_correctly_from_command_list_with_name ... ok [INFO] [stdout] test pane::tests::pane_1st_form_raises_error_on_invalid_split_value ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_deserializes_correctly_from_command_list_with_null_name ... ok [INFO] [stdout] test actions::tests::list_shows_projects_in_subdirectories ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_deserializes_correctly_with_name ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_deserializes_split_h ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_deserializes_correctly_from_string ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_deserializes_correctly_from_single_command_with_null_name ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_deserializes_split_horizontal ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_deserializes_correctly_with_null_name ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_deserializes_split_size_null ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_deserializes_split_size_number ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_deserializes_split_size_string ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_deserializes_split_v ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_deserializes_split_vertical ... ok [INFO] [stdout] test pane::tests::pane_deserializes_post_create ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_fails_to_deserialize_from_boolean_with_name ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_fails_to_deserialize_from_boolean_with_null_name ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_fails_to_deserialize_from_number_with_null_name ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_raises_error_on_invalid_split_size_value ... ok [INFO] [stdout] test pane::tests::pane_3rd_form_deserializes_correctly_with_null_name ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_raises_error_on_invalid_split_value ... ok [INFO] [stdout] test pane::tests::pane_3rd_form_deserializes_correctly_with_id ... ok [INFO] [stdout] test pane::tests::pane_3rd_form_deserializes_correctly_with_name ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_fails_to_deserialize_from_number_with_name ... ok [INFO] [stdout] test pane::tests::pane_3rd_form_deserializes_correctly_with_null_id ... ok [INFO] [stdout] test pane::tests::pane_check_fails_when_working_dir_is_missing ... ok [INFO] [stdout] test pane::tests::pane_check_succeeds_on_valid_pane ... ok [INFO] [stdout] test pane::tests::pane_deserializes_null_command ... ok [INFO] [stdout] test pane::tests::pane_deserializes_sequence_as_command ... ok [INFO] [stdout] test pane::tests::pane_deserializes_sequence_commands ... ok [INFO] [stdout] test pane::tests::pane_deserializes_string_command ... ok [INFO] [stdout] test pane::tests::pane_from_string_translates_to_single_command_pane ... ok [INFO] [stdout] test pane::tests::pane_raises_error_on_invalid_commands_value ... ok [INFO] [stdout] test pane::tests::pane_raises_error_on_invalid_split_from_value ... ok [INFO] [stdout] test pane::tests::pane_check_succeeds_when_working_dir_is_a_existing_dir ... ok [INFO] [stdout] test project::tests::project_check_fails_on_invalid_session_name ... ok [INFO] [stdout] test project::tests::project_coerces_from_some ... ok [INFO] [stdout] test project::tests::project_check_fails_on_invalid_startup_window ... ok [INFO] [stdout] test project::tests::project_deserializer_accepts_multiple_window_commands ... ok [INFO] [stdout] test project::tests::project_deserializer_attach_default_when_neither_attach_or_detach_are_set ... ok [INFO] [stdout] test project::tests::project_check_succeeds_on_valid_project ... ok [INFO] [stdout] test project::tests::project_coerces_from_none ... ok [INFO] [stdout] test project::tests::project_deserializer_attach_value_is_set_correctly_when_attach_is_set ... ok [INFO] [stdout] test project::tests::project_check_fails_when_working_dir_is_missing ... ok [INFO] [stdout] test project::tests::project_deserializer_attach_value_is_set_correctly_when_detached_is_set ... ok [INFO] [stdout] test project::tests::project_deserializer_accepts_single_window_command ... ok [INFO] [stdout] test project::tests::project_check_succeeds_when_working_dir_is_a_existing_dir ... ok [INFO] [stdout] test project::tests::project_deserializer_accepts_empty_values ... ok [INFO] [stdout] test pane::tests::pane_check_fails_when_working_dir_is_not_a_directory ... ok [INFO] [stdout] test project::tests::project_deserializer_raises_error_when_both_attach_and_detached_are_set ... ok [INFO] [stdout] test project::tests::project_deserializer_rejects_unknown_fields ... ok [INFO] [stdout] test project::tests::project_deserializes_from_null ... ok [INFO] [stdout] test project::tests::project_deserializes_correctly ... ok [INFO] [stdout] test project::tests::project_deserializes_working_dir ... ok [INFO] [stdout] test project::tests::project_deserializes_working_dir_null_as_home ... ok [INFO] [stdout] test project::tests::project_get_tmux_command_for_template_returns_joined_quoted_params ... ok [INFO] [stdout] test project::tests::project_get_tmux_command_for_template_returns_single_command ... ok [INFO] [stdout] test project::tests::project_check_fails_when_working_dir_is_not_a_directory ... ok [INFO] [stdout] test project::tests::project_get_tmux_command_splits_command_and_appends_options ... ok [INFO] [stdout] test project::tests::project_on_create_deserializes_as_on_first_start ... ok [INFO] [stdout] test project::tests::project_pane_single_command_serializes_to_a_single_string ... ok [INFO] [stdout] test project::tests::project_pane_two_or_more_commands_serializes_to_a_full_object ... ok [INFO] [stdout] test project::tests::project_prepare_replaces_attach_when_force_attach_is_set ... ok [INFO] [stdout] test project::tests::project_prepare_replaces_session_name_when_none ... ok [INFO] [stdout] test project::tests::project_prepare_replaces_tmux_command_if_set_in_config ... ok [INFO] [stdout] test project::tests::project_prepare_sets_tmux_default_command_when_empty ... ok [INFO] [stdout] test project::tests::project_raises_error_on_invalid_working_dir_value ... ok [INFO] [stdout] test project::tests::project_pane_no_command_serializes_to_an_empty_string ... ok [INFO] [stdout] test project::tests::project_startup_window_by_index ... ok [INFO] [stdout] test project::tests::project_startup_window_by_name ... ok [INFO] [stdout] test utils::tests::correct_command_fails_on_empty_command ... ok [INFO] [stdout] test utils::tests::correct_command_parses_command_with_flags_command ... ok [INFO] [stdout] test utils::tests::correct_command_parses_returns_correct_arguments ... ok [INFO] [stdout] test utils::tests::correct_command_parses_single_command ... ok [INFO] [stdout] test utils::tests::fails_when_project_name_has_a_trailing_slash ... ok [INFO] [stdout] test utils::tests::fails_when_project_name_is_an_absolute_path ... ok [INFO] [stdout] test utils::tests::parses_empty_namespace ... ok [INFO] [stdout] test utils::tests::parses_multilevel_namspaces ... ok [INFO] [stdout] test utils::tests::parses_namespace ... ok [INFO] [stdout] test window::tests::window_1st_form_deserializes_correctly_deserializes_command_lists ... ok [INFO] [stdout] test window::tests::window_1st_form_deserializes_from_single_command ... ok [INFO] [stdout] test window::tests::window_1st_form_does_not_accept_unknown_fields ... ok [INFO] [stdout] test window::tests::window_1st_form_fails_when_a_field_does_not_accept_a_pane_list ... ok [INFO] [stdout] test window::tests::window_1st_form_fails_when_a_field_does_not_accept_command_list ... ok [INFO] [stdout] test window::tests::window_1st_form_fails_when_a_field_does_not_accept_window_definiton ... ok [INFO] [stdout] test window::tests::window_1st_form_fails_when_a_field_does_not_accept_window_definiton_with_name ... ok [INFO] [stdout] test window::tests::window_1st_form_fails_when_clear_panes_has_an_invalid_value ... ok [INFO] [stdout] test window::tests::window_1st_form_deserializes_from_multiple_commands ... ok [INFO] [stdout] test window::tests::window_1st_form_fails_when_null_key_name_is_not_first_line ... ok [INFO] [stdout] test window::tests::window_1st_form_deserializes_correctly_with_key_name ... ok [INFO] [stdout] test window::tests::window_1st_form_deserializes_from_null ... ok [INFO] [stdout] test window::tests::window_1st_form_fails_when_key_name_is_not_first_line ... ok [INFO] [stdout] test window::tests::window_2nd_form_deserializes_from_sequence_with_name ... ok [INFO] [stdout] test window::tests::window_2nd_form_deserializes_from_str_with_name ... ok [INFO] [stdout] test window::tests::window_2nd_form_deserializes_from_sequence_with_null_name ... ok [INFO] [stdout] test window::tests::window_2nd_form_deserializes_null_name ... ok [INFO] [stdout] test window::tests::window_2nd_form_deserializes_from_str_with_null_name ... ok [INFO] [stdout] test window::tests::window_2nd_form_raises_error_on_invalid_layout_value ... ok [INFO] [stdout] test window::tests::window_1st_form_deserializes_correctly_with_null_key_name ... ok [INFO] [stdout] test window::tests::window_1st_form_deserializes_correctly_with_explicit_name ... ok [INFO] [stdout] test window::tests::window_2nd_form_deserializes_correctly_from_pane_listwith_null_name ... ok [INFO] [stdout] test window::tests::window_2nd_form_deserializes_correctly_with_name ... ok [INFO] [stdout] test window::tests::window_2nd_form_deserializes_correctly_with_null_name ... ok [INFO] [stdout] test window::tests::window_2nd_form_deserializes_name_string ... ok [INFO] [stdout] test window::tests::window_2nd_form_raises_error_on_invalid_name_value ... ok [INFO] [stdout] test window::tests::window_2nd_form_raises_error_on_invalid_window_definition ... ok [INFO] [stdout] test window::tests::window_3rd_form_deserializes_correctly_with_null_key ... ok [INFO] [stdout] test window::tests::window_2nd_form_deserializes_from_null ... ok [INFO] [stdout] test window::tests::window_3rd_form_overrides_null_name ... ok [INFO] [stdout] test window::tests::window_2nd_form_raises_error_on_multiple_hashmap_keys ... ok [INFO] [stdout] test window::tests::window_3rd_form_deserializes_correctly_with_string_key ... ok [INFO] [stdout] test window::tests::window_check_fails_on_invalid_name ... ok [INFO] [stdout] test window::tests::window_check_fails_when_layout_and_split_are_both_used ... ok [INFO] [stdout] test window::tests::window_check_fails_when_pane_split_from_is_out_of_bounds ... ok [INFO] [stdout] test window::tests::window_check_fails_when_working_dir_is_missing ... ok [INFO] [stdout] test window::tests::window_deserializes_empty_pane_list ... ok [INFO] [stdout] test window::tests::window_deserializes_pane_keyword_as_panes ... ok [INFO] [stdout] test window::tests::window_check_succeeds_on_valid_window ... ok [INFO] [stdout] test window::tests::window_check_fails_when_layout_and_split_size_are_both_used ... ok [INFO] [stdout] test window::tests::window_check_succeeds_when_working_dir_is_a_existing_dir ... ok [INFO] [stdout] test window::tests::window_check_fails_when_working_dir_is_not_a_directory ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 179 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.10s [INFO] [stdout] [INFO] [stderr] Running unittests src/bin/airmux.rs (/opt/rustwide/target/x86_64-unknown-linux-musl/debug/deps/airmux-b37c544c8aa77d1c) [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "ddc0552765393f7c451ec36f8197eeb501d48d520e1ecbcef762562193b5de28", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "ddc0552765393f7c451ec36f8197eeb501d48d520e1ecbcef762562193b5de28", kill_on_drop: false }` [INFO] [stdout] ddc0552765393f7c451ec36f8197eeb501d48d520e1ecbcef762562193b5de28