[INFO] updating cached repository https://github.com/ezksd/combinator
[INFO] running `Command { std: "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", kill_on_drop: false }`
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] a2989e2e8fc92c9c8b1b4c949d9d8cc0b4de1986
[INFO] documenting ezksd/combinator against try#66dfc4e010913fbed0c4ea91fc2c010004b0f441 for pr-73566
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fezksd%2Fcombinator" "/workspace/builds/worker-8/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-8/source'...
[INFO] [stderr] done.
[INFO] validating manifest of git repo https://github.com/ezksd/combinator on toolchain 66dfc4e010913fbed0c4ea91fc2c010004b0f441
[INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+66dfc4e010913fbed0c4ea91fc2c010004b0f441" "read-manifest" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] started tweaking git repo https://github.com/ezksd/combinator
[INFO] finished tweaking git repo https://github.com/ezksd/combinator
[INFO] tweaked toml for git repo https://github.com/ezksd/combinator written to /workspace/builds/worker-8/source/Cargo.toml
[INFO] crate git repo https://github.com/ezksd/combinator already has a lockfile, it will not be regenerated
[INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+66dfc4e010913fbed0c4ea91fc2c010004b0f441" "fetch" "--locked" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-8/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-8/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:819119df93c0f5eca3f29186f14981ef29945a311854d7222af07488600a2584" "/opt/rustwide/cargo-home/bin/cargo" "+66dfc4e010913fbed0c4ea91fc2c010004b0f441" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap.
[INFO] [stdout] ab0315fd72101d961bd196989d4edb123422d3d856bae291406b3fab76b3d3d3
[INFO] running `Command { std: "docker" "start" "-a" "ab0315fd72101d961bd196989d4edb123422d3d856bae291406b3fab76b3d3d3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "ab0315fd72101d961bd196989d4edb123422d3d856bae291406b3fab76b3d3d3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ab0315fd72101d961bd196989d4edb123422d3d856bae291406b3fab76b3d3d3", kill_on_drop: false }`
[INFO] [stdout] ab0315fd72101d961bd196989d4edb123422d3d856bae291406b3fab76b3d3d3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-8/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-8/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" "RUSTDOCFLAGS=--cap-lints=forbid" "-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:819119df93c0f5eca3f29186f14981ef29945a311854d7222af07488600a2584" "/opt/rustwide/cargo-home/bin/cargo" "+66dfc4e010913fbed0c4ea91fc2c010004b0f441" "doc" "--frozen" "--no-deps" "--document-private-items" "--message-format=json", kill_on_drop: false }`
[INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap.
[INFO] [stdout] 2816286bf436f3ea0da8ef97597b0c2229f2262bc29387f5982d748961b48bd3
[INFO] running `Command { std: "docker" "start" "-a" "2816286bf436f3ea0da8ef97597b0c2229f2262bc29387f5982d748961b48bd3", kill_on_drop: false }`
[INFO] [stderr] Documenting combinator v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] error[E0495]: cannot infer an appropriate lifetime for lifetime parameter `'a` due to conflicting requirements
[INFO] [stdout] --> src/parser/chars.rs:18:16
[INFO] [stdout] |
[INFO] [stdout] 18 | let head = digit().flat_map(|i| if i == 0 { empty() } else { pure(i) });
[INFO] [stdout] | ^^^^^
[INFO] [stdout] |
[INFO] [stdout] note: first, the lifetime cannot outlive the lifetime `'a` as defined on the function body at 17:15...
[INFO] [stdout] --> src/parser/chars.rs:17:15
[INFO] [stdout] |
[INFO] [stdout] 17 | pub fn number<'a>() -> impl Parser {
[INFO] [stdout] | ^^
[INFO] [stdout] note: ...so that the types are compatible
[INFO] [stdout] --> src/parser/chars.rs:17:24
[INFO] [stdout] |
[INFO] [stdout] 17 | pub fn number<'a>() -> impl Parser {
[INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] = note: expected `&str`
[INFO] [stdout] found `&'a str`
[INFO] [stdout] = note: but, the lifetime must be valid for the static lifetime...
[INFO] [stdout] note: ...so that the expression is assignable
[INFO] [stdout] --> src/parser/chars.rs:18:49
[INFO] [stdout] |
[INFO] [stdout] 18 | let head = digit().flat_map(|i| if i == 0 { empty() } else { pure(i) });
[INFO] [stdout] | ^^^^^^^
[INFO] [stdout] = note: expected `std::boxed::Box<(dyn parser::Parser + 'static)>`
[INFO] [stdout] found `std::boxed::Box>`
[INFO] [stdout]
[INFO] [stdout]
[INFO] [stdout] error[E0495]: cannot infer an appropriate lifetime due to conflicting requirements
[INFO] [stdout] --> src/parser/chars.rs:41:5
[INFO] [stdout] |
[INFO] [stdout] 41 | item().flat_map(move |x| if f(x) { pure(x) } else { empty() })
[INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] |
[INFO] [stdout] note: first, the lifetime cannot outlive the lifetime `'a` as defined on the function body at 37:12...
[INFO] [stdout] --> src/parser/chars.rs:37:12
[INFO] [stdout] |
[INFO] [stdout] 37 | pub fn sat<'a, F>(f: F) -> impl Parser
[INFO] [stdout] | ^^
[INFO] [stdout] note: ...so that the types are compatible
[INFO] [stdout] --> src/parser/chars.rs:37:28
[INFO] [stdout] |
[INFO] [stdout] 37 | pub fn sat<'a, F>(f: F) -> impl Parser
[INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] = note: expected `&str`
[INFO] [stdout] found `&'a str`
[INFO] [stdout] = note: but, the lifetime must be valid for the static lifetime...
[INFO] [stdout] note: ...so that the expression is assignable
[INFO] [stdout] --> src/parser/chars.rs:41:40
[INFO] [stdout] |
[INFO] [stdout] 41 | item().flat_map(move |x| if f(x) { pure(x) } else { empty() })
[INFO] [stdout] | ^^^^^^^
[INFO] [stdout] = note: expected `std::boxed::Box<(dyn parser::Parser + 'static)>`
[INFO] [stdout] found `std::boxed::Box>`
[INFO] [stdout]
[INFO] [stdout]
[INFO] [stdout] error[E0495]: cannot infer an appropriate lifetime for lifetime parameter `'a` due to conflicting requirements
[INFO] [stdout] --> src/parser/chars.rs:45:16
[INFO] [stdout] |
[INFO] [stdout] 45 | many1(any!(chr('_'), sat(char::is_alphanumeric))).map(|x| collect(&x))
[INFO] [stdout] | ^^^
[INFO] [stdout] |
[INFO] [stdout] note: first, the lifetime cannot outlive the lifetime `'a` as defined on the function body at 44:12...
[INFO] [stdout] --> src/parser/chars.rs:44:12
[INFO] [stdout] |
[INFO] [stdout] 44 | pub fn var<'a>() -> impl Parser {
[INFO] [stdout] | ^^
[INFO] [stdout] note: ...so that the types are compatible
[INFO] [stdout] --> src/parser/chars.rs:44:21
[INFO] [stdout] |
[INFO] [stdout] 44 | pub fn var<'a>() -> impl Parser {
[INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] = note: expected `&str`
[INFO] [stdout] found `&'a str`
[INFO] [stdout] = note: but, the lifetime must be valid for the static lifetime...
[INFO] [stdout] note: ...so that the expression is assignable
[INFO] [stdout] --> src/parser/mod.rs:74:17
[INFO] [stdout] |
[INFO] [stdout] 74 | Any(v)
[INFO] [stdout] | ^
[INFO] [stdout] |
[INFO] [stdout] ::: src/parser/chars.rs:45:11
[INFO] [stdout] |
[INFO] [stdout] 45 | many1(any!(chr('_'), sat(char::is_alphanumeric))).map(|x| collect(&x))
[INFO] [stdout] | ------------------------------------------ in this macro invocation
[INFO] [stdout] = note: expected `std::vec::Vec + 'static)>>`
[INFO] [stdout] found `std::vec::Vec>>`
[INFO] [stdout] = note: this error originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout]
[INFO] [stdout]
[INFO] [stdout] error[E0495]: cannot infer an appropriate lifetime for lifetime parameter `'a` due to conflicting requirements
[INFO] [stdout] --> src/parser/chars.rs:51:16
[INFO] [stdout] |
[INFO] [stdout] 51 | v.push(chr(c).boxed());
[INFO] [stdout] | ^^^
[INFO] [stdout] |
[INFO] [stdout] note: first, the lifetime cannot outlive the lifetime `'a` as defined on the function body at 48:15...
[INFO] [stdout] --> src/parser/chars.rs:48:15
[INFO] [stdout] |
[INFO] [stdout] 48 | pub fn letter<'a>(s: &str) -> impl Parser {
[INFO] [stdout] | ^^
[INFO] [stdout] note: ...so that the types are compatible
[INFO] [stdout] --> src/parser/chars.rs:48:31
[INFO] [stdout] |
[INFO] [stdout] 48 | pub fn letter<'a>(s: &str) -> impl Parser {
[INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] = note: expected `&str`
[INFO] [stdout] found `&'a str`
[INFO] [stdout] = note: but, the lifetime must be valid for the static lifetime...
[INFO] [stdout] note: ...so that the expression is assignable
[INFO] [stdout] --> src/parser/chars.rs:53:9
[INFO] [stdout] |
[INFO] [stdout] 53 | All(v).map(|x| collect(&x))
[INFO] [stdout] | ^
[INFO] [stdout] = note: expected `std::vec::Vec + 'static)>>`
[INFO] [stdout] found `std::vec::Vec>>`
[INFO] [stdout]
[INFO] [stdout]
[INFO] [stdout] error[E0495]: cannot infer an appropriate lifetime for lifetime parameter `'a` due to conflicting requirements
[INFO] [stdout] --> src/json.rs:26:9
[INFO] [stdout] |
[INFO] [stdout] 26 | json_object(),
[INFO] [stdout] | ^^^^^^^^^^^
[INFO] [stdout] |
[INFO] [stdout] note: first, the lifetime cannot outlive the lifetime `'a` as defined on the function body at 24:19...
[INFO] [stdout] --> src/json.rs:24:19
[INFO] [stdout] |
[INFO] [stdout] 24 | pub fn json_value<'a>() -> impl Parser {
[INFO] [stdout] | ^^
[INFO] [stdout] note: ...so that the types are compatible
[INFO] [stdout] --> src/json.rs:24:28
[INFO] [stdout] |
[INFO] [stdout] 24 | pub fn json_value<'a>() -> impl Parser {
[INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] = note: expected `&str`
[INFO] [stdout] found `&'a str`
[INFO] [stdout] = note: but, the lifetime must be valid for the static lifetime...
[INFO] [stdout] note: ...so that the expression is assignable
[INFO] [stdout] --> src/parser/mod.rs:74:17
[INFO] [stdout] |
[INFO] [stdout] 74 | Any(v)
[INFO] [stdout] | ^
[INFO] [stdout] |
[INFO] [stdout] ::: src/json.rs:25:5
[INFO] [stdout] |
[INFO] [stdout] 25 | / any!(
[INFO] [stdout] 26 | | json_object(),
[INFO] [stdout] 27 | | json_array(),
[INFO] [stdout] 28 | | json_string().map(JsonString),
[INFO] [stdout] ... |
[INFO] [stdout] 31 | | json_null()
[INFO] [stdout] 32 | | )
[INFO] [stdout] | |_____- in this macro invocation
[INFO] [stdout] = note: expected `std::vec::Vec + 'static)>>`
[INFO] [stdout] found `std::vec::Vec>>`
[INFO] [stdout] = note: this error originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout]
[INFO] [stdout]
[INFO] [stdout] error[E0495]: cannot infer an appropriate lifetime for lifetime parameter `'a` due to conflicting requirements
[INFO] [stdout] --> src/json.rs:20:17
[INFO] [stdout] |
[INFO] [stdout] 20 | prefix!(spaces(), chr($x))
[INFO] [stdout] | ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 112 | around!(token!('"'), many(any!(control(), other())), chr('"')).map(|v| collect(&v))
[INFO] [stdout] | ----------- in this macro invocation
[INFO] [stdout] |
[INFO] [stdout] note: first, the lifetime cannot outlive the lifetime `'a` as defined on the function body at 82:16...
[INFO] [stdout] --> src/json.rs:82:16
[INFO] [stdout] |
[INFO] [stdout] 82 | fn json_string<'a>() -> impl Parser {
[INFO] [stdout] | ^^
[INFO] [stdout] note: ...so that the types are compatible
[INFO] [stdout] --> src/json.rs:82:25
[INFO] [stdout] |
[INFO] [stdout] 82 | fn json_string<'a>() -> impl Parser {
[INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] = note: expected `&str`
[INFO] [stdout] found `&'a str`
[INFO] [stdout] = note: but, the lifetime must be valid for the static lifetime...
[INFO] [stdout] note: ...so that the expression is assignable
[INFO] [stdout] --> src/parser/mod.rs:74:17
[INFO] [stdout] |
[INFO] [stdout] 74 | Any(v)
[INFO] [stdout] | ^
[INFO] [stdout] |
[INFO] [stdout] ::: src/json.rs:112:31
[INFO] [stdout] |
[INFO] [stdout] 112 | around!(token!('"'), many(any!(control(), other())), chr('"')).map(|v| collect(&v))
[INFO] [stdout] | ------------------------ in this macro invocation
[INFO] [stdout] = note: expected `std::vec::Vec + 'static)>>`
[INFO] [stdout] found `std::vec::Vec>>`
[INFO] [stdout] = note: this error originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout]
[INFO] [stdout]
[INFO] [stdout] error[E0495]: cannot infer an appropriate lifetime for lifetime parameter `'a` due to conflicting requirements
[INFO] [stdout] --> src/json.rs:84:17
[INFO] [stdout] |
[INFO] [stdout] 84 | prefix!(chr('\\'), or(item(), prefix!(chr('u'), repeat(digit(), 4)))).flat_map(
[INFO] [stdout] | ^^^
[INFO] [stdout] |
[INFO] [stdout] note: first, the lifetime cannot outlive the lifetime `'a` as defined on the function body at 83:16...
[INFO] [stdout] --> src/json.rs:83:16
[INFO] [stdout] |
[INFO] [stdout] 83 | fn control<'a>() -> impl Parser {
[INFO] [stdout] | ^^
[INFO] [stdout] note: ...so that the types are compatible
[INFO] [stdout] --> src/json.rs:83:25
[INFO] [stdout] |
[INFO] [stdout] 83 | fn control<'a>() -> impl Parser {
[INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] = note: expected `&str`
[INFO] [stdout] found `&'a str`
[INFO] [stdout] = note: but, the lifetime must be valid for the static lifetime...
[INFO] [stdout] note: ...so that the expression is assignable
[INFO] [stdout] --> src/json.rs:87:41
[INFO] [stdout] |
[INFO] [stdout] 87 | '"' | '\\' | '/' => pure(c),
[INFO] [stdout] | ^^^^^^^
[INFO] [stdout] = note: expected `std::boxed::Box<(dyn parser::Parser + 'static)>`
[INFO] [stdout] found `std::boxed::Box>`
[INFO] [stdout]
[INFO] [stdout]
[INFO] [stdout] error[E0495]: cannot infer an appropriate lifetime due to conflicting requirements
[INFO] [stdout] --> src/json.rs:107:9
[INFO] [stdout] |
[INFO] [stdout] 107 | / item().flat_map(|x| match x {
[INFO] [stdout] 108 | | '"' | '\\' => empty(),
[INFO] [stdout] 109 | | _ => pure(x),
[INFO] [stdout] 110 | | })
[INFO] [stdout] | |__________^
[INFO] [stdout] |
[INFO] [stdout] note: first, the lifetime cannot outlive the lifetime `'a` as defined on the function body at 106:14...
[INFO] [stdout] --> src/json.rs:106:14
[INFO] [stdout] |
[INFO] [stdout] 106 | fn other<'a>() -> impl Parser {
[INFO] [stdout] | ^^
[INFO] [stdout] note: ...so that the types are compatible
[INFO] [stdout] --> src/json.rs:106:23
[INFO] [stdout] |
[INFO] [stdout] 106 | fn other<'a>() -> impl Parser {
[INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] = note: expected `&str`
[INFO] [stdout] found `&'a str`
[INFO] [stdout] = note: but, the lifetime must be valid for the static lifetime...
[INFO] [stdout] note: ...so that the expression is assignable
[INFO] [stdout] --> src/json.rs:108:27
[INFO] [stdout] |
[INFO] [stdout] 108 | '"' | '\\' => empty(),
[INFO] [stdout] | ^^^^^^^
[INFO] [stdout] = note: expected `std::boxed::Box<(dyn parser::Parser + 'static)>`
[INFO] [stdout] found `std::boxed::Box>`
[INFO] [stdout]
[INFO] [stdout]
[INFO] [stdout] error[E0495]: cannot infer an appropriate lifetime for lifetime parameter `'a` due to conflicting requirements
[INFO] [stdout] --> src/json.rs:140:5
[INFO] [stdout] |
[INFO] [stdout] 140 | flag().flat_map(|g| {
[INFO] [stdout] | ^^^^
[INFO] [stdout] |
[INFO] [stdout] note: first, the lifetime cannot outlive the lifetime `'a` as defined on the function body at 115:16...
[INFO] [stdout] --> src/json.rs:115:16
[INFO] [stdout] |
[INFO] [stdout] 115 | fn json_number<'a>() -> impl Parser {
[INFO] [stdout] | ^^
[INFO] [stdout] note: ...so that the types are compatible
[INFO] [stdout] --> src/json.rs:115:25
[INFO] [stdout] |
[INFO] [stdout] 115 | fn json_number<'a>() -> impl Parser {
[INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] = note: expected `&str`
[INFO] [stdout] found `&'a str`
[INFO] [stdout] = note: but, the lifetime must be valid for the static lifetime...
[INFO] [stdout] note: ...so that the expression is assignable
[INFO] [stdout] --> src/json.rs:143:17
[INFO] [stdout] |
[INFO] [stdout] 143 | / float()
[INFO] [stdout] 144 | | .map(move |o| match o {
[INFO] [stdout] 145 | | Some(f) => JsonFloat(g as f32 * (i as f32 + f)),
[INFO] [stdout] 146 | | None => JsonInteger(g * i as i32),
[INFO] [stdout] 147 | | })
[INFO] [stdout] 148 | | .boxed()
[INFO] [stdout] | |____________________________^
[INFO] [stdout] = note: expected `std::boxed::Box<(dyn parser::Parser + 'static)>`
[INFO] [stdout] found `std::boxed::Box>`
[INFO] [stdout]
[INFO] [stdout]
[INFO] [stdout] error: aborting due to 9 previous errors
[INFO] [stdout]
[INFO] [stdout]
[INFO] [stdout] For more information about this error, try `rustc --explain E0495`.
[INFO] [stdout]
[INFO] [stderr] error: Could not document `combinator`.
[INFO] [stderr]
[INFO] [stderr] Caused by:
[INFO] [stderr] process didn't exit successfully: `rustdoc --edition=2018 --crate-type lib --crate-name combinator src/lib.rs -o /opt/rustwide/target/doc --error-format=json --json=diagnostic-rendered-ansi --document-private-items -L dependency=/opt/rustwide/target/debug/deps --cap-lints=forbid` (exit code: 1)
[INFO] running `Command { std: "docker" "inspect" "2816286bf436f3ea0da8ef97597b0c2229f2262bc29387f5982d748961b48bd3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2816286bf436f3ea0da8ef97597b0c2229f2262bc29387f5982d748961b48bd3", kill_on_drop: false }`
[INFO] [stdout] 2816286bf436f3ea0da8ef97597b0c2229f2262bc29387f5982d748961b48bd3