[INFO] crate rustorm-cli 0.1.0 is already in cache [INFO] testing rustorm-cli-0.1.0 against beta-2020-07-24 for beta-1.46-1 [INFO] extracting crate rustorm-cli 0.1.0 into /workspace/builds/worker-1/source [INFO] validating manifest of crates.io crate rustorm-cli 0.1.0 on toolchain beta-2020-07-24 [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+beta-2020-07-24" "read-manifest" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] started tweaking crates.io crate rustorm-cli 0.1.0 [INFO] finished tweaking crates.io crate rustorm-cli 0.1.0 [INFO] tweaked toml for crates.io crate rustorm-cli 0.1.0 written to /workspace/builds/worker-1/source/Cargo.toml [INFO] crate crates.io crate rustorm-cli 0.1.0 already has a lockfile, it will not be regenerated [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+beta-2020-07-24" "fetch" "--locked" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/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_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env@sha256:a636fd89d022f18117e1dc8fb37a0a009933cdbbe082814857f0e2024962d47c" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2020-07-24" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 467d71b368fe37b83114a3dba3353e06d2cf50580aa5f2036be6f7479f321d76 [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" "467d71b368fe37b83114a3dba3353e06d2cf50580aa5f2036be6f7479f321d76", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "467d71b368fe37b83114a3dba3353e06d2cf50580aa5f2036be6f7479f321d76", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "467d71b368fe37b83114a3dba3353e06d2cf50580aa5f2036be6f7479f321d76", kill_on_drop: false }` [INFO] [stdout] 467d71b368fe37b83114a3dba3353e06d2cf50580aa5f2036be6f7479f321d76 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/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@sha256:a636fd89d022f18117e1dc8fb37a0a009933cdbbe082814857f0e2024962d47c" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2020-07-24" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 5a51c219afb3e37b252739d03bcd63475d58457d31dca41f6a1841e0a5409e8c [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" "5a51c219afb3e37b252739d03bcd63475d58457d31dca41f6a1841e0a5409e8c", kill_on_drop: false }` [INFO] [stderr] Compiling libc v0.2.65 [INFO] [stderr] Compiling syn v1.0.7 [INFO] [stderr] Compiling serde v1.0.102 [INFO] [stderr] Compiling smallvec v0.6.12 [INFO] [stderr] Compiling arrayvec v0.4.12 [INFO] [stderr] Compiling static_assertions v0.3.4 [INFO] [stderr] Compiling nix v0.15.0 [INFO] [stderr] Compiling bit-vec v0.6.1 [INFO] [stderr] Compiling mysql v16.1.0 [INFO] [stderr] Compiling nom v2.2.1 [INFO] [stderr] Compiling nom v1.2.4 [INFO] [stderr] Compiling dotenv v0.15.0 [INFO] [stderr] Compiling num-traits v0.2.8 [INFO] [stderr] Compiling num-integer v0.1.41 [INFO] [stderr] Compiling num-bigint v0.2.3 [INFO] [stderr] Compiling num-rational v0.2.2 [INFO] [stderr] Compiling num-iter v0.1.39 [INFO] [stderr] Compiling num-complex v0.2.3 [INFO] [stderr] Compiling owning_ref v0.3.3 [INFO] [stderr] Compiling unicode-normalization v0.1.8 [INFO] [stderr] Compiling lexical-core v0.4.6 [INFO] [stderr] Compiling lexical v2.2.2 [INFO] [stderr] Compiling block-buffer v0.7.3 [INFO] [stderr] Compiling meval v0.1.0 [INFO] [stderr] Compiling sha2 v0.8.0 [INFO] [stderr] Compiling num-traits v0.1.43 [INFO] [stderr] Compiling idna v0.2.0 [INFO] [stderr] Compiling idna v0.1.5 [INFO] [stderr] Compiling getrandom v0.1.13 [INFO] [stderr] Compiling rand v0.4.6 [INFO] [stderr] Compiling time v0.1.42 [INFO] [stderr] Compiling parking_lot_core v0.6.2 [INFO] [stderr] Compiling net2 v0.2.33 [INFO] [stderr] Compiling flate2 v1.0.12 [INFO] [stderr] Compiling atty v0.2.13 [INFO] [stderr] Compiling parking_lot v0.9.0 [INFO] [stderr] Compiling clap v2.33.0 [INFO] [stderr] Compiling rand_core v0.5.1 [INFO] [stderr] Compiling url v1.7.2 [INFO] [stderr] Compiling scheduled-thread-pool v0.2.2 [INFO] [stderr] Compiling url v2.1.0 [INFO] [stderr] Compiling rand_chacha v0.2.1 [INFO] [stderr] Compiling r2d2 v0.8.6 [INFO] [stderr] Compiling rand v0.3.23 [INFO] [stderr] Compiling parking_lot_core v0.2.14 [INFO] [stderr] Compiling rand v0.7.2 [INFO] [stderr] Compiling parking_lot v0.4.8 [INFO] [stderr] Compiling tree_magic v0.2.1 [INFO] [stderr] Compiling serde_derive v1.0.102 [INFO] [stderr] Compiling thiserror-impl v1.0.4 [INFO] [stderr] Compiling num v0.2.0 [INFO] [stderr] Compiling twox-hash v1.5.0 [INFO] [stderr] Compiling thiserror v1.0.4 [INFO] [stderr] Compiling chrono v0.4.9 [INFO] [stderr] Compiling serde_json v1.0.41 [INFO] [stderr] Compiling rust_decimal v1.0.3 [INFO] [stderr] Compiling bigdecimal v0.1.0 [INFO] [stderr] Compiling bigdecimal v0.0.14 [INFO] [stderr] Compiling geo v0.4.13 [INFO] [stderr] Compiling uuid v0.5.1 [INFO] [stderr] Compiling mysql_common v0.18.1 [INFO] [stderr] Compiling rustorm_dao v0.4.1 [INFO] [stderr] Compiling rustorm_codegen v0.3.1 [INFO] [stderr] Compiling r2d2_mysql v16.0.0 [INFO] [stderr] Compiling rustorm v0.15.2 [INFO] [stderr] Compiling rustorm-cli v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `ErrorKind` [INFO] [stdout] --> src/cli.rs:4:22 [INFO] [stdout] | [INFO] [stdout] 4 | use std::io::{Write, ErrorKind}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Value` [INFO] [stdout] --> src/main.rs:8:33 [INFO] [stdout] | [INFO] [stdout] 8 | use rustorm::{TableName, Table, Value}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::ops::Add` [INFO] [stdout] --> src/main.rs:9:5 [INFO] [stdout] | [INFO] [stdout] 9 | use std::ops::Add; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `pool` [INFO] [stdout] --> src/main.rs:52:14 [INFO] [stdout] | [INFO] [stdout] 52 | let (mut pool, mut em) = connect(table.get_database_url().as_str()); [INFO] [stdout] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pool` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `arg_matchs` [INFO] [stdout] --> src/main.rs:43:30 [INFO] [stdout] | [INFO] [stdout] 43 | ("mybatis-xml", Some(arg_matchs)) => { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_arg_matchs` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `databaseurl` [INFO] [stdout] --> src/main.rs:44:17 [INFO] [stdout] | [INFO] [stdout] 44 | let databaseurl = get_database_url(&matches); [INFO] [stdout] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_databaseurl` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/main.rs:52:14 [INFO] [stdout] | [INFO] [stdout] 52 | let (mut pool, mut em) = connect(table.get_database_url().as_str()); [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/db/mysql.rs:10:9 [INFO] [stdout] | [INFO] [stdout] 10 | let mut em = pool.em_mut(db_url).unwrap_or_else(|e| { [INFO] [stdout] | ----^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 8 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 1m 58s [INFO] running `Command { std: "docker" "inspect" "5a51c219afb3e37b252739d03bcd63475d58457d31dca41f6a1841e0a5409e8c", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "5a51c219afb3e37b252739d03bcd63475d58457d31dca41f6a1841e0a5409e8c", kill_on_drop: false }` [INFO] [stdout] 5a51c219afb3e37b252739d03bcd63475d58457d31dca41f6a1841e0a5409e8c [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/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@sha256:a636fd89d022f18117e1dc8fb37a0a009933cdbbe082814857f0e2024962d47c" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2020-07-24" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 59ccb16890550ea79657e09bdf116b89b5e26024bb7dda10b5a534b62813bb36 [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" "59ccb16890550ea79657e09bdf116b89b5e26024bb7dda10b5a534b62813bb36", kill_on_drop: false }` [INFO] [stderr] Compiling rustorm-cli v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `ErrorKind` [INFO] [stdout] --> src/cli.rs:4:22 [INFO] [stdout] | [INFO] [stdout] 4 | use std::io::{Write, ErrorKind}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Value` [INFO] [stdout] --> src/main.rs:8:33 [INFO] [stdout] | [INFO] [stdout] 8 | use rustorm::{TableName, Table, Value}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::ops::Add` [INFO] [stdout] --> src/main.rs:9:5 [INFO] [stdout] | [INFO] [stdout] 9 | use std::ops::Add; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `pool` [INFO] [stdout] --> src/main.rs:52:14 [INFO] [stdout] | [INFO] [stdout] 52 | let (mut pool, mut em) = connect(table.get_database_url().as_str()); [INFO] [stdout] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pool` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `arg_matchs` [INFO] [stdout] --> src/main.rs:43:30 [INFO] [stdout] | [INFO] [stdout] 43 | ("mybatis-xml", Some(arg_matchs)) => { [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_arg_matchs` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `databaseurl` [INFO] [stdout] --> src/main.rs:44:17 [INFO] [stdout] | [INFO] [stdout] 44 | let databaseurl = get_database_url(&matches); [INFO] [stdout] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_databaseurl` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/main.rs:52:14 [INFO] [stdout] | [INFO] [stdout] 52 | let (mut pool, mut em) = connect(table.get_database_url().as_str()); [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/db/mysql.rs:10:9 [INFO] [stdout] | [INFO] [stdout] 10 | let mut em = pool.em_mut(db_url).unwrap_or_else(|e| { [INFO] [stdout] | ----^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 8 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 2.18s [INFO] running `Command { std: "docker" "inspect" "59ccb16890550ea79657e09bdf116b89b5e26024bb7dda10b5a534b62813bb36", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "59ccb16890550ea79657e09bdf116b89b5e26024bb7dda10b5a534b62813bb36", kill_on_drop: false }` [INFO] [stdout] 59ccb16890550ea79657e09bdf116b89b5e26024bb7dda10b5a534b62813bb36 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/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@sha256:a636fd89d022f18117e1dc8fb37a0a009933cdbbe082814857f0e2024962d47c" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2020-07-24" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 09cae8595e4c3e06e57ad3385d27dfc2177e9ff4c2de60cadcf2c705f0b63eae [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" "09cae8595e4c3e06e57ad3385d27dfc2177e9ff4c2de60cadcf2c705f0b63eae", kill_on_drop: false }` [INFO] [stderr] warning: unused import: `ErrorKind` [INFO] [stderr] --> src/cli.rs:4:22 [INFO] [stderr] | [INFO] [stderr] 4 | use std::io::{Write, ErrorKind}; [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `Value` [INFO] [stderr] --> src/main.rs:8:33 [INFO] [stderr] | [INFO] [stderr] 8 | use rustorm::{TableName, Table, Value}; [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::ops::Add` [INFO] [stderr] --> src/main.rs:9:5 [INFO] [stderr] | [INFO] [stderr] 9 | use std::ops::Add; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused variable: `pool` [INFO] [stderr] --> src/main.rs:52:14 [INFO] [stderr] | [INFO] [stderr] 52 | let (mut pool, mut em) = connect(table.get_database_url().as_str()); [INFO] [stderr] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pool` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `arg_matchs` [INFO] [stderr] --> src/main.rs:43:30 [INFO] [stderr] | [INFO] [stderr] 43 | ("mybatis-xml", Some(arg_matchs)) => { [INFO] [stderr] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_arg_matchs` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `databaseurl` [INFO] [stderr] --> src/main.rs:44:17 [INFO] [stderr] | [INFO] [stderr] 44 | let databaseurl = get_database_url(&matches); [INFO] [stderr] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_databaseurl` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/main.rs:52:14 [INFO] [stderr] | [INFO] [stderr] 52 | let (mut pool, mut em) = connect(table.get_database_url().as_str()); [INFO] [stderr] | ----^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/db/mysql.rs:10:9 [INFO] [stderr] | [INFO] [stderr] 10 | let mut em = pool.em_mut(db_url).unwrap_or_else(|e| { [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: 8 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.56s [INFO] [stderr] Running /opt/rustwide/target/debug/deps/rustorm_cli-7ea333068e252054 [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 [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "09cae8595e4c3e06e57ad3385d27dfc2177e9ff4c2de60cadcf2c705f0b63eae", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "09cae8595e4c3e06e57ad3385d27dfc2177e9ff4c2de60cadcf2c705f0b63eae", kill_on_drop: false }` [INFO] [stdout] 09cae8595e4c3e06e57ad3385d27dfc2177e9ff4c2de60cadcf2c705f0b63eae