[INFO] cloning repository https://github.com/tomknig/payments-engine [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/tomknig/payments-engine" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftomknig%2Fpayments-engine", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftomknig%2Fpayments-engine'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 0fe73cdfab133e5d45437355c253db1722dc1967 [INFO] testing tomknig/payments-engine against try#dec9417b8611e34e787a3e4c37686b5131f9e5c5 for pr-154210 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftomknig%2Fpayments-engine" "/workspace/builds/worker-5-tc2/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc2/source'... [INFO] [stderr] done. [INFO] removed /workspace/builds/worker-5-tc2/source/rust-toolchain.toml [INFO] started tweaking git repo https://github.com/tomknig/payments-engine [INFO] finished tweaking git repo https://github.com/tomknig/payments-engine [INFO] tweaked toml for git repo https://github.com/tomknig/payments-engine written to /workspace/builds/worker-5-tc2/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/tomknig/payments-engine on toolchain dec9417b8611e34e787a3e4c37686b5131f9e5c5 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/tomknig/payments-engine 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" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded assert_cmd v2.1.2 [INFO] [stderr] Downloaded csv-core v0.1.13 [INFO] [stderr] Downloaded csv v1.4.0 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 95194f8ab1b28a98c2b415aa3f670d911b46f6231fe551da455e3c0f6fc69048 [INFO] running `Command { std: "docker" "start" "-a" "95194f8ab1b28a98c2b415aa3f670d911b46f6231fe551da455e3c0f6fc69048", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "95194f8ab1b28a98c2b415aa3f670d911b46f6231fe551da455e3c0f6fc69048", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "95194f8ab1b28a98c2b415aa3f670d911b46f6231fe551da455e3c0f6fc69048", kill_on_drop: false }` [INFO] [stdout] 95194f8ab1b28a98c2b415aa3f670d911b46f6231fe551da455e3c0f6fc69048 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] bd05929b13e550045b2f0ef170e97b43d17372640ca9afb65333c86be8476af6 [INFO] running `Command { std: "docker" "start" "-a" "bd05929b13e550045b2f0ef170e97b43d17372640ca9afb65333c86be8476af6", kill_on_drop: false }` [INFO] [stderr] Compiling anyhow v1.0.101 [INFO] [stderr] Compiling memchr v2.8.0 [INFO] [stderr] Compiling itoa v1.0.17 [INFO] [stderr] Compiling quote v1.0.44 [INFO] [stderr] Compiling ryu v1.0.23 [INFO] [stderr] Compiling syn v2.0.116 [INFO] [stderr] Compiling csv-core v0.1.13 [INFO] [stderr] Compiling csv v1.4.0 [INFO] [stderr] Compiling thiserror-impl v2.0.18 [INFO] [stderr] Compiling serde_derive v1.0.228 [INFO] [stderr] Compiling thiserror v2.0.18 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling payments-engine v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 10.92s [INFO] running `Command { std: "docker" "inspect" "bd05929b13e550045b2f0ef170e97b43d17372640ca9afb65333c86be8476af6", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "bd05929b13e550045b2f0ef170e97b43d17372640ca9afb65333c86be8476af6", kill_on_drop: false }` [INFO] [stdout] bd05929b13e550045b2f0ef170e97b43d17372640ca9afb65333c86be8476af6 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 1746fc229ada3b2a310de7ad17a0dd1b8b89105847cb0f32cb890f5c4a2aa466 [INFO] running `Command { std: "docker" "start" "-a" "1746fc229ada3b2a310de7ad17a0dd1b8b89105847cb0f32cb890f5c4a2aa466", kill_on_drop: false }` [INFO] [stderr] Compiling libc v0.2.182 [INFO] [stderr] Compiling csv-core v0.1.13 [INFO] [stderr] Compiling predicates-core v1.0.10 [INFO] [stderr] Compiling assert_cmd v2.1.2 [INFO] [stderr] Compiling regex-automata v0.4.14 [INFO] [stderr] Compiling termtree v0.5.1 [INFO] [stderr] Compiling difflib v0.4.0 [INFO] [stderr] Compiling predicates-tree v1.0.13 [INFO] [stderr] Compiling csv v1.4.0 [INFO] [stderr] Compiling predicates v3.1.4 [INFO] [stderr] Compiling payments-engine v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] Compiling bstr v1.12.1 [INFO] [stderr] Compiling wait-timeout v0.2.1 [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 9.12s [INFO] running `Command { std: "docker" "inspect" "1746fc229ada3b2a310de7ad17a0dd1b8b89105847cb0f32cb890f5c4a2aa466", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "1746fc229ada3b2a310de7ad17a0dd1b8b89105847cb0f32cb890f5c4a2aa466", kill_on_drop: false }` [INFO] [stdout] 1746fc229ada3b2a310de7ad17a0dd1b8b89105847cb0f32cb890f5c4a2aa466 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] c375ac28c434a39b9e6d39d6cca17d7647a2a08726eb69575f12ace591015e11 [INFO] running `Command { std: "docker" "start" "-a" "c375ac28c434a39b9e6d39d6cca17d7647a2a08726eb69575f12ace591015e11", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.06s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/payments_engine-ccf0139c8ccb9139) [INFO] [stdout] [INFO] [stdout] running 74 tests [INFO] [stdout] test models::account::tests::chargebacks::test_chargeback ... ok [INFO] [stdout] test models::account::tests::chargebacks::test_chargeback_of_all_held_funds ... ok [INFO] [stdout] test models::account::tests::deposits::test_deposit_money ... ok [INFO] [stdout] test models::account::tests::deposits::test_deposit_to_locked_account ... ok [INFO] [stdout] test models::account::tests::open_disputes::test_open_dispute_for_all_available_funds ... ok [INFO] [stdout] test models::account::tests::open_disputes::test_open_dispute ... ok [INFO] [stdout] test models::account::tests::chargebacks::test_chargeback_with_insufficient_held_funds ... ok [INFO] [stdout] test models::account::tests::open_disputes::test_open_dispute_on_empty_account ... ok [INFO] [stdout] test models::account::tests::chargebacks::test_chargeback_with_locked_account ... ok [INFO] [stdout] test models::account::tests::chargebacks::test_chargeback_with_no_held_funds ... ok [INFO] [stdout] test models::account::tests::open_disputes::test_open_dispute_with_insufficient_funds ... ok [INFO] [stdout] test models::account::tests::invariants::test_total_money_invariant ... ok [INFO] [stdout] test models::account::tests::resolve_disputes::test_resolve_dispute ... ok [INFO] [stdout] test models::account::tests::resolve_disputes::test_resolve_dispute_of_all_held_funds ... ok [INFO] [stdout] test models::account::tests::resolve_disputes::test_resolve_dispute_on_locked_account ... ok [INFO] [stdout] test models::account::tests::resolve_disputes::test_resolve_dispute_with_insufficient_held_funds ... ok [INFO] [stdout] test models::account::tests::withdrawals::test_withdraw_all_available_funds ... ok [INFO] [stdout] test models::account::tests::resolve_disputes::test_resolve_dispute_with_no_held_funds ... ok [INFO] [stdout] test models::account::tests::withdrawals::test_withdraw_available_funds ... ok [INFO] [stdout] test models::account::tests::withdrawals::test_withdraw_from_locked_account ... ok [INFO] [stdout] test models::account::tests::withdrawals::test_withdraw_from_empty_account ... ok [INFO] [stdout] test models::account::tests::open_disputes::test_open_dispute_on_locked_account ... ok [INFO] [stdout] test models::account::tests::withdrawals::test_withdraw_unavailable_funds ... ok [INFO] [stdout] test models::ledger::tests::chargebacks::test_a_successful_chargeback_freezes_the_affected_account ... ok [INFO] [stdout] test models::ledger::tests::chargebacks::test_issue_a_chargeback_without_an_opened_dispute ... ok [INFO] [stdout] test models::ledger::tests::deposits::test_process_a_single_deposit_transaction ... ok [INFO] [stdout] test models::ledger::tests::chargebacks::test_issue_a_chargeback_for_a_resolved_dispute ... ok [INFO] [stdout] test models::ledger::tests::chargebacks::test_issue_a_chargeback_for_an_open_and_unresolved_dispute ... ok [INFO] [stdout] test models::ledger::tests::deposits::test_skip_repeated_transaction_id ... ok [INFO] [stdout] test models::ledger::tests::deposits::test_process_multiple_deposit_transactions_of_one_user ... ok [INFO] [stdout] test models::ledger::tests::open_disputes::test_open_dispute_for_existing_transaction_but_insufficient_balance ... ok [INFO] [stdout] test models::ledger::tests::open_disputes::test_open_dispute_for_already_disputed_deposit ... ok [INFO] [stdout] test models::ledger::tests::open_disputes::test_open_dispute_for_non_existing_transaction ... ok [INFO] [stdout] test models::ledger::tests::open_disputes::test_open_dispute_for_existing_but_incorrect_transaction ... ok [INFO] [stdout] test models::ledger::tests::open_disputes::test_open_dispute_for_transaction_of_another_client ... ok [INFO] [stdout] test models::ledger::tests::resolve_disputes::test_resolve_a_resolved_dispute ... ok [INFO] [stdout] test models::ledger::tests::resolve_disputes::test_resolve_an_open_and_unresolved_dispute ... ok [INFO] [stdout] test models::ledger::tests::withdrawals::test_withdrawal_fails_if_amount_exceeds_balance ... ok [INFO] [stdout] test models::ledger::tests::withdrawals::test_withdrawal_fails_if_transaction_id_has_been_used_by_deposit ... ok [INFO] [stdout] test models::ledger::tests::withdrawals::test_withdrawal_fails_if_transaction_id_has_been_used_by_withdrawal ... ok [INFO] [stdout] test models::ledger::tests::withdrawals::test_withdrawal_fails_if_client_does_not_exist ... ok [INFO] [stdout] test models::ledger::tests::resolve_disputes::test_resolve_without_an_opened_dispute ... ok [INFO] [stdout] test models::ledger::tests::deposits::test_process_multiple_deposit_transactions_of_multiple_users ... ok [INFO] [stdout] test models::ledger::tests::open_disputes::test_open_dispute_with_existing_deposit ... ok [INFO] [stdout] test models::ledger::tests::withdrawals::test_withdrawal_succeeds_if_funds_are_available ... ok [INFO] [stdout] test models::money::tests::parse::test_first_integer_that_exceeds_size ... ok [INFO] [stdout] test models::money::tests::parse::test_max_integer_precision_parses_successfully ... ok [INFO] [stdout] test models::money::tests::parse::test_max_number_parses_successfully ... ok [INFO] [stdout] test models::money::tests::parse::test_overflow_at_max_precision_doesnt_panic ... ok [INFO] [stdout] test models::money::tests::parse::test_overflow_at_max_integer_precision_doesnt_panic ... ok [INFO] [stdout] test models::money::tests::parse::test_parse_char_in_fraction ... ok [INFO] [stdout] test models::money::tests::parse::test_parse_char_in_integer ... ok [INFO] [stdout] test models::money::tests::parse::test_parse_multiple_dots ... ok [INFO] [stdout] test models::money::tests::parse::test_parse_integer ... ok [INFO] [stdout] test models::money::tests::parse::test_parse_special_characters_in_fraction ... ok [INFO] [stdout] test models::money::tests::parse_unchecked::test_display_full_precision ... ok [INFO] [stdout] test models::money::tests::parse_unchecked::test_display_leading_zeros_in_fraction ... ok [INFO] [stdout] test models::money::tests::parse::test_parse_negative_number ... ok [INFO] [stdout] test models::money::tests::parse::test_parse_valid_decimal ... ok [INFO] [stdout] test models::money::tests::parse::test_reject_too_many_decimal_places ... ok [INFO] [stdout] test models::money::tests::parse_unchecked::test_parse_four_fractional_digits ... ok [INFO] [stdout] test models::money::tests::parse_unchecked::test_parse_fraction_with_leading_and_trailing_zeros ... ok [INFO] [stdout] test models::money::tests::parse_unchecked::test_parse_fraction_with_leading_zeros ... ok [INFO] [stdout] test models::money::tests::parse_unchecked::test_parse_fraction_with_trailing_zeros ... ok [INFO] [stdout] test models::money::tests::parse_unchecked::test_parse_integer ... ok [INFO] [stdout] test models::money::tests::parse_unchecked::test_parse_one_fractional_digit ... ok [INFO] [stdout] test models::money::tests::parse_unchecked::test_parse_three_fractional_digits ... ok [INFO] [stdout] test models::money::tests::parse_unchecked::test_parse_two_fractional_digits ... ok [INFO] [stdout] test models::money::tests::arithmetic::test_subtraction_doesnt_panic ... ok [INFO] [stdout] test models::money::tests::arithmetic::test_addition_doesnt_panic ... ok [INFO] [stdout] test models::money::tests::parse_unchecked::test_display_zero_fraction ... ok [INFO] [stdout] test models::money::tests::parse_unchecked::test_display_one_decimal_place ... ok [INFO] [stdout] test models::money::tests::parse::test_parse_negative_number_with_char_in_fraction ... ok [INFO] [stdout] test models::ledger::tests::withdrawals::test_withdrawal_after_a_dispute_has_been_opened ... ok [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/payments_engine-f2d4464693f2f1de) [INFO] [stdout] [INFO] [stdout] test result: ok. 74 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.08s [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Running tests/cli.rs (/opt/rustwide/target/debug/deps/cli-4a9a55ef115d64cd) [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 1 test [INFO] [stderr] Doc-tests payments_engine [INFO] [stdout] test test_fixtures ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.53s [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" "c375ac28c434a39b9e6d39d6cca17d7647a2a08726eb69575f12ace591015e11", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "c375ac28c434a39b9e6d39d6cca17d7647a2a08726eb69575f12ace591015e11", kill_on_drop: false }` [INFO] [stdout] c375ac28c434a39b9e6d39d6cca17d7647a2a08726eb69575f12ace591015e11