[INFO] updating cached repository jlgerber/levelspecter [INFO] running `"git" "fetch" "--all"` [INFO] [stdout] Fetching origin [INFO] [stderr] From git://github.com/jlgerber/levelspecter [INFO] [stderr] * branch HEAD -> FETCH_HEAD [INFO] running `"git" "clone" "work/cache/sources/gh/jlgerber/levelspecter" "work/ex/beta-1.38-1/sources/1.37.0/gh/jlgerber/levelspecter"` [INFO] [stderr] Cloning into 'work/ex/beta-1.38-1/sources/1.37.0/gh/jlgerber/levelspecter'... [INFO] [stderr] done. [INFO] running `"git" "clone" "work/cache/sources/gh/jlgerber/levelspecter" "work/ex/beta-1.38-1/sources/beta-2019-08-13/gh/jlgerber/levelspecter"` [INFO] [stderr] Cloning into 'work/ex/beta-1.38-1/sources/beta-2019-08-13/gh/jlgerber/levelspecter'... [INFO] [stderr] done. [INFO] running `"git" "rev-parse" "HEAD"` [INFO] [stdout] 375a84388c65db07e1ca27f57f7264848674aa99 [INFO] sha for GitHub repo jlgerber/levelspecter: 375a84388c65db07e1ca27f57f7264848674aa99 [INFO] validating manifest of jlgerber/levelspecter on toolchain 1.37.0 [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+1.37.0" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] validating manifest of jlgerber/levelspecter on toolchain beta-2019-08-13 [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+beta-2019-08-13" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started frobbing jlgerber/levelspecter [INFO] finished frobbing jlgerber/levelspecter [INFO] frobbed toml for jlgerber/levelspecter written to work/ex/beta-1.38-1/sources/1.37.0/gh/jlgerber/levelspecter/Cargo.toml [INFO] started frobbing jlgerber/levelspecter [INFO] finished frobbing jlgerber/levelspecter [INFO] frobbed toml for jlgerber/levelspecter written to work/ex/beta-1.38-1/sources/beta-2019-08-13/gh/jlgerber/levelspecter/Cargo.toml [INFO] crate jlgerber/levelspecter already has a lockfile, it will not be regenerated [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+1.37.0" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+beta-2019-08-13" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] testing jlgerber/levelspecter against beta-2019-08-13 for beta-1.38-1 [INFO] running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/beta-1.38-1/worker-6/beta-2019-08-13:/opt/crater/target:rw,Z" "-v" "/mnt/big/crater/work/ex/beta-1.38-1/sources/beta-2019-08-13/gh/jlgerber/levelspecter:/opt/crater/workdir:ro,Z" "-v" "/mnt/big/crater/work/local/cargo-home:/opt/crater/cargo-home:ro,Z" "-v" "/mnt/big/crater/work/local/rustup-home:/opt/crater/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/opt/crater/workdir" "-e" "MAP_USER_ID=1000" "-e" "CARGO_TARGET_DIR=/opt/crater/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/crater/cargo-home" "-e" "RUSTUP_HOME=/opt/crater/rustup-home" "-w" "/opt/crater/workdir" "-m" "1536M" "--network" "none" "rustops/crates-build-env" "/opt/crater/cargo-home/bin/cargo" "+beta-2019-08-13" "build" "--frozen"` [INFO] [stdout] 9313796267e5deddf102c9ebc454c639e106c4af0bf6f3b7b15405b9ab03dd35 [INFO] running `"docker" "start" "-a" "9313796267e5deddf102c9ebc454c639e106c4af0bf6f3b7b15405b9ab03dd35"` [INFO] [stderr] Compiling libc v0.2.58 [INFO] [stderr] Compiling memchr v2.2.0 [INFO] [stderr] Compiling static_assertions v0.2.5 [INFO] [stderr] Compiling nom v5.0.0 [INFO] [stderr] Compiling stackvector v1.0.6 [INFO] [stderr] Compiling lexical-core v0.4.1 [INFO] [stderr] Compiling backtrace-sys v0.1.28 [INFO] [stderr] Compiling backtrace v0.3.31 [INFO] [stderr] Compiling failure v0.1.5 [INFO] [stderr] Compiling aschar-casesensitive v0.2.0 (https://github.com/jlgerber/aschar-casesensitive.git#6d27c1c2) [INFO] [stderr] Compiling levelspecter v0.10.0 (/opt/crater/workdir) [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 18.79s [INFO] running `"docker" "inspect" "9313796267e5deddf102c9ebc454c639e106c4af0bf6f3b7b15405b9ab03dd35"` [INFO] running `"docker" "rm" "-f" "9313796267e5deddf102c9ebc454c639e106c4af0bf6f3b7b15405b9ab03dd35"` [INFO] [stdout] 9313796267e5deddf102c9ebc454c639e106c4af0bf6f3b7b15405b9ab03dd35 [INFO] running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/beta-1.38-1/worker-6/beta-2019-08-13:/opt/crater/target:rw,Z" "-v" "/mnt/big/crater/work/ex/beta-1.38-1/sources/beta-2019-08-13/gh/jlgerber/levelspecter:/opt/crater/workdir:ro,Z" "-v" "/mnt/big/crater/work/local/cargo-home:/opt/crater/cargo-home:ro,Z" "-v" "/mnt/big/crater/work/local/rustup-home:/opt/crater/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/opt/crater/workdir" "-e" "MAP_USER_ID=1000" "-e" "CARGO_TARGET_DIR=/opt/crater/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/crater/cargo-home" "-e" "RUSTUP_HOME=/opt/crater/rustup-home" "-w" "/opt/crater/workdir" "-m" "1536M" "--network" "none" "rustops/crates-build-env" "/opt/crater/cargo-home/bin/cargo" "+beta-2019-08-13" "test" "--frozen" "--no-run"` [INFO] [stdout] 4461d8a817cef74b84472bd526ac1468d81470ff95c47b42ea318160c725fcaf [INFO] running `"docker" "start" "-a" "4461d8a817cef74b84472bd526ac1468d81470ff95c47b42ea318160c725fcaf"` [INFO] [stderr] Compiling levelspecter v0.10.0 (/opt/crater/workdir) [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 4.91s [INFO] running `"docker" "inspect" "4461d8a817cef74b84472bd526ac1468d81470ff95c47b42ea318160c725fcaf"` [INFO] running `"docker" "rm" "-f" "4461d8a817cef74b84472bd526ac1468d81470ff95c47b42ea318160c725fcaf"` [INFO] [stdout] 4461d8a817cef74b84472bd526ac1468d81470ff95c47b42ea318160c725fcaf [INFO] running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/beta-1.38-1/worker-6/beta-2019-08-13:/opt/crater/target:rw,Z" "-v" "/mnt/big/crater/work/ex/beta-1.38-1/sources/beta-2019-08-13/gh/jlgerber/levelspecter:/opt/crater/workdir:ro,Z" "-v" "/mnt/big/crater/work/local/cargo-home:/opt/crater/cargo-home:ro,Z" "-v" "/mnt/big/crater/work/local/rustup-home:/opt/crater/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/opt/crater/workdir" "-e" "MAP_USER_ID=1000" "-e" "CARGO_TARGET_DIR=/opt/crater/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/crater/cargo-home" "-e" "RUSTUP_HOME=/opt/crater/rustup-home" "-w" "/opt/crater/workdir" "-m" "1536M" "--network" "none" "rustops/crates-build-env" "/opt/crater/cargo-home/bin/cargo" "+beta-2019-08-13" "test" "--frozen"` [INFO] [stdout] 22ecfc20080ce9b7efdd101b816904db366734339b54c9f2f0254000ed951c2a [INFO] running `"docker" "start" "-a" "22ecfc20080ce9b7efdd101b816904db366734339b54c9f2f0254000ed951c2a"` [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 0.08s [INFO] [stderr] Running /opt/crater/target/debug/deps/levelspecter-7bb875d9e72db06c [INFO] [stdout] [INFO] [stdout] running 139 tests [INFO] [stdout] test levelparser::levelspec::rel_seq::can_parse_rel_seq ... ok [INFO] [stdout] test levelparser::levelspec::rel_seq::can_parse_rel_seq_shot ... ok [INFO] [stdout] test levelparser::levelspec::rel_seq::can_parse_rel_seq_alt ... ok [INFO] [stdout] test levelparser::levelspec::seq::cannot_have_underscore ... ok [INFO] [stdout] test levelparser::levelspec::seq::cannot_have_space ... ok [INFO] [stdout] test levelparser::levelspec::seq::can_parse_wildcard ... ok [INFO] [stdout] test levelparser::levelspec::seq::can_parse ... ok [INFO] [stdout] test levelparser::levelspec::seq::can_parse_assetdev ... ok [INFO] [stdout] test levelparser::levelspec::rel_seq::can_parse_rel_shot ... ok [INFO] [stdout] test levelparser::levelspec::rel_seq::can_parse_show_seq_rel ... ok [INFO] [stdout] test levelparser::levelspec::seq::cannot_have_wildcard_and_chars ... ok [INFO] [stdout] test levelparser::levelspec::seq::cannot_start_with_number ... ok [INFO] [stdout] test levelparser::levelspec::shot::can_parse ... ok [INFO] [stdout] test levelparser::levelspec::shot::can_parse_assetdev ... ok [INFO] [stdout] test levelparser::levelspec::shot::can_parse_wildcard ... ok [INFO] [stdout] test levelparser::levelspec::shot::cannot_have_space ... ok [INFO] [stdout] test levelparser::levelspec::shot::cannot_have_underscore ... ok [INFO] [stdout] test levelparser::levelspec::shot::cannot_have_wildcard_and_chars ... ok [INFO] [stdout] test levelparser::levelspec::shot::cannot_parse_assetdev_lowercase ... ok [INFO] [stdout] test levelparser::levelspec::shot::cannot_start_with_letter ... ok [INFO] [stdout] test levelparser::levelspec::show::can_parse ... ok [INFO] [stdout] test levelparser::levelspec::show::can_parse_show_dot ... ok [INFO] [stdout] test levelparser::levelspec::show::can_parse_show_dot_dot ... ok [INFO] [stdout] test levelparser::levelspec::show::can_parse_show_wildcard ... ok [INFO] [stdout] test levelparser::levelspec::show::cannot_have_space ... ok [INFO] [stdout] test levelparser::levelspec::show::cannot_have_underscore ... ok [INFO] [stdout] test levelparser::levelspec::show::cannot_have_wildcard_and_chars ... ok [INFO] [stdout] test levelparser::levelspec::show::cannot_parse_lowercase ... ok [INFO] [stdout] test levelparser::levelspec::show::cannot_start_with_number ... ok [INFO] [stdout] test levelparser::parse_assetdev_seq_case_sensitive::can_parse_assetdev_capital ... ok [INFO] [stdout] test levelparser::parse_assetdev_seq_case_sensitive::cannot_parse_assetdev_lower ... ok [INFO] [stdout] test levelparser::parse_assetdev_seq_case_sensitive::cannot_parse_seq_other_than_assetdev ... ok [INFO] [stdout] test levelparser::parse_assetdev_shot::can_parse_assetdev_shot_capital ... ok [INFO] [stdout] test levelparser::parse_assetdev_shot::can_parse_wildcard ... ok [INFO] [stdout] test levelparser::parse_assetdev_shot::cannot_parse_assetdev_shot_lower ... ok [INFO] [stdout] test levelparser::parse_level::seq_can_parse_wildcard ... ok [INFO] [stdout] test levelparser::parse_level::shot_can_parse_wildcard ... ok [INFO] [stdout] test levelparser::parse_level::show_can_parse_wildcard ... ok [INFO] [stdout] test levelparser::parse_rel_assetdev_seq::can_parse_seq_capital ... ok [INFO] [stdout] test levelparser::parse_rel_assetdev_seq::cannot_parse_relseq_lower ... ok [INFO] [stdout] test levelparser::parse_rel_seq::can_parse_seq_capital ... ok [INFO] [stdout] test levelparser::parse_rel_seq::can_parse_wildcard ... ok [INFO] [stdout] test levelparser::parse_rel_seq::cannot_parse_relseq_lower ... ok [INFO] [stdout] test levelparser::parse_rel_seq_rel::can_parse_seq_assetdev_capital ... ok [INFO] [stdout] test levelparser::parse_rel_seq_rel::can_parse_seq_capital ... ok [INFO] [stdout] test levelparser::parse_rel_seq_rel::can_parse_wildcard ... ok [INFO] [stdout] test levelparser::parse_rel_seq_rel::cannot_parse_relseq_assetdev_lower ... ok [INFO] [stdout] test levelparser::parse_rel_seq_rel::cannot_parse_relseq_lower ... ok [INFO] [stdout] test levelparser::parse_rel_shot::can_parse_relshot_lower ... ok [INFO] [stdout] test levelparser::parse_rel_shot::can_parse_wildcard ... ok [INFO] [stdout] test levelparser::parse_seq::can_parse_seq ... ok [INFO] [stdout] test levelparser::levelspec::seq::can_parse_assetdev_lowercase ... ok [INFO] [stdout] test levelparser::parse_shot::can_parse_shot ... ok [INFO] [stdout] test levelparser::parse_show::can_parse_show ... ok [INFO] [stdout] test levelparser::parse_show_rel_seq::can_parse_show_rel_seq_wildcard ... ok [INFO] [stdout] test levelparser::parse_show_rel_seq::can_parse_show_relshot_lower ... ok [INFO] [stdout] test levelparser::parse_show_rel_shot::can_parse_show_relshot_lower ... ok [INFO] [stdout] test levelparser::parse_show_rel_shot::can_show_parse_wildcard ... ok [INFO] [stdout] test levelparser::rel_seq_alt::can_parse ... ok [INFO] [stdout] test levelparser::rel_seq_alt::can_parse_wildcard ... ok [INFO] [stdout] test levelparser::rel_seq_alt::can_parse_assetdev_lowercase ... ok [INFO] [stdout] test levelparser::rel_seq_alt::can_parse_assetdev ... ok [INFO] [stdout] test levelparser::rel_seq_rel_alt::can_parse_wildcard ... ok [INFO] [stdout] test levelparser::rel_seq_alt::cannot_have_underscore ... ok [INFO] [stdout] test levelparser::rel_seq_rel_alt::can_parse ... ok [INFO] [stdout] test levelparser::rel_seq_alt::cannot_have_space ... ok [INFO] [stdout] test levelparser::rel_seq_rel_alt::can_parse_assetdev_lowercase ... ok [INFO] [stdout] test levelparser::rel_seq_rel_alt::cannot_have_space ... ok [INFO] [stdout] test levelparser::rel_seq_rel_alt::cannot_have_wildcard_and_chars ... ok [INFO] [stdout] test levelparser::rel_seq_alt::cannot_have_wildcard_and_chars ... ok [INFO] [stdout] test levelparser::rel_seq_rel_alt::can_parse_assetdev ... ok [INFO] [stdout] test levelparser::rel_seq_alt::cannot_start_with_number ... ok [INFO] [stdout] test levelparser::rel_seq_rel_alt::cannot_have_underscore ... ok [INFO] [stdout] test levelparser::rel_seq_shot_alt::can_parse_assetdev ... ok [INFO] [stdout] test levelparser::rel_seq_shot_alt::cannot_have_space ... ok [INFO] [stdout] test levelparser::rel_seq_shot_alt::can_parse ... ok [INFO] [stdout] test levelparser::rel_shot_alt::can_parse ... ok [INFO] [stdout] test levelparser::rel_seq_rel_alt::cannot_start_with_number ... ok [INFO] [stdout] test levelparser::rel_seq_shot_alt::cannot_start_with_number ... ok [INFO] [stdout] test levelparser::rel_shot_alt::can_parse_wildcard ... ok [INFO] [stdout] test levelparser::rel_seq_shot_alt::cannot_have_underscore ... ok [INFO] [stdout] test levelparser::rel_seq_shot_alt::cannot_have_wildcard_and_chars ... ok [INFO] [stdout] test levelparser::rel_seq_shot_alt::can_parse_assetdev_lowercase ... ok [INFO] [stdout] test levelparser::seq_alt::can_parse ... ok [INFO] [stdout] test levelparser::seq_alt::can_parse_assetdev ... ok [INFO] [stdout] test levelparser::rel_shot_alt::cannot_have_underscore ... ok [INFO] [stdout] test levelparser::rel_shot_alt::cannot_have_wildcard_and_chars ... ok [INFO] [stdout] test levelparser::seq_alt::can_parse_assetdev_lowercase ... ok [INFO] [stdout] test levelparser::rel_seq_shot_alt::can_parse_wildcard ... ok [INFO] [stdout] test levelparser::rel_shot_alt::cannot_have_space ... ok [INFO] [stdout] test levelparser::seq_alt::cannot_have_underscore ... ok [INFO] [stdout] test levelparser::seq_alt::cannot_start_with_number ... ok [INFO] [stdout] test levelparser::seq_alt::cannot_have_space ... ok [INFO] [stdout] test levelparser::shot_alt::cannot_have_underscore ... ok [INFO] [stdout] test levelparser::shot_alt::can_parse ... ok [INFO] [stdout] test levelparser::seq_alt::can_parse_wildcard ... ok [INFO] [stdout] test levelparser::seq_alt::cannot_have_wildcard_and_chars ... ok [INFO] [stdout] test levelparser::shot_alt::can_parse_assetdev ... ok [INFO] [stdout] test levelparser::shot_alt::can_parse_wildcard ... ok [INFO] [stdout] test levelparser::show_alt::can_parse_wildcard ... ok [INFO] [stdout] test levelparser::show_alt::cannot_have_space ... ok [INFO] [stdout] test levelparser::shot_alt::cannot_parse_assetdev_lowercase ... ok [INFO] [stdout] test levelparser::show_alt::cannot_have_underscore ... ok [INFO] [stdout] test levelparser::show_alt::cannot_have_wildcard_and_chars ... ok [INFO] [stdout] test levelparser::shot_alt::cannot_have_space ... ok [INFO] [stdout] test levelparser::shot_alt::cannot_have_wildcard_and_chars ... ok [INFO] [stdout] test levelparser::show_alt::can_parse ... ok [INFO] [stdout] test levelparser::shot_alt::cannot_start_with_letter ... ok [INFO] [stdout] test levelparser::show_rel_seq_alt::wont_parse_show_rel_shot_lower ... ok [INFO] [stdout] test levelparser::show_alt::cannot_start_with_number ... ok [INFO] [stdout] test levelparser::show_rel_seq_alt::can_parse_show_rel_seq_lower ... ok [INFO] [stdout] test levelparser::show_rel_seq_alt::can_parse_wildcard ... ok [INFO] [stdout] test levelparser::show_rel_shot_alt::can_parse_show_rel_shot_lower ... ok [INFO] [stdout] test levelparser::show_rel_shot_alt::can_show_parse_wildcard ... ok [INFO] [stdout] test levelparser::show_seq_rel_alt::can_parse ... ok [INFO] [stdout] test levelparser::show_seq_rel_alt::can_parse_assetdev ... ok [INFO] [stdout] test levelparser::show_seq_rel_alt::can_parse_assetdev_lowercase ... ok [INFO] [stdout] test levelparser::show_seq_rel_alt::cannot_have_space ... ok [INFO] [stdout] test levelparser::show_seq_rel_alt::can_parse_wildcard ... ok [INFO] [stdout] test levelspec::tests::can_new_up_shot ... ok [INFO] [stdout] test levelspec::tests::can_new_up_seq ... ok [INFO] [stdout] test levelparser::show_seq_rel_alt::cannot_start_with_number ... ok [INFO] [stdout] test levelparser::show_seq_rel_alt::cannot_have_wildcard_and_chars ... ok [INFO] [stdout] test levelparser::show_seq_rel_alt::cannot_have_underscore ... ok [INFO] [stdout] test levelspec::tests::can_parse_seq_with_relative_show_and_shot ... ok [INFO] [stdout] test levelspec::tests::can_parse_shot ... ok [INFO] [stdout] test levelspec::tests::can_parse_shot_lower ... ok [INFO] [stdout] test levelspec::tests::can_parse_show ... ok [INFO] [stdout] test levelspec::tests::can_replace_rel ... ok [INFO] [stdout] test levelspec::tests::cannot_parse_show_lower ... ok [INFO] [stdout] test levelspec::tests::is_concrete_for_seq_wildcard_works ... ok [INFO] [stdout] test levelspec::tests::is_concrete_for_show_wildcard_works ... ok [INFO] [stdout] test levelspec::tests::is_concrete_for_shot_wildcard_works ... ok [INFO] [stdout] test levelspec::tests::is_concrete_works ... ok [INFO] [stdout] test levelspec::tests::can_parse_shot_with_relative_show ... ok [INFO] [stdout] test levelspec::tests::can_parse_seq ... ok [INFO] [stdout] test levelspec::tests::can_parse_seq_with_relative_show ... ok [INFO] [stdout] test levelspec::tests::can_parse_shot_with_wildcard ... ok [INFO] [stdout] test levelspec::tests::can_new_up_show ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 139 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out [INFO] [stdout] [INFO] [stderr] Running /opt/crater/target/debug/deps/levelspecter-155d8ccc0fa0dcb0 [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] [stderr] Running /opt/crater/target/debug/deps/levelspec_tests-aef5b73698e583dd [INFO] [stdout] [INFO] [stdout] running 4 tests [INFO] [stdout] test can_parse_show ... ok [INFO] [stdout] test can_parse_shot_with_wildcard ... ok [INFO] [stdout] test can_parse_shot ... ok [INFO] [stdout] test can_parse_seq ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 4 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out [INFO] [stdout] [INFO] [stderr] Doc-tests levelspecter [INFO] [stdout] [INFO] [stdout] running 2 tests [INFO] [stdout] test src/levelparser.rs - levelparser::levelspec_parser (line 30) ... ok [INFO] [stdout] test src/levelspec.rs - levelspec::LevelSpec::new (line 32) ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out [INFO] [stdout] [INFO] running `"docker" "inspect" "22ecfc20080ce9b7efdd101b816904db366734339b54c9f2f0254000ed951c2a"` [INFO] running `"docker" "rm" "-f" "22ecfc20080ce9b7efdd101b816904db366734339b54c9f2f0254000ed951c2a"` [INFO] [stdout] 22ecfc20080ce9b7efdd101b816904db366734339b54c9f2f0254000ed951c2a