[INFO] cloning repository https://github.com/mathew-bravo/db-rehearsal
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/mathew-bravo/db-rehearsal" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmathew-bravo%2Fdb-rehearsal", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmathew-bravo%2Fdb-rehearsal'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] afa894c974823515915d76721ae8ab598d8408b1
[INFO] testing mathew-bravo/db-rehearsal against 1.95.0 for beta-1.96-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmathew-bravo%2Fdb-rehearsal" "/workspace/builds/worker-0-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-0-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/mathew-bravo/db-rehearsal
[INFO] finished tweaking git repo https://github.com/mathew-bravo/db-rehearsal
[INFO] tweaked toml for git repo https://github.com/mathew-bravo/db-rehearsal written to /workspace/builds/worker-0-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/mathew-bravo/db-rehearsal on toolchain 1.95.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/mathew-bravo/db-rehearsal 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.95.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 4a331d33a3526e016df326f36cb30cf068c9f702215a2ebb9da61b474a2bf61a
[INFO] running `Command { std: "docker" "start" "-a" "4a331d33a3526e016df326f36cb30cf068c9f702215a2ebb9da61b474a2bf61a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "4a331d33a3526e016df326f36cb30cf068c9f702215a2ebb9da61b474a2bf61a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "4a331d33a3526e016df326f36cb30cf068c9f702215a2ebb9da61b474a2bf61a", kill_on_drop: false }`
[INFO] [stdout] 4a331d33a3526e016df326f36cb30cf068c9f702215a2ebb9da61b474a2bf61a
[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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 23f32f554fc293ff180be5e04fd073e9f1014e817654afd72541e1a9ac697a1e
[INFO] running `Command { std: "docker" "start" "-a" "23f32f554fc293ff180be5e04fd073e9f1014e817654afd72541e1a9ac697a1e", kill_on_drop: false }`
[INFO] [stderr]    Compiling clap_lex v1.0.0
[INFO] [stderr]    Compiling iana-time-zone v0.1.65
[INFO] [stderr]    Compiling syn v2.0.117
[INFO] [stderr]    Compiling chrono v0.4.44
[INFO] [stderr]    Compiling clap_builder v4.5.60
[INFO] [stderr]    Compiling clap_derive v4.5.55
[INFO] [stderr]    Compiling clap v4.5.60
[INFO] [stderr]    Compiling db-rehearsal v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: struct `CapturedQuery` is never constructed
[INFO] [stdout]   --> src/capture/general_log.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct CapturedQuery {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `CommandType` is never used
[INFO] [stdout]   --> src/capture/general_log.rs:19:10
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub enum CommandType {
[INFO] [stdout]    |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `QueryType` is never used
[INFO] [stdout]   --> src/capture/general_log.rs:29:10
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub enum QueryType {
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PendingCapturedQuery` is never constructed
[INFO] [stdout]   --> src/capture/general_log.rs:42:8
[INFO] [stdout]    |
[INFO] [stdout] 42 | struct PendingCapturedQuery {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CapturedQueryFilter` is never constructed
[INFO] [stdout]   --> src/capture/general_log.rs:51:12
[INFO] [stdout]    |
[INFO] [stdout] 51 | pub struct CapturedQueryFilter {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `matches` is never used
[INFO] [stdout]   --> src/capture/general_log.rs:58:8
[INFO] [stdout]    |
[INFO] [stdout] 57 | impl CapturedQueryFilter {
[INFO] [stdout]    | ------------------------ method in this implementation
[INFO] [stdout] 58 |     fn matches(&self, query: &CapturedQuery) -> bool {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CapturedQueryStream` is never constructed
[INFO] [stdout]   --> src/capture/general_log.rs:73:12
[INFO] [stdout]    |
[INFO] [stdout] 73 | pub struct CapturedQueryStream<R: BufRead> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FilteredCapturedQueryStream` is never constructed
[INFO] [stdout]   --> src/capture/general_log.rs:81:12
[INFO] [stdout]    |
[INFO] [stdout] 81 | pub struct FilteredCapturedQueryStream<I> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `with_filter`, `process_line`, and `finish` are never used
[INFO] [stdout]    --> src/capture/general_log.rs:87:12
[INFO] [stdout]     |
[INFO] [stdout]  86 | impl<R: BufRead> CapturedQueryStream<R> {
[INFO] [stdout]     | --------------------------------------- associated items in this implementation
[INFO] [stdout]  87 |     pub fn new(reader: R) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  96 |     pub fn with_filter(self, filter: CapturedQueryFilter) -> FilteredCapturedQueryStream<Self> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 100 |     fn process_line(&mut self, line: &str) -> Option<CapturedQuery> {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 129 |     fn finish(&mut self) -> Option<CapturedQuery> {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/capture/general_log.rs:165:12
[INFO] [stdout]     |
[INFO] [stdout] 164 | impl<I> FilteredCapturedQueryStream<I> {
[INFO] [stdout]     | -------------------------------------- associated function in this implementation
[INFO] [stdout] 165 |     pub fn new(inner: I, filter: CapturedQueryFilter) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `capture_general_log` is never used
[INFO] [stdout]    --> src/capture/general_log.rs:195:8
[INFO] [stdout]     |
[INFO] [stdout] 195 | pub fn capture_general_log(path: &Path) -> Result<CapturedQueryStream<BufReader<File>>, Error> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `push_continuation_line` is never used
[INFO] [stdout]    --> src/capture/general_log.rs:200:4
[INFO] [stdout]     |
[INFO] [stdout] 200 | fn push_continuation_line(query: &mut PendingCapturedQuery, line: &str) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_log_entry` is never used
[INFO] [stdout]    --> src/capture/general_log.rs:208:4
[INFO] [stdout]     |
[INFO] [stdout] 208 | fn parse_log_entry(line: &str) -> Option<PendingCapturedQuery> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `looks_like_log_entry_start` is never used
[INFO] [stdout]    --> src/capture/general_log.rs:232:4
[INFO] [stdout]     |
[INFO] [stdout] 232 | fn looks_like_log_entry_start(line: &str) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `split_once_whitespace` is never used
[INFO] [stdout]    --> src/capture/general_log.rs:248:4
[INFO] [stdout]     |
[INFO] [stdout] 248 | fn split_once_whitespace(input: &str) -> Option<(&str, &str)> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `looks_like_rfc3339_prefix` is never used
[INFO] [stdout]    --> src/capture/general_log.rs:253:4
[INFO] [stdout]     |
[INFO] [stdout] 253 | fn looks_like_rfc3339_prefix(token: &str) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `finalize_query` is never used
[INFO] [stdout]    --> src/capture/general_log.rs:264:4
[INFO] [stdout]     |
[INFO] [stdout] 264 | fn finalize_query(query: PendingCapturedQuery) -> CapturedQuery {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_command_type` is never used
[INFO] [stdout]    --> src/capture/general_log.rs:275:4
[INFO] [stdout]     |
[INFO] [stdout] 275 | fn parse_command_type(command_type: &str) -> CommandType {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `classify_query_type` is never used
[INFO] [stdout]    --> src/capture/general_log.rs:287:4
[INFO] [stdout]     |
[INFO] [stdout] 287 | fn classify_query_type(command_type: &CommandType, sql: &str) -> QueryType {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_noisy_query` is never used
[INFO] [stdout]    --> src/capture/general_log.rs:320:4
[INFO] [stdout]     |
[INFO] [stdout] 320 | fn is_noisy_query(sql: &str) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `normalized_leading_keywords` is never used
[INFO] [stdout]    --> src/capture/general_log.rs:328:4
[INFO] [stdout]     |
[INFO] [stdout] 328 | fn normalized_leading_keywords(sql: &str, count: usize) -> Vec<String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `normalize_keyword` is never used
[INFO] [stdout]    --> src/capture/general_log.rs:336:4
[INFO] [stdout]     |
[INFO] [stdout] 336 | fn normalize_keyword(token: &str) -> String {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 9.79s
[INFO] running `Command { std: "docker" "inspect" "23f32f554fc293ff180be5e04fd073e9f1014e817654afd72541e1a9ac697a1e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "23f32f554fc293ff180be5e04fd073e9f1014e817654afd72541e1a9ac697a1e", kill_on_drop: false }`
[INFO] [stdout] 23f32f554fc293ff180be5e04fd073e9f1014e817654afd72541e1a9ac697a1e
[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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] f7dc0506ba67ed408855f46d84f967c56e47a92c34d56ed3627bf57485ec8438
[INFO] running `Command { std: "docker" "start" "-a" "f7dc0506ba67ed408855f46d84f967c56e47a92c34d56ed3627bf57485ec8438", kill_on_drop: false }`
[INFO] [stderr]    Compiling db-rehearsal v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.89s
[INFO] running `Command { std: "docker" "inspect" "f7dc0506ba67ed408855f46d84f967c56e47a92c34d56ed3627bf57485ec8438", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f7dc0506ba67ed408855f46d84f967c56e47a92c34d56ed3627bf57485ec8438", kill_on_drop: false }`
[INFO] [stdout] f7dc0506ba67ed408855f46d84f967c56e47a92c34d56ed3627bf57485ec8438
[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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] c034dabf436cb8184f7a581bb60810aeb7ea50bcd02c26ba02175e6ef2e279a3
[INFO] running `Command { std: "docker" "start" "-a" "c034dabf436cb8184f7a581bb60810aeb7ea50bcd02c26ba02175e6ef2e279a3", kill_on_drop: false }`
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.06s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/db_rehearsal-6f57152f276f66da)
[INFO] [stdout] 
[INFO] [stdout] running 8 tests
[INFO] [stdout] test capture::general_log::tests::skips_malformed_header_like_lines_instead_of_appending_them ... ok
[INFO] [stdout] test capture::general_log::tests::future_filter_layer_spec_skips_noise_and_optionally_scopes_connection_id ... ok
[INFO] [stdout] test capture::general_log::tests::preserves_blank_lines_inside_multiline_queries ... ok
[INFO] [stdout] test capture::general_log::tests::streams_queries_incrementally ... ok
[INFO] [stdout] test capture::general_log::tests::surfaces_non_utf8_binary_content_as_invalid_data ... ok
[INFO] [stdout] test capture::general_log::tests::classifies_admin_statements ... ok
[INFO] [stdout] test capture::general_log::tests::test_capture_general_log ... ok
[INFO] [stdout] test capture::general_log::tests::test_capture_mysql_8_general_log ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 8 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.85s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "c034dabf436cb8184f7a581bb60810aeb7ea50bcd02c26ba02175e6ef2e279a3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c034dabf436cb8184f7a581bb60810aeb7ea50bcd02c26ba02175e6ef2e279a3", kill_on_drop: false }`
[INFO] [stdout] c034dabf436cb8184f7a581bb60810aeb7ea50bcd02c26ba02175e6ef2e279a3
