[INFO] cloning repository https://github.com/dermoumi/rmux [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/dermoumi/rmux" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdermoumi%2Frmux", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdermoumi%2Frmux'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] ec6283e01e9c2d5aac47e8fb43b57f085865e5c4 [INFO] testing dermoumi/rmux against master#432e145bd5a974c5b6f4dd9b352891bd7502b69d for pr-87041 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdermoumi%2Frmux" "/workspace/builds/worker-10/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-10/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/dermoumi/rmux on toolchain 432e145bd5a974c5b6f4dd9b352891bd7502b69d [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+432e145bd5a974c5b6f4dd9b352891bd7502b69d" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/dermoumi/rmux [INFO] finished tweaking git repo https://github.com/dermoumi/rmux [INFO] tweaked toml for git repo https://github.com/dermoumi/rmux written to /workspace/builds/worker-10/source/Cargo.toml [INFO] crate git repo https://github.com/dermoumi/rmux already has a lockfile, it will not be regenerated [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+432e145bd5a974c5b6f4dd9b352891bd7502b69d" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-10/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-10/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:34b6a614d2c27851fe6cbf88fbd1137609cefab8b10d0615aaeb6fd47975d74e" "/opt/rustwide/cargo-home/bin/cargo" "+432e145bd5a974c5b6f4dd9b352891bd7502b69d" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 71d6679f0d0a828d0473c89103611444f0dd26fd80c0c6d7b9769e367eec47e8 [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "71d6679f0d0a828d0473c89103611444f0dd26fd80c0c6d7b9769e367eec47e8", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "71d6679f0d0a828d0473c89103611444f0dd26fd80c0c6d7b9769e367eec47e8", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "71d6679f0d0a828d0473c89103611444f0dd26fd80c0c6d7b9769e367eec47e8", kill_on_drop: false }` [INFO] [stdout] 71d6679f0d0a828d0473c89103611444f0dd26fd80c0c6d7b9769e367eec47e8 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-10/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-10/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" "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:34b6a614d2c27851fe6cbf88fbd1137609cefab8b10d0615aaeb6fd47975d74e" "/opt/rustwide/cargo-home/bin/cargo" "+432e145bd5a974c5b6f4dd9b352891bd7502b69d" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] 982afceb11da959fa59272792ced1b65c7f3d4ee2ed1771d3be8249a39ecc72f [INFO] running `Command { std: "docker" "start" "-a" "982afceb11da959fa59272792ced1b65c7f3d4ee2ed1771d3be8249a39ecc72f", 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 doc-comment v0.3.3 [INFO] [stderr] Compiling unicode-width v0.1.8 [INFO] [stderr] Compiling bitflags v1.2.1 [INFO] [stderr] Compiling linked-hash-map v0.5.3 [INFO] [stderr] Compiling regex-syntax v0.6.21 [INFO] [stderr] Compiling serde_json v1.0.60 [INFO] [stderr] Compiling ansi_term v0.11.0 [INFO] [stderr] Compiling strsim v0.8.0 [INFO] [stderr] Compiling vec_map v0.8.2 [INFO] [stderr] Compiling dtoa v0.4.6 [INFO] [stderr] Compiling itoa v0.4.6 [INFO] [stderr] Compiling mkdirp v1.0.0 [INFO] [stderr] Compiling shell-words v1.0.0 [INFO] [stderr] Compiling main_error v0.1.1 [INFO] [stderr] Compiling app_dirs v1.2.1 [INFO] [stderr] Compiling textwrap v0.11.0 [INFO] [stderr] Compiling yaml-rust v0.4.4 [INFO] [stderr] Compiling quote v1.0.8 [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 dirs-next v2.0.0 [INFO] [stderr] Compiling rand_core v0.5.1 [INFO] [stderr] Compiling shellexpand v2.1.0 [INFO] [stderr] Compiling regex v1.4.2 [INFO] [stderr] Compiling rand_chacha v0.2.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] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 1m 34s [INFO] running `Command { std: "docker" "inspect" "982afceb11da959fa59272792ced1b65c7f3d4ee2ed1771d3be8249a39ecc72f", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "982afceb11da959fa59272792ced1b65c7f3d4ee2ed1771d3be8249a39ecc72f", kill_on_drop: false }` [INFO] [stdout] 982afceb11da959fa59272792ced1b65c7f3d4ee2ed1771d3be8249a39ecc72f [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-10/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-10/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" "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:34b6a614d2c27851fe6cbf88fbd1137609cefab8b10d0615aaeb6fd47975d74e" "/opt/rustwide/cargo-home/bin/cargo" "+432e145bd5a974c5b6f4dd9b352891bd7502b69d" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] d865d66d1a238dc97ba60315f6dff353b2fdfdbaccdc32aa0422d9f975b6dd0e [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "d865d66d1a238dc97ba60315f6dff353b2fdfdbaccdc32aa0422d9f975b6dd0e", kill_on_drop: false }` [INFO] [stderr] Compiling airmux v0.2.3 (/opt/rustwide/workdir) [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 11.93s [INFO] running `Command { std: "docker" "inspect" "d865d66d1a238dc97ba60315f6dff353b2fdfdbaccdc32aa0422d9f975b6dd0e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "d865d66d1a238dc97ba60315f6dff353b2fdfdbaccdc32aa0422d9f975b6dd0e", kill_on_drop: false }` [INFO] [stdout] d865d66d1a238dc97ba60315f6dff353b2fdfdbaccdc32aa0422d9f975b6dd0e [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-10/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-10/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" "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:34b6a614d2c27851fe6cbf88fbd1137609cefab8b10d0615aaeb6fd47975d74e" "/opt/rustwide/cargo-home/bin/cargo" "+432e145bd5a974c5b6f4dd9b352891bd7502b69d" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 63302a5a99ae8abc9cfddbd84fafdef7586789fc41689859dc1af75f015a18bd [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "63302a5a99ae8abc9cfddbd84fafdef7586789fc41689859dc1af75f015a18bd", kill_on_drop: false }` [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.08s [INFO] [stderr] Running unittests (/opt/rustwide/target/debug/deps/airmux-2f18c433b248149b) [INFO] [stdout] [INFO] [stdout] running 179 tests [INFO] [stdout] test actions::tests::edit_project_project_name_cannot_be_empty ... 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_none ... ok [INFO] [stdout] test actions::tests::get_filename_returns_empty_filepath_if_project_file_is_single_dash ... ok [INFO] [stdout] test actions::tests::get_filename_extracts_project_name_from_project_file ... 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_empty ... ok [INFO] [stdout] test actions::tests::env_context_returns_none_if_out_of_bounds ... ok [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::edit_project_fails_when_project_path_is_directory ... ok [INFO] [stdout] test actions::tests::remove_project_project_name_cannot_be_empty ... ok [INFO] [stdout] test command::tests::process_command_removes_line_carriages ... ok [INFO] [stdout] test config::tests::check_attemps_to_make_the_directory ... ok [INFO] [stdout] test config::tests::check_fails_when_app_name_is_empty ... ok [INFO] [stdout] test config::tests::check_fails_when_author_name_is_empty ... ok [INFO] [stdout] test command::tests::process_command_escapes_pounds ... ok [INFO] [stdout] test actions::tests::remove_project_fails_if_project_does_not_exist ... 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::from_args_matches_commands_correctly ... ok [INFO] [stdout] test config::tests::get_config_dir_returns_correct_path ... ok [INFO] [stdout] test config::tests::get_config_dir_returns_correct_subdir_path ... ok [INFO] [stdout] test config::tests::get_projects_dir_returns_correct_path ... ok [INFO] [stdout] test config::tests::get_projects_dir_returns_correct_subdir_path ... ok [INFO] [stdout] test config::tests::get_tmux_command_splits_commands_correctly ... ok [INFO] [stdout] test pane::tests::pane_1st_form_deserializes_correctly ... ok [INFO] [stdout] test pane::tests::pane_1st_form_deserializes_correctly_with_key_name ... 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_from_null ... ok [INFO] [stdout] test pane::tests::pane_1st_form_deserializes_split_h ... ok [INFO] [stdout] test pane::tests::pane_1st_form_deserializes_split_horizontal ... 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_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_working_dir_from_number ... 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_pane_definition_without_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_fails_when_key_name_is_not_first_line ... 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_raises_error_on_invalid_split_value ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_deserializes_correctly_from_command_list_with_name ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_deserializes_correctly_from_command_list_with_null_name ... 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_correctly_from_string ... ok [INFO] [stdout] test pane::tests::pane_1st_form_fails_when_a_field_does_not_accept_a_command_list ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_deserializes_correctly_with_name ... 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_horizontal ... 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_h ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_deserializes_split_vertical ... 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_boolean_with_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_fails_to_deserialize_from_number_with_name ... ok [INFO] [stdout] test pane::tests::pane_2nd_form_raises_error_on_invalid_split_value ... 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_name ... ok [INFO] [stdout] test pane::tests::pane_3rd_form_deserializes_correctly_with_id ... ok [INFO] [stdout] test actions::tests::remove_project_removes_existing_project ... ok [INFO] [stdout] test pane::tests::pane_3rd_form_deserializes_correctly_with_null_id ... ok [INFO] [stdout] test pane::tests::pane_3rd_form_deserializes_correctly_with_null_name ... ok [INFO] [stdout] test pane::tests::pane_check_fails_when_working_dir_is_missing ... ok [INFO] [stdout] test pane::tests::pane_check_succeeds_when_working_dir_is_a_existing_dir ... ok [INFO] [stdout] test pane::tests::pane_deserializes_null_command ... ok [INFO] [stdout] test pane::tests::pane_deserializes_post_create ... 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 project::tests::project_check_fails_on_invalid_session_name ... ok [INFO] [stdout] test project::tests::project_check_fails_on_invalid_startup_window ... ok [INFO] [stdout] test project::tests::project_check_fails_when_working_dir_is_missing ... ok [INFO] [stdout] test pane::tests::pane_check_succeeds_on_valid_pane ... ok [INFO] [stdout] test config::tests::check_fails_when_config_dir_is_a_file ... ok [INFO] [stdout] test actions::tests::remove_project_removes_parent_subdirectories_if_empty ... ok [INFO] [stdout] test actions::tests::edit_project_creates_file_locally ... ok [INFO] [stdout] test actions::tests::edit_project_succeeds_when_project_file_exists ... ok [INFO] [stdout] test actions::tests::edit_project_succeeds_when_project_file_does_not_exist ... ok [INFO] [stdout] test actions::tests::edit_project_creates_sub_directories_as_needed ... ok [INFO] [stdout] test project::tests::project_check_succeeds_on_valid_project ... ok [INFO] [stdout] test project::tests::project_deserializer_accepts_empty_values ... ok [INFO] [stdout] test project::tests::project_check_succeeds_when_working_dir_is_a_existing_dir ... ok [INFO] [stdout] test project::tests::project_coerces_from_none ... ok [INFO] [stdout] test project::tests::project_deserializer_attach_value_is_set_correctly_when_detached_is_set ... ok [INFO] [stdout] test project::tests::project_coerces_from_some ... ok [INFO] [stdout] test project::tests::project_deserializer_rejects_unknown_fields ... 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_attach_value_is_set_correctly_when_attach_is_set ... ok [INFO] [stdout] test project::tests::project_deserializer_accepts_multiple_window_commands ... ok [INFO] [stdout] test project::tests::project_deserializer_accepts_single_window_command ... ok [INFO] [stdout] test project::tests::project_deserializer_attach_default_when_neither_attach_or_detach_are_set ... ok [INFO] [stdout] test project::tests::project_deserializes_working_dir ... 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_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_no_command_serializes_to_an_empty_string ... 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_get_tmux_command_for_template_returns_single_command ... ok [INFO] [stdout] test project::tests::project_deserializes_from_null ... ok [INFO] [stdout] test project::tests::project_deserializes_working_dir_null_as_home ... ok [INFO] [stdout] test project::tests::project_raises_error_on_invalid_working_dir_value ... ok [INFO] [stdout] test project::tests::project_deserializes_correctly ... ok [INFO] [stdout] test project::tests::project_startup_window_by_index ... 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_pane_two_or_more_commands_serializes_to_a_full_object ... ok [INFO] [stdout] test project::tests::project_startup_window_by_name ... ok [INFO] [stdout] test pane::tests::pane_check_fails_when_working_dir_is_not_a_directory ... ok [INFO] [stdout] test utils::tests::correct_command_parses_command_with_flags_command ... ok [INFO] [stdout] test utils::tests::correct_command_parses_single_command ... ok [INFO] [stdout] test actions::tests::remove_project_does_not_remove_parent_subdirs_if_not_empty ... ok [INFO] [stdout] test utils::tests::fails_when_project_name_is_an_absolute_path ... ok [INFO] [stdout] test utils::tests::correct_command_parses_returns_correct_arguments ... ok [INFO] [stdout] test utils::tests::parses_multilevel_namspaces ... ok [INFO] [stdout] test utils::tests::parses_namespace ... ok [INFO] [stdout] test utils::tests::correct_command_fails_on_empty_command ... ok [INFO] [stdout] test utils::tests::parses_empty_namespace ... 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_from_null ... ok [INFO] [stdout] test utils::tests::fails_when_project_name_has_a_trailing_slash ... ok [INFO] [stdout] test window::tests::window_1st_form_deserializes_from_single_command ... ok [INFO] [stdout] test window::tests::window_1st_form_deserializes_from_multiple_commands ... 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_deserializes_correctly_with_explicit_name ... ok [INFO] [stdout] test window::tests::window_1st_form_fails_when_key_name_is_not_first_line ... ok [INFO] [stdout] test window::tests::window_1st_form_deserializes_correctly_deserializes_command_lists ... 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_2nd_form_deserializes_correctly_with_name ... ok [INFO] [stdout] test window::tests::window_2nd_form_deserializes_from_sequence_with_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_from_str_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_2nd_form_deserializes_from_null ... 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_with_name ... ok [INFO] [stdout] test window::tests::window_1st_form_deserializes_correctly_with_key_name ... ok [INFO] [stdout] test window::tests::window_1st_form_fails_when_a_field_does_not_accept_window_definiton ... ok [INFO] [stdout] test project::tests::project_check_fails_when_working_dir_is_not_a_directory ... ok [INFO] [stdout] test window::tests::window_2nd_form_deserializes_from_sequence_with_null_name ... ok [INFO] [stdout] test window::tests::window_2nd_form_raises_error_on_invalid_window_definition ... ok [INFO] [stdout] test window::tests::window_2nd_form_deserializes_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_layout_value ... ok [INFO] [stdout] test window::tests::window_2nd_form_deserializes_correctly_with_null_name ... ok [INFO] [stdout] test window::tests::window_2nd_form_deserializes_from_str_with_null_name ... ok [INFO] [stdout] test window::tests::window_check_fails_when_layout_and_split_are_both_used ... ok [INFO] [stdout] test window::tests::window_2nd_form_raises_error_on_multiple_hashmap_keys ... ok [INFO] [stdout] test window::tests::window_3rd_form_overrides_null_name ... ok [INFO] [stdout] test window::tests::window_check_fails_on_invalid_name ... ok [INFO] [stdout] test window::tests::window_check_fails_when_pane_split_from_is_out_of_bounds ... ok [INFO] [stdout] test window::tests::window_3rd_form_deserializes_correctly_with_null_key ... ok [INFO] [stdout] test window::tests::window_3rd_form_deserializes_correctly_with_string_key ... ok [INFO] [stdout] test actions::tests::remove_project_removes_local_project ... 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_deserializes_pane_keyword_as_panes ... ok [INFO] [stdout] test actions::tests::list_follows_symlinks ... ok [INFO] [stdout] test window::tests::window_check_fails_when_working_dir_is_not_a_directory ... ok [INFO] [stdout] test actions::tests::get_project_list_returns_projects_without_extensions ... ok [INFO] [stdout] test actions::tests::list_detects_symlink_loops ... ok [INFO] [stdout] test window::tests::window_check_fails_when_working_dir_is_missing ... ok [INFO] [stdout] test actions::tests::list_project_does_not_fail ... ok [INFO] [stdout] test window::tests::window_deserializes_empty_pane_list ... ok [INFO] [stderr] Running unittests (/opt/rustwide/target/debug/deps/airmux-de2c6ab458c172c4) [INFO] [stdout] test actions::tests::list_shows_projects_in_subdirectories ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 179 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.19s [INFO] [stdout] [INFO] [stderr] Doc-tests airmux [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] [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" "63302a5a99ae8abc9cfddbd84fafdef7586789fc41689859dc1af75f015a18bd", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "63302a5a99ae8abc9cfddbd84fafdef7586789fc41689859dc1af75f015a18bd", kill_on_drop: false }` [INFO] [stdout] 63302a5a99ae8abc9cfddbd84fafdef7586789fc41689859dc1af75f015a18bd