[INFO] cloning repository https://github.com/yousefmoazzam/c-compiler [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/yousefmoazzam/c-compiler" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fyousefmoazzam%2Fc-compiler", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fyousefmoazzam%2Fc-compiler'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 3e755655d00de9bb3b2f8a7d32b477e312a9a7c0 [INFO] testing yousefmoazzam/c-compiler against 1.84.0 for beta-1.85-1 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fyousefmoazzam%2Fc-compiler" "/workspace/builds/worker-0-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-0-tc1/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/yousefmoazzam/c-compiler on toolchain 1.84.0 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.84.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/yousefmoazzam/c-compiler [INFO] finished tweaking git repo https://github.com/yousefmoazzam/c-compiler [INFO] tweaked toml for git repo https://github.com/yousefmoazzam/c-compiler written to /workspace/builds/worker-0-tc1/source/Cargo.toml [INFO] crate git repo https://github.com/yousefmoazzam/c-compiler 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" "+1.84.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:86ea7c7af713d31e8cfdb68a6d0db50b5cf7cbeecde3d112f9f257f747318d36" "/opt/rustwide/cargo-home/bin/cargo" "+1.84.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 87fd60e90da8a5254f9c48f023696be7af40ce26fa24fb0eed0d88b05598c094 [INFO] running `Command { std: "docker" "start" "-a" "87fd60e90da8a5254f9c48f023696be7af40ce26fa24fb0eed0d88b05598c094", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "87fd60e90da8a5254f9c48f023696be7af40ce26fa24fb0eed0d88b05598c094", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "87fd60e90da8a5254f9c48f023696be7af40ce26fa24fb0eed0d88b05598c094", kill_on_drop: false }` [INFO] [stdout] 87fd60e90da8a5254f9c48f023696be7af40ce26fa24fb0eed0d88b05598c094 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:86ea7c7af713d31e8cfdb68a6d0db50b5cf7cbeecde3d112f9f257f747318d36" "/opt/rustwide/cargo-home/bin/cargo" "+1.84.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 06702e19d0004607fa0544e319a114576a1bb8179076780c12eebd895c62225d [INFO] running `Command { std: "docker" "start" "-a" "06702e19d0004607fa0544e319a114576a1bb8179076780c12eebd895c62225d", kill_on_drop: false }` [INFO] [stderr] Compiling memchr v2.7.4 [INFO] [stderr] Compiling regex-syntax v0.8.5 [INFO] [stderr] Compiling aho-corasick v1.1.3 [INFO] [stderr] Compiling regex-automata v0.4.8 [INFO] [stderr] Compiling regex v1.11.1 [INFO] [stderr] Compiling c_compiler v0.0.0 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 4.60s [INFO] running `Command { std: "docker" "inspect" "06702e19d0004607fa0544e319a114576a1bb8179076780c12eebd895c62225d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "06702e19d0004607fa0544e319a114576a1bb8179076780c12eebd895c62225d", kill_on_drop: false }` [INFO] [stdout] 06702e19d0004607fa0544e319a114576a1bb8179076780c12eebd895c62225d [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:86ea7c7af713d31e8cfdb68a6d0db50b5cf7cbeecde3d112f9f257f747318d36" "/opt/rustwide/cargo-home/bin/cargo" "+1.84.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] d77d9e70581892a6687ed857ec43528264fcad8b1aa3b1b25e34674d4c77f61c [INFO] running `Command { std: "docker" "start" "-a" "d77d9e70581892a6687ed857ec43528264fcad8b1aa3b1b25e34674d4c77f61c", kill_on_drop: false }` [INFO] [stderr] Compiling c_compiler v0.0.0 (/opt/rustwide/workdir) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.90s [INFO] running `Command { std: "docker" "inspect" "d77d9e70581892a6687ed857ec43528264fcad8b1aa3b1b25e34674d4c77f61c", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "d77d9e70581892a6687ed857ec43528264fcad8b1aa3b1b25e34674d4c77f61c", kill_on_drop: false }` [INFO] [stdout] d77d9e70581892a6687ed857ec43528264fcad8b1aa3b1b25e34674d4c77f61c [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:86ea7c7af713d31e8cfdb68a6d0db50b5cf7cbeecde3d112f9f257f747318d36" "/opt/rustwide/cargo-home/bin/cargo" "+1.84.0" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] d3b17ffd227a9ea8f8ec73d230172ac0d1642dfe4cf1fd07793f417245336e46 [INFO] running `Command { std: "docker" "start" "-a" "d3b17ffd227a9ea8f8ec73d230172ac0d1642dfe4cf1fd07793f417245336e46", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.01s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/c_compiler-7b4f036d83d9a502) [INFO] [stdout] [INFO] [stdout] running 72 tests [INFO] [stdout] test emit::tests::emit_allocate_stack_instruction ... ok [INFO] [stdout] test emit::tests::emit_function_definition_returns_correct_vector_of_strings ... ok [INFO] [stdout] test emit::tests::emit_neg_unary_operator ... ok [INFO] [stdout] test emit::tests::emit_mov_instruction ... ok [INFO] [stdout] test emit::tests::emit_imm_operand ... ok [INFO] [stdout] test emit::tests::emit_not_unary_operator ... ok [INFO] [stdout] test emit::tests::emit_program_definition_returns_correct_vector_of_strings ... ok [INFO] [stdout] test emit::tests::emit_register_ax_operand ... ok [INFO] [stdout] test emit::tests::emit_register_r10d_operand ... ok [INFO] [stdout] test emit::tests::emit_ret_instruction ... ok [INFO] [stdout] test emit::tests::emit_stack_addr_operand ... ok [INFO] [stdout] test emit::tests::emit_unary_instruction ... ok [INFO] [stdout] test lex::tests::create_int_keyword_token_when_found_at_start_of_string ... ok [INFO] [stdout] test lex::tests::open_parenthesis_token_is_created ... ok [INFO] [stdout] test emit::tests::panic_if_pseudo_register_operand_encountered - should panic ... ok [INFO] [stdout] test lex::tests::create_int_keyword_and_main_identifier_tokens ... ok [INFO] [stdout] test lex::tests::numeric_constant_token_is_created_with_correct_value ... ok [INFO] [stdout] test lex::tests::close_brace_token_is_created ... ok [INFO] [stdout] test lex::tests::asterisk_character_token_is_created ... ok [INFO] [stdout] test lex::tests::close_parenthesis_token_is_created ... ok [INFO] [stdout] test parse::asm::first_pass::tests::parse_ir_constant_to_asm_immediate ... ok [INFO] [stdout] test parse::asm::first_pass::tests::parse_ir_bitwise_complement_operator_to_asm_unary_operator ... ok [INFO] [stdout] test parse::asm::first_pass::tests::parse_ir_negation_operator_to_asm_unary_operator ... ok [INFO] [stdout] test lex::tests::panic_if_decrement_operator_detected - should panic ... ok [INFO] [stdout] test lex::tests::get_correct_tokens_despite_newline_characters ... ok [INFO] [stdout] test lex::tests::minus_character_token_is_created ... ok [INFO] [stdout] test parse::asm::first_pass::tests::parse_ir_return_instruction_to_asm_instructions ... ok [INFO] [stdout] test lex::tests::panic_if_no_match_found_for_substring - should panic ... ok [INFO] [stdout] test parse::asm::first_pass::tests::parse_ir_function_defn_to_asm_function_defn ... ok [INFO] [stdout] test parse::asm::first_pass::tests::parse_ir_unary_operator_instruction_to_asm_instruction ... ok [INFO] [stdout] test parse::asm::first_pass::tests::parse_ir_var_to_asm_pseudo_register ... ok [INFO] [stdout] test parse::asm::first_pass::tests::parse_ir_program_definition_to_asm_program_defn ... ok [INFO] [stdout] test lex::tests::plus_character_token_is_created ... ok [INFO] [stdout] test lex::tests::open_brace_token_is_created ... ok [INFO] [stdout] test lex::tests::percent_character_token_is_created ... ok [INFO] [stdout] test parse::asm::second_pass::tests::non_pseudo_register_operand_is_left_unchanged ... ok [INFO] [stdout] test lex::tests::forward_slash_character_token_is_created ... ok [INFO] [stdout] test parse::asm::second_pass::tests::program_parsing_returns_final_stack_offset_and_correct_program_defn ... ok [INFO] [stdout] test parse::asm::second_pass::tests::pseudo_registers_with_same_identifier_get_same_stack_address ... ok [INFO] [stdout] test parse::asm::third_pass::tests::convert_mov_instructions_with_src_dst_stack_addrs_to_two_mov_instructions ... ok [INFO] [stdout] test parse::asm::third_pass::tests::insert_stack_frame_allocate_instruction_at_start_of_function_defn_instructions ... ok [INFO] [stdout] test parse::asm::second_pass::tests::convert_pseudo_register_to_stack_address_and_update_hash_table_and_offset ... ok [INFO] [stdout] test parse::asm::second_pass::tests::dont_transform_return_instruction ... ok [INFO] [stdout] test parse::asm::second_pass::tests::function_defn_name_left_unchanged ... ok [INFO] [stdout] test parse::c::tests::parse_addition_operator ... ok [INFO] [stdout] test parse::c::tests::parse_bitwise_complement_operator ... ok [INFO] [stdout] test parse::c::tests::parse_expression_containing_bitwise_complement_operator ... ok [INFO] [stdout] test parse::c::tests::parse_expression_containing_expression_wrapped_in_parentheses ... ok [INFO] [stdout] test parse::c::tests::parse_expression_containing_negation_operator ... ok [INFO] [stdout] test parse::c::tests::parse_expression_containing_numeric_constant ... ok [INFO] [stdout] test parse::c::tests::parse_expression_with_division_operator ... ok [INFO] [stdout] test parse::c::tests::parse_expression_with_modulo_operator ... ok [INFO] [stdout] test parse::c::tests::parse_function_defn_with_int_return_and_statement_as_body ... ok [INFO] [stdout] test parse::c::tests::parse_negation_operator ... ok [INFO] [stdout] test parse::c::tests::parse_program_defn_consisting_of_single_function_defn ... ok [INFO] [stdout] test parse::c::tests::parse_single_addition_operator_expression ... ok [INFO] [stdout] test parse::c::tests::parse_expression_with_two_different_precedence_binary_operators ... ok [INFO] [stdout] test parse::asm::second_pass::tests::panic_if_allocate_stack_instruction_encountered - should panic ... ok [INFO] [stdout] test parse::c::tests::parse_statement_with_return_identifier_and_numeric_expression ... ok [INFO] [stdout] test parse::c::tests::panic_if_open_parenthesis_before_expression_but_no_close_parenthesis_after - should panic ... ok [INFO] [stdout] test parse::ir::tests::parse_c_constant_to_ir_constant ... ok [INFO] [stdout] test parse::c::tests::parse_two_addition_operator_expression ... ok [INFO] [stdout] test parse::ir::tests::parse_c_function_defn_to_ir_function_defn ... ok [INFO] [stdout] test parse::ir::tests::parse_c_complement_operstor_to_ir_unary_operator ... ok [INFO] [stdout] test parse::ir::tests::parse_return_statement_containing_expression_with_one_unary_operator_to_ir_instruction ... ok [INFO] [stdout] test parse::ir::tests::parse_c_negation_operator_to_ir_unary_operator ... ok [INFO] [stdout] test parse::ir::tests::parse_c_program_defn_to_ir_program_defn ... ok [INFO] [stdout] test parse::ir::tests::parse_return_statement_containing_expression_with_two_unary_operators_to_ir_instruction ... ok [INFO] [stdout] test parse::ir::tests::parse_return_statement_containing_numeric_constant_to_ir_instruction ... ok [INFO] [stdout] test lex::tests::return_keyword_token_is_created ... ok [INFO] [stdout] test lex::tests::semicolon_token_is_created ... ok [INFO] [stdout] test lex::tests::tilde_token_is_created ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 72 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.04s [INFO] [stdout] [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/c_compiler-c316e5eb7d1ee963) [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] [stderr] Doc-tests c_compiler [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" "d3b17ffd227a9ea8f8ec73d230172ac0d1642dfe4cf1fd07793f417245336e46", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "d3b17ffd227a9ea8f8ec73d230172ac0d1642dfe4cf1fd07793f417245336e46", kill_on_drop: false }` [INFO] [stdout] d3b17ffd227a9ea8f8ec73d230172ac0d1642dfe4cf1fd07793f417245336e46