[INFO] updating cached repository https://github.com/syedkaleem29/rust-sql-parser [INFO] running `"git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "-c" "remote.origin.fetch=refs/heads/*:refs/heads/*" "fetch" "origin" "--force" "--prune"` [INFO] running `"git" "rev-parse" "HEAD"` [INFO] [stdout] a8ff5b32b0abbab448af6f0516d223591f9f32b9 [INFO] testing syedkaleem29/rust-sql-parser against beta-2020-06-03 for beta-1.45-1 [INFO] running `"git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsyedkaleem29%2Frust-sql-parser" "/workspace/builds/worker-6/source"` [INFO] [stderr] Cloning into '/workspace/builds/worker-6/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/syedkaleem29/rust-sql-parser on toolchain beta-2020-06-03 [INFO] running `"/workspace/cargo-home/bin/cargo" "+beta-2020-06-03" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started tweaking git repo https://github.com/syedkaleem29/rust-sql-parser [INFO] finished tweaking git repo https://github.com/syedkaleem29/rust-sql-parser [INFO] tweaked toml for git repo https://github.com/syedkaleem29/rust-sql-parser written to /workspace/builds/worker-6/source/Cargo.toml [INFO] crate git repo https://github.com/syedkaleem29/rust-sql-parser already has a lockfile, it will not be regenerated [INFO] running `"/workspace/cargo-home/bin/cargo" "+beta-2020-06-03" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/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" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2020-06-03" "build" "--frozen"` [INFO] [stdout] 117a5963eabd43f508eb26eee92621cc74fd80da83c13ceaf65b4439600a3878 [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `"docker" "start" "-a" "117a5963eabd43f508eb26eee92621cc74fd80da83c13ceaf65b4439600a3878"` [INFO] [stderr] sudo: setrlimit(RLIMIT_CORE): Operation not permitted [INFO] [stderr] Compiling sql-parser v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] warning: unused import: `std::str::FromStr` [INFO] [stderr] --> src/token.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std::str::FromStr; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `SQLParser` [INFO] [stderr] --> src/parser.rs:3:8 [INFO] [stderr] | [INFO] [stderr] 3 | struct SQLParser; [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Query` [INFO] [stderr] --> src/parser.rs:5:8 [INFO] [stderr] | [INFO] [stderr] 5 | struct Query { [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Column` [INFO] [stderr] --> src/parser.rs:11:8 [INFO] [stderr] | [INFO] [stderr] 11 | struct Column { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Table` [INFO] [stderr] --> src/parser.rs:16:8 [INFO] [stderr] | [INFO] [stderr] 16 | struct Table { [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: enum is never used: `QueryType` [INFO] [stderr] --> src/parser.rs:20:6 [INFO] [stderr] | [INFO] [stderr] 20 | enum QueryType{ [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `parser` [INFO] [stderr] --> src/parser.rs:27:5 [INFO] [stderr] | [INFO] [stderr] 27 | fn parser(query: String) -> Query { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `SELECT` [INFO] [stderr] --> src/token.rs:11:2 [INFO] [stderr] | [INFO] [stderr] 11 | SELECT, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `ALL` [INFO] [stderr] --> src/token.rs:12:2 [INFO] [stderr] | [INFO] [stderr] 12 | ALL, [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `FROM` [INFO] [stderr] --> src/token.rs:13:2 [INFO] [stderr] | [INFO] [stderr] 13 | FROM, [INFO] [stderr] | ^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `IDENTIFIER` [INFO] [stderr] --> src/token.rs:14:2 [INFO] [stderr] | [INFO] [stderr] 14 | IDENTIFIER, [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `tokenize` [INFO] [stderr] --> src/token.rs:19:9 [INFO] [stderr] | [INFO] [stderr] 19 | pub fn tokenize(query: String) -> Vec { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `makeToken` [INFO] [stderr] --> src/token.rs:28:5 [INFO] [stderr] | [INFO] [stderr] 28 | fn makeToken(str_token: &str) -> Token { [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: structure field `qType` should have a snake case name [INFO] [stderr] --> src/parser.rs:6:2 [INFO] [stderr] | [INFO] [stderr] 6 | qType: QueryType, [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `q_type` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: structure field `qCols` should have a snake case name [INFO] [stderr] --> src/parser.rs:7:2 [INFO] [stderr] | [INFO] [stderr] 7 | qCols: Column, [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `q_cols` [INFO] [stderr] [INFO] [stderr] warning: structure field `qFrom` should have a snake case name [INFO] [stderr] --> src/parser.rs:8:2 [INFO] [stderr] | [INFO] [stderr] 8 | qFrom: Table, [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `q_from` [INFO] [stderr] [INFO] [stderr] warning: structure field `tableName` should have a snake case name [INFO] [stderr] --> src/parser.rs:12:2 [INFO] [stderr] | [INFO] [stderr] 12 | tableName: String, [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `table_name` [INFO] [stderr] [INFO] [stderr] warning: structure field `columnName` should have a snake case name [INFO] [stderr] --> src/parser.rs:13:2 [INFO] [stderr] | [INFO] [stderr] 13 | columnName: String, [INFO] [stderr] | ^^^^^^^^^^ help: convert the identifier to snake case: `column_name` [INFO] [stderr] [INFO] [stderr] warning: structure field `tableName` should have a snake case name [INFO] [stderr] --> src/parser.rs:17:2 [INFO] [stderr] | [INFO] [stderr] 17 | tableName: String [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `table_name` [INFO] [stderr] [INFO] [stderr] warning: structure field `tokenType` should have a snake case name [INFO] [stderr] --> src/token.rs:6:2 [INFO] [stderr] | [INFO] [stderr] 6 | tokenType: TokenType, [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `token_type` [INFO] [stderr] [INFO] [stderr] warning: method `makeToken` should have a snake case name [INFO] [stderr] --> src/token.rs:28:5 [INFO] [stderr] | [INFO] [stderr] 28 | fn makeToken(str_token: &str) -> Token { [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `make_token` [INFO] [stderr] [INFO] [stderr] warning: 21 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 0.83s [INFO] running `"docker" "inspect" "117a5963eabd43f508eb26eee92621cc74fd80da83c13ceaf65b4439600a3878"` [INFO] running `"docker" "rm" "-f" "117a5963eabd43f508eb26eee92621cc74fd80da83c13ceaf65b4439600a3878"` [INFO] [stdout] 117a5963eabd43f508eb26eee92621cc74fd80da83c13ceaf65b4439600a3878 [INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/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" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2020-06-03" "test" "--frozen" "--no-run"` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] ffd5babab1dad4f65c909b5538117bcc8f085db0b9f4506d0fbe1dee6ec031e9 [INFO] running `"docker" "start" "-a" "ffd5babab1dad4f65c909b5538117bcc8f085db0b9f4506d0fbe1dee6ec031e9"` [INFO] [stderr] sudo: setrlimit(RLIMIT_CORE): Operation not permitted [INFO] [stderr] Compiling sql-parser v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] warning: unused import: `std::str::FromStr` [INFO] [stderr] --> src/token.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std::str::FromStr; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `SQLParser` [INFO] [stderr] --> src/parser.rs:3:8 [INFO] [stderr] | [INFO] [stderr] 3 | struct SQLParser; [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Query` [INFO] [stderr] --> src/parser.rs:5:8 [INFO] [stderr] | [INFO] [stderr] 5 | struct Query { [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Column` [INFO] [stderr] --> src/parser.rs:11:8 [INFO] [stderr] | [INFO] [stderr] 11 | struct Column { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Table` [INFO] [stderr] --> src/parser.rs:16:8 [INFO] [stderr] | [INFO] [stderr] 16 | struct Table { [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: enum is never used: `QueryType` [INFO] [stderr] --> src/parser.rs:20:6 [INFO] [stderr] | [INFO] [stderr] 20 | enum QueryType{ [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `parser` [INFO] [stderr] --> src/parser.rs:27:5 [INFO] [stderr] | [INFO] [stderr] 27 | fn parser(query: String) -> Query { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `SELECT` [INFO] [stderr] --> src/token.rs:11:2 [INFO] [stderr] | [INFO] [stderr] 11 | SELECT, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `ALL` [INFO] [stderr] --> src/token.rs:12:2 [INFO] [stderr] | [INFO] [stderr] 12 | ALL, [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `FROM` [INFO] [stderr] --> src/token.rs:13:2 [INFO] [stderr] | [INFO] [stderr] 13 | FROM, [INFO] [stderr] | ^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `IDENTIFIER` [INFO] [stderr] --> src/token.rs:14:2 [INFO] [stderr] | [INFO] [stderr] 14 | IDENTIFIER, [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `tokenize` [INFO] [stderr] --> src/token.rs:19:9 [INFO] [stderr] | [INFO] [stderr] 19 | pub fn tokenize(query: String) -> Vec { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `makeToken` [INFO] [stderr] --> src/token.rs:28:5 [INFO] [stderr] | [INFO] [stderr] 28 | fn makeToken(str_token: &str) -> Token { [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: structure field `qType` should have a snake case name [INFO] [stderr] --> src/parser.rs:6:2 [INFO] [stderr] | [INFO] [stderr] 6 | qType: QueryType, [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `q_type` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: structure field `qCols` should have a snake case name [INFO] [stderr] --> src/parser.rs:7:2 [INFO] [stderr] | [INFO] [stderr] 7 | qCols: Column, [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `q_cols` [INFO] [stderr] [INFO] [stderr] warning: structure field `qFrom` should have a snake case name [INFO] [stderr] --> src/parser.rs:8:2 [INFO] [stderr] | [INFO] [stderr] 8 | qFrom: Table, [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `q_from` [INFO] [stderr] [INFO] [stderr] warning: structure field `tableName` should have a snake case name [INFO] [stderr] --> src/parser.rs:12:2 [INFO] [stderr] | [INFO] [stderr] 12 | tableName: String, [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `table_name` [INFO] [stderr] [INFO] [stderr] warning: structure field `columnName` should have a snake case name [INFO] [stderr] --> src/parser.rs:13:2 [INFO] [stderr] | [INFO] [stderr] 13 | columnName: String, [INFO] [stderr] | ^^^^^^^^^^ help: convert the identifier to snake case: `column_name` [INFO] [stderr] [INFO] [stderr] warning: structure field `tableName` should have a snake case name [INFO] [stderr] --> src/parser.rs:17:2 [INFO] [stderr] | [INFO] [stderr] 17 | tableName: String [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `table_name` [INFO] [stderr] [INFO] [stderr] warning: structure field `tokenType` should have a snake case name [INFO] [stderr] --> src/token.rs:6:2 [INFO] [stderr] | [INFO] [stderr] 6 | tokenType: TokenType, [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `token_type` [INFO] [stderr] [INFO] [stderr] warning: method `makeToken` should have a snake case name [INFO] [stderr] --> src/token.rs:28:5 [INFO] [stderr] | [INFO] [stderr] 28 | fn makeToken(str_token: &str) -> Token { [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `make_token` [INFO] [stderr] [INFO] [stderr] warning: 21 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::str::FromStr` [INFO] [stderr] --> src/token.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std::str::FromStr; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: field is never read: `qType` [INFO] [stderr] --> src/parser.rs:6:2 [INFO] [stderr] | [INFO] [stderr] 6 | qType: QueryType, [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: field is never read: `qCols` [INFO] [stderr] --> src/parser.rs:7:2 [INFO] [stderr] | [INFO] [stderr] 7 | qCols: Column, [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `qFrom` [INFO] [stderr] --> src/parser.rs:8:2 [INFO] [stderr] | [INFO] [stderr] 8 | qFrom: Table, [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `tableName` [INFO] [stderr] --> src/parser.rs:12:2 [INFO] [stderr] | [INFO] [stderr] 12 | tableName: String, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `columnName` [INFO] [stderr] --> src/parser.rs:13:2 [INFO] [stderr] | [INFO] [stderr] 13 | columnName: String, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `tableName` [INFO] [stderr] --> src/parser.rs:17:2 [INFO] [stderr] | [INFO] [stderr] 17 | tableName: String [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `SELECT` [INFO] [stderr] --> src/parser.rs:21:2 [INFO] [stderr] | [INFO] [stderr] 21 | SELECT, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `UPDATE` [INFO] [stderr] --> src/parser.rs:22:2 [INFO] [stderr] | [INFO] [stderr] 22 | UPDATE, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `DELETE` [INFO] [stderr] --> src/parser.rs:23:2 [INFO] [stderr] | [INFO] [stderr] 23 | DELETE [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: structure field `qType` should have a snake case name [INFO] [stderr] --> src/parser.rs:6:2 [INFO] [stderr] | [INFO] [stderr] 6 | qType: QueryType, [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `q_type` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: structure field `qCols` should have a snake case name [INFO] [stderr] --> src/parser.rs:7:2 [INFO] [stderr] | [INFO] [stderr] 7 | qCols: Column, [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `q_cols` [INFO] [stderr] [INFO] [stderr] warning: structure field `qFrom` should have a snake case name [INFO] [stderr] --> src/parser.rs:8:2 [INFO] [stderr] | [INFO] [stderr] 8 | qFrom: Table, [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `q_from` [INFO] [stderr] [INFO] [stderr] warning: structure field `tableName` should have a snake case name [INFO] [stderr] --> src/parser.rs:12:2 [INFO] [stderr] | [INFO] [stderr] 12 | tableName: String, [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `table_name` [INFO] [stderr] [INFO] [stderr] warning: structure field `columnName` should have a snake case name [INFO] [stderr] --> src/parser.rs:13:2 [INFO] [stderr] | [INFO] [stderr] 13 | columnName: String, [INFO] [stderr] | ^^^^^^^^^^ help: convert the identifier to snake case: `column_name` [INFO] [stderr] [INFO] [stderr] warning: structure field `tableName` should have a snake case name [INFO] [stderr] --> src/parser.rs:17:2 [INFO] [stderr] | [INFO] [stderr] 17 | tableName: String [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `table_name` [INFO] [stderr] [INFO] [stderr] warning: structure field `tokenType` should have a snake case name [INFO] [stderr] --> src/token.rs:6:2 [INFO] [stderr] | [INFO] [stderr] 6 | tokenType: TokenType, [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `token_type` [INFO] [stderr] [INFO] [stderr] warning: method `makeToken` should have a snake case name [INFO] [stderr] --> src/token.rs:28:5 [INFO] [stderr] | [INFO] [stderr] 28 | fn makeToken(str_token: &str) -> Token { [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `make_token` [INFO] [stderr] [INFO] [stderr] warning: 18 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.87s [INFO] running `"docker" "inspect" "ffd5babab1dad4f65c909b5538117bcc8f085db0b9f4506d0fbe1dee6ec031e9"` [INFO] running `"docker" "rm" "-f" "ffd5babab1dad4f65c909b5538117bcc8f085db0b9f4506d0fbe1dee6ec031e9"` [INFO] [stdout] ffd5babab1dad4f65c909b5538117bcc8f085db0b9f4506d0fbe1dee6ec031e9 [INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/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" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2020-06-03" "test" "--frozen"` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] 02c304c4b3acfb77d6a6a66cced087e5729df73df03864bd2bd16f7e31d4d431 [INFO] running `"docker" "start" "-a" "02c304c4b3acfb77d6a6a66cced087e5729df73df03864bd2bd16f7e31d4d431"` [INFO] [stderr] sudo: setrlimit(RLIMIT_CORE): Operation not permitted [INFO] [stderr] warning: unused import: `std::str::FromStr` [INFO] [stderr] --> src/token.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std::str::FromStr; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: field is never read: `qType` [INFO] [stderr] --> src/parser.rs:6:2 [INFO] [stderr] | [INFO] [stderr] 6 | qType: QueryType, [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: field is never read: `qCols` [INFO] [stderr] --> src/parser.rs:7:2 [INFO] [stderr] | [INFO] [stderr] 7 | qCols: Column, [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `qFrom` [INFO] [stderr] --> src/parser.rs:8:2 [INFO] [stderr] | [INFO] [stderr] 8 | qFrom: Table, [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `tableName` [INFO] [stderr] --> src/parser.rs:12:2 [INFO] [stderr] | [INFO] [stderr] 12 | tableName: String, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `columnName` [INFO] [stderr] --> src/parser.rs:13:2 [INFO] [stderr] | [INFO] [stderr] 13 | columnName: String, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `tableName` [INFO] [stderr] --> src/parser.rs:17:2 [INFO] [stderr] | [INFO] [stderr] 17 | tableName: String [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `SELECT` [INFO] [stderr] --> src/parser.rs:21:2 [INFO] [stderr] | [INFO] [stderr] 21 | SELECT, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `UPDATE` [INFO] [stderr] --> src/parser.rs:22:2 [INFO] [stderr] | [INFO] [stderr] 22 | UPDATE, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `DELETE` [INFO] [stderr] --> src/parser.rs:23:2 [INFO] [stderr] | [INFO] [stderr] 23 | DELETE [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: structure field `qType` should have a snake case name [INFO] [stderr] --> src/parser.rs:6:2 [INFO] [stderr] | [INFO] [stderr] 6 | qType: QueryType, [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `q_type` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: structure field `qCols` should have a snake case name [INFO] [stderr] --> src/parser.rs:7:2 [INFO] [stderr] | [INFO] [stderr] 7 | qCols: Column, [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `q_cols` [INFO] [stderr] [INFO] [stderr] warning: structure field `qFrom` should have a snake case name [INFO] [stderr] --> src/parser.rs:8:2 [INFO] [stderr] | [INFO] [stderr] 8 | qFrom: Table, [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `q_from` [INFO] [stderr] [INFO] [stderr] warning: structure field `tableName` should have a snake case name [INFO] [stderr] --> src/parser.rs:12:2 [INFO] [stderr] | [INFO] [stderr] 12 | tableName: String, [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `table_name` [INFO] [stderr] [INFO] [stderr] warning: structure field `columnName` should have a snake case name [INFO] [stderr] --> src/parser.rs:13:2 [INFO] [stderr] | [INFO] [stderr] 13 | columnName: String, [INFO] [stderr] | ^^^^^^^^^^ help: convert the identifier to snake case: `column_name` [INFO] [stderr] [INFO] [stderr] warning: structure field `tableName` should have a snake case name [INFO] [stderr] --> src/parser.rs:17:2 [INFO] [stderr] | [INFO] [stderr] 17 | tableName: String [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `table_name` [INFO] [stderr] [INFO] [stderr] warning: structure field `tokenType` should have a snake case name [INFO] [stderr] --> src/token.rs:6:2 [INFO] [stderr] | [INFO] [stderr] 6 | tokenType: TokenType, [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `token_type` [INFO] [stderr] [INFO] [stderr] warning: method `makeToken` should have a snake case name [INFO] [stderr] --> src/token.rs:28:5 [INFO] [stderr] | [INFO] [stderr] 28 | fn makeToken(str_token: &str) -> Token { [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `make_token` [INFO] [stderr] [INFO] [stderr] warning: 18 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::str::FromStr` [INFO] [stderr] --> src/token.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std::str::FromStr; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `SQLParser` [INFO] [stderr] --> src/parser.rs:3:8 [INFO] [stderr] | [INFO] [stderr] 3 | struct SQLParser; [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Query` [INFO] [stderr] --> src/parser.rs:5:8 [INFO] [stderr] | [INFO] [stderr] 5 | struct Query { [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Column` [INFO] [stderr] --> src/parser.rs:11:8 [INFO] [stderr] | [INFO] [stderr] 11 | struct Column { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Table` [INFO] [stderr] --> src/parser.rs:16:8 [INFO] [stderr] | [INFO] [stderr] 16 | struct Table { [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: enum is never used: `QueryType` [INFO] [stderr] --> src/parser.rs:20:6 [INFO] [stderr] | [INFO] [stderr] 20 | enum QueryType{ [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `parser` [INFO] [stderr] --> src/parser.rs:27:5 [INFO] [stderr] | [INFO] [stderr] 27 | fn parser(query: String) -> Query { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `SELECT` [INFO] [stderr] --> src/token.rs:11:2 [INFO] [stderr] | [INFO] [stderr] 11 | SELECT, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `ALL` [INFO] [stderr] --> src/token.rs:12:2 [INFO] [stderr] | [INFO] [stderr] 12 | ALL, [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `FROM` [INFO] [stderr] --> src/token.rs:13:2 [INFO] [stderr] | [INFO] [stderr] 13 | FROM, [INFO] [stderr] | ^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `IDENTIFIER` [INFO] [stderr] --> src/token.rs:14:2 [INFO] [stderr] | [INFO] [stderr] 14 | IDENTIFIER, [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stdout] [INFO] [stdout] running 1 test [INFO] [stderr] warning: associated function is never used: `tokenize` [INFO] [stderr] --> src/token.rs:19:9 [INFO] [stderr] | [INFO] [stderr] 19 | pub fn tokenize(query: String) -> Vec { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `makeToken` [INFO] [stderr] --> src/token.rs:28:5 [INFO] [stderr] | [INFO] [stderr] 28 | fn makeToken(str_token: &str) -> Token { [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: structure field `qType` should have a snake case name [INFO] [stderr] --> src/parser.rs:6:2 [INFO] [stderr] | [INFO] [stderr] 6 | qType: QueryType, [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `q_type` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: structure field `qCols` should have a snake case name [INFO] [stderr] --> src/parser.rs:7:2 [INFO] [stderr] | [INFO] [stderr] 7 | qCols: Column, [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `q_cols` [INFO] [stderr] [INFO] [stderr] warning: structure field `qFrom` should have a snake case name [INFO] [stderr] --> src/parser.rs:8:2 [INFO] [stderr] | [INFO] [stderr] 8 | qFrom: Table, [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `q_from` [INFO] [stderr] [INFO] [stderr] warning: structure field `tableName` should have a snake case name [INFO] [stderr] --> src/parser.rs:12:2 [INFO] [stderr] | [INFO] [stderr] 12 | tableName: String, [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `table_name` [INFO] [stderr] [INFO] [stderr] warning: structure field `columnName` should have a snake case name [INFO] [stderr] --> src/parser.rs:13:2 [INFO] [stderr] | [INFO] [stderr] 13 | columnName: String, [INFO] [stderr] | ^^^^^^^^^^ help: convert the identifier to snake case: `column_name` [INFO] [stderr] [INFO] [stderr] warning: structure field `tableName` should have a snake case name [INFO] [stderr] --> src/parser.rs:17:2 [INFO] [stderr] | [INFO] [stderr] 17 | tableName: String [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `table_name` [INFO] [stderr] [INFO] [stderr] warning: structure field `tokenType` should have a snake case name [INFO] [stderr] --> src/token.rs:6:2 [INFO] [stderr] | [INFO] [stderr] 6 | tokenType: TokenType, [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `token_type` [INFO] [stderr] [INFO] [stderr] warning: method `makeToken` should have a snake case name [INFO] [stderr] --> src/token.rs:28:5 [INFO] [stderr] | [INFO] [stderr] 28 | fn makeToken(str_token: &str) -> Token { [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `make_token` [INFO] [stderr] [INFO] [stderr] warning: 21 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.01s [INFO] [stderr] Running /opt/rustwide/target/debug/deps/sql_parser-9016e52e1ac1b3b6 [INFO] [stdout] test parser::test::test_parser ... FAILED [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] [INFO] [stdout] ---- parser::test::test_parser stdout ---- [INFO] [stdout] Token { token: "SELECT", tokenType: SELECT } [INFO] [stdout] Token { token: "*", tokenType: ALL } [INFO] [stdout] Token { token: "FROM", tokenType: FROM } [INFO] [stdout] Token { token: "Table;", tokenType: IDENTIFIER } [INFO] [stdout] thread 'parser::test::test_parser' panicked at 'not implemented', src/parser.rs:32:9 [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x562e04fee825 - backtrace::backtrace::libunwind::trace::h07c956be65d9b461 [INFO] [stdout] at /cargo/registry/src/github.com-1ecc6299db9ec823/backtrace-0.3.46/src/backtrace/libunwind.rs:86 [INFO] [stdout] 1: 0x562e04fee825 - backtrace::backtrace::trace_unsynchronized::h2fdb9e4177ad4d20 [INFO] [stdout] at /cargo/registry/src/github.com-1ecc6299db9ec823/backtrace-0.3.46/src/backtrace/mod.rs:66 [INFO] [stdout] 2: 0x562e04fee825 - std::sys_common::backtrace::_print_fmt::ha62d8426311107ac [INFO] [stdout] at src/libstd/sys_common/backtrace.rs:78 [INFO] [stdout] 3: 0x562e04fee825 - ::fmt::h3ec6bdab62f1e8d9 [INFO] [stdout] at src/libstd/sys_common/backtrace.rs:59 [INFO] [stdout] 4: 0x562e050165fc - core::fmt::write::h935cb0ed4078a853 [INFO] [stdout] at src/libcore/fmt/mod.rs:1076 [INFO] [stdout] 5: 0x562e04fa2a65 - std::io::Write::write_fmt::h944a31ab04b0dfe4 [INFO] [stdout] at /rustc/b7dc83a3f6ca9746fb3d121761c3605477b77d90/src/libstd/io/mod.rs:1537 [INFO] [stdout] 6: 0x562e04fe8d61 - std::io::impls::>::write_fmt::h6bd94c41a9c566d2 [INFO] [stdout] at src/libstd/io/impls.rs:176 [INFO] [stdout] 7: 0x562e04ff1050 - std::sys_common::backtrace::_print::h460db802d801ccf8 [INFO] [stdout] at src/libstd/sys_common/backtrace.rs:62 [INFO] [stdout] 8: 0x562e04ff1050 - std::sys_common::backtrace::print::h399d664f56640530 [INFO] [stdout] at src/libstd/sys_common/backtrace.rs:49 [INFO] [stdout] 9: 0x562e04ff1050 - std::panicking::default_hook::{{closure}}::hc6dfd87957c765b8 [INFO] [stdout] at src/libstd/panicking.rs:198 [INFO] [stdout] 10: 0x562e04ff0d4a - std::panicking::default_hook::hfdceba6d6d1a18ae [INFO] [stdout] at src/libstd/panicking.rs:215 [INFO] [stdout] 11: 0x562e04ff1687 - std::panicking::rust_panic_with_hook::hd01e282bff1b1e63 [INFO] [stdout] at src/libstd/panicking.rs:486 [INFO] [stdout] 12: 0x562e04f9fe77 - std::panicking::begin_panic::h995074163fabc2ab [INFO] [stdout] at /rustc/b7dc83a3f6ca9746fb3d121761c3605477b77d90/src/libstd/panicking.rs:410 [INFO] [stdout] 13: 0x562e04fa0760 - sql_parser::parser::SQLParser::parser::h0883ab735c3c0cca [INFO] [stdout] at src/parser.rs:32 [INFO] [stdout] 14: 0x562e04f9c0e0 - sql_parser::parser::test::test_parser::ha550dae7281c13e7 [INFO] [stdout] at src/parser.rs:44 [INFO] [stdout] 15: 0x562e04f9c07a - sql_parser::parser::test::test_parser::{{closure}}::h108a47fd037d44e3 [INFO] [stdout] at src/parser.rs:41 [INFO] [stdout] 16: 0x562e04f9b7ee - core::ops::function::FnOnce::call_once::h88cc05beb4c81f4e [INFO] [stdout] at /rustc/b7dc83a3f6ca9746fb3d121761c3605477b77d90/src/libcore/ops/function.rs:232 [INFO] [stdout] 17: 0x562e04fc9e52 - as core::ops::function::FnOnce>::call_once::hd23431bd7b767a0c [INFO] [stdout] at /rustc/b7dc83a3f6ca9746fb3d121761c3605477b77d90/src/liballoc/boxed.rs:1076 [INFO] [stdout] 18: 0x562e04fc9e52 - as core::ops::function::FnOnce<()>>::call_once::h6986d2e83b783a4e [INFO] [stdout] at /rustc/b7dc83a3f6ca9746fb3d121761c3605477b77d90/src/libstd/panic.rs:318 [INFO] [stdout] 19: 0x562e04fc9e52 - std::panicking::try::do_call::haee67871ebe8ee92 [INFO] [stdout] at /rustc/b7dc83a3f6ca9746fb3d121761c3605477b77d90/src/libstd/panicking.rs:297 [INFO] [stdout] 20: 0x562e04fc9e52 - std::panicking::try::hcba534043f17f42d [INFO] [stdout] at /rustc/b7dc83a3f6ca9746fb3d121761c3605477b77d90/src/libstd/panicking.rs:274 [INFO] [stdout] 21: 0x562e04fc9e52 - std::panic::catch_unwind::h6908c2ae7517b434 [INFO] [stdout] at /rustc/b7dc83a3f6ca9746fb3d121761c3605477b77d90/src/libstd/panic.rs:394 [INFO] [stdout] 22: 0x562e04fc9e52 - test::run_test_in_process::h66277a63b8267865 [INFO] [stdout] at src/libtest/lib.rs:541 [INFO] [stdout] 23: 0x562e04fc9e52 - test::run_test::run_test_inner::{{closure}}::h591f321b83c3f302 [INFO] [stdout] at src/libtest/lib.rs:450 [INFO] [stdout] 24: 0x562e04fa1f26 - std::sys_common::backtrace::__rust_begin_short_backtrace::h843e47ea29613666 [INFO] [stdout] at /rustc/b7dc83a3f6ca9746fb3d121761c3605477b77d90/src/libstd/sys_common/backtrace.rs:130 [INFO] [stdout] 25: 0x562e04fa74c5 - std::thread::Builder::spawn_unchecked::{{closure}}::{{closure}}::ha6c43669df0cbe25 [INFO] [stdout] at /rustc/b7dc83a3f6ca9746fb3d121761c3605477b77d90/src/libstd/thread/mod.rs:475 [INFO] [stdout] 26: 0x562e04fa74c5 - as core::ops::function::FnOnce<()>>::call_once::hc86e5439e615a14a [INFO] [stdout] at /rustc/b7dc83a3f6ca9746fb3d121761c3605477b77d90/src/libstd/panic.rs:318 [INFO] [stdout] 27: 0x562e04fa74c5 - std::panicking::try::do_call::h4b45bcf4d5d82a80 [INFO] [stdout] at /rustc/b7dc83a3f6ca9746fb3d121761c3605477b77d90/src/libstd/panicking.rs:297 [INFO] [stdout] 28: 0x562e04fa74c5 - std::panicking::try::h297c0c407d3f8196 [INFO] [stdout] at /rustc/b7dc83a3f6ca9746fb3d121761c3605477b77d90/src/libstd/panicking.rs:274 [INFO] [stdout] 29: 0x562e04fa74c5 - std::panic::catch_unwind::h877baa9fbef2eafe [INFO] [stdout] at /rustc/b7dc83a3f6ca9746fb3d121761c3605477b77d90/src/libstd/panic.rs:394 [INFO] [stdout] 30: 0x562e04fa74c5 - std::thread::Builder::spawn_unchecked::{{closure}}::hdb000626ad29158a [INFO] [stdout] at /rustc/b7dc83a3f6ca9746fb3d121761c3605477b77d90/src/libstd/thread/mod.rs:474 [INFO] [stdout] 31: 0x562e04fa74c5 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h87e786b011f05b5c [INFO] [stdout] at /rustc/b7dc83a3f6ca9746fb3d121761c3605477b77d90/src/libcore/ops/function.rs:232 [INFO] [stdout] 32: 0x562e04ff794a - as core::ops::function::FnOnce>::call_once::hfc5c0e64036d1b09 [INFO] [stdout] at /rustc/b7dc83a3f6ca9746fb3d121761c3605477b77d90/src/liballoc/boxed.rs:1076 [INFO] [stdout] 33: 0x562e04ff794a - as core::ops::function::FnOnce>::call_once::hf3d73184efc070c1 [INFO] [stdout] at /rustc/b7dc83a3f6ca9746fb3d121761c3605477b77d90/src/liballoc/boxed.rs:1076 [INFO] [stdout] 34: 0x562e04ff794a - std::sys::unix::thread::Thread::new::thread_start::hb9eb749d91dfe8e2 [INFO] [stdout] at src/libstd/sys/unix/thread.rs:87 [INFO] [stdout] 35: 0x7fbd4dbf7609 - start_thread [INFO] [stdout] 36: 0x7fbd4db03103 - __clone [INFO] [stdout] 37: 0x0 - [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] parser::test::test_parser [INFO] [stdout] [INFO] [stdout] test result: FAILED. 0 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out [INFO] [stdout] [INFO] [stderr] error: test failed, to rerun pass '--lib' [INFO] running `"docker" "inspect" "02c304c4b3acfb77d6a6a66cced087e5729df73df03864bd2bd16f7e31d4d431"` [INFO] running `"docker" "rm" "-f" "02c304c4b3acfb77d6a6a66cced087e5729df73df03864bd2bd16f7e31d4d431"` [INFO] [stdout] 02c304c4b3acfb77d6a6a66cced087e5729df73df03864bd2bd16f7e31d4d431