[INFO] fetching crate remote_config 0.2.0...
[INFO] testing remote_config-0.2.0 against try#db823df02fd0c2cf67b43025ac3fef3f2d743245 for pr-150681
[INFO] extracting crate remote_config 0.2.0 into /workspace/builds/worker-3-tc2/source
[INFO] started tweaking crates.io crate remote_config 0.2.0
[INFO] finished tweaking crates.io crate remote_config 0.2.0
[INFO] tweaked toml for crates.io crate remote_config 0.2.0 written to /workspace/builds/worker-3-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate remote_config 0.2.0 on toolchain db823df02fd0c2cf67b43025ac3fef3f2d743245
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]      Locking 198 packages to latest compatible versions
[INFO] [stderr]       Adding reqwest v0.12.28 (available: v0.13.1)
[INFO] [stderr]       Adding serde-xml-rs v0.6.0 (available: v0.8.2)
[INFO] [stderr]       Adding toml v0.8.23 (available: v0.9.10+spec-1.1.0)
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] f295447b9bb47f225a0682293cf75b4dfb1a8f1afc878424ab337d942a256ad3
[INFO] running `Command { std: "docker" "start" "-a" "f295447b9bb47f225a0682293cf75b4dfb1a8f1afc878424ab337d942a256ad3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "f295447b9bb47f225a0682293cf75b4dfb1a8f1afc878424ab337d942a256ad3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f295447b9bb47f225a0682293cf75b4dfb1a8f1afc878424ab337d942a256ad3", kill_on_drop: false }`
[INFO] [stdout] f295447b9bb47f225a0682293cf75b4dfb1a8f1afc878424ab337d942a256ad3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-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" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 3aac69820e03e77ce622f66202c68fdee1f8ef1722bd0506a4d373936ae76d77
[INFO] running `Command { std: "docker" "start" "-a" "3aac69820e03e77ce622f66202c68fdee1f8ef1722bd0506a4d373936ae76d77", kill_on_drop: false }`
[INFO] [stderr]    Compiling find-msvc-tools v0.1.6
[INFO] [stderr]    Compiling shlex v1.3.0
[INFO] [stderr]    Compiling pkg-config v0.3.32
[INFO] [stderr]    Compiling openssl v0.10.75
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling bitflags v2.10.0
[INFO] [stderr]    Compiling syn v2.0.114
[INFO] [stderr]    Compiling indexmap v2.13.0
[INFO] [stderr]    Compiling tokio v1.49.0
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling openssl-probe v0.1.6
[INFO] [stderr]    Compiling form_urlencoded v1.2.2
[INFO] [stderr]    Compiling sync_wrapper v1.0.2
[INFO] [stderr]    Compiling ipnet v2.11.0
[INFO] [stderr]    Compiling base64 v0.22.1
[INFO] [stderr]    Compiling cc v1.2.51
[INFO] [stderr]    Compiling http-body-util v0.1.3
[INFO] [stderr]    Compiling zeroize v1.8.2
[INFO] [stderr]    Compiling iri-string v0.7.10
[INFO] [stderr]    Compiling cache_control v0.2.0
[INFO] [stderr]    Compiling rustls-pki-types v1.13.2
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling openssl-sys v0.9.111
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling tower v0.5.2
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]    Compiling h2 v0.4.13
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling yoke v0.8.1
[INFO] [stderr]    Compiling zerovec v0.11.5
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]    Compiling tinystr v0.8.2
[INFO] [stderr]    Compiling potential_utf v0.1.4
[INFO] [stderr]    Compiling icu_collections v2.1.1
[INFO] [stderr]    Compiling icu_locale_core v2.1.1
[INFO] [stderr]    Compiling icu_provider v2.1.1
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling icu_properties v2.1.2
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling hyper-util v0.1.19
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling url v2.5.8
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]    Compiling remote_config v0.2.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/config.rs:103:24
[INFO] [stdout]     |
[INFO] [stdout] 103 |     fn from(value: Box<(dyn Error + 'static)>) -> Self {
[INFO] [stdout]     |                        ^                   ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 103 -     fn from(value: Box<(dyn Error + 'static)>) -> Self {
[INFO] [stdout] 103 +     fn from(value: Box<dyn Error + 'static >) -> Self {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 27.15s
[INFO] running `Command { std: "docker" "inspect" "3aac69820e03e77ce622f66202c68fdee1f8ef1722bd0506a4d373936ae76d77", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3aac69820e03e77ce622f66202c68fdee1f8ef1722bd0506a4d373936ae76d77", kill_on_drop: false }`
[INFO] [stdout] 3aac69820e03e77ce622f66202c68fdee1f8ef1722bd0506a4d373936ae76d77
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-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" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 0a49fe125c1627658a03affb63c7eee3ea9cd05c81692431443c829ad34d72f8
[INFO] running `Command { std: "docker" "start" "-a" "0a49fe125c1627658a03affb63c7eee3ea9cd05c81692431443c829ad34d72f8", kill_on_drop: false }`
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling regex-syntax v0.8.8
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]    Compiling similar v2.7.0
[INFO] [stderr]    Compiling colored v3.0.0
[INFO] [stderr]    Compiling rand_core v0.9.3
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling rand v0.9.2
[INFO] [stderr]    Compiling tokio v1.49.0
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling regex-automata v0.4.13
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling assert-json-diff v2.0.2
[INFO] [stderr]    Compiling regex v1.12.2
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling tower v0.5.2
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling h2 v0.4.13
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling hyper-util v0.1.19
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling mockito v1.7.1
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]    Compiling remote_config v0.2.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/config.rs:103:24
[INFO] [stdout]     |
[INFO] [stdout] 103 |     fn from(value: Box<(dyn Error + 'static)>) -> Self {
[INFO] [stdout]     |                        ^                   ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 103 -     fn from(value: Box<(dyn Error + 'static)>) -> Self {
[INFO] [stdout] 103 +     fn from(value: Box<dyn Error + 'static >) -> Self {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/config.rs:103:24
[INFO] [stdout]     |
[INFO] [stdout] 103 |     fn from(value: Box<(dyn Error + 'static)>) -> Self {
[INFO] [stdout]     |                        ^                   ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 103 -     fn from(value: Box<(dyn Error + 'static)>) -> Self {
[INFO] [stdout] 103 +     fn from(value: Box<dyn Error + 'static >) -> Self {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 26.46s
[INFO] running `Command { std: "docker" "inspect" "0a49fe125c1627658a03affb63c7eee3ea9cd05c81692431443c829ad34d72f8", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0a49fe125c1627658a03affb63c7eee3ea9cd05c81692431443c829ad34d72f8", kill_on_drop: false }`
[INFO] [stdout] 0a49fe125c1627658a03affb63c7eee3ea9cd05c81692431443c829ad34d72f8
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-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" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 7305a2465ea5e14185c8e5659fe4d318b19c39917139615c69e4933d149a952f
[INFO] running `Command { std: "docker" "start" "-a" "7305a2465ea5e14185c8e5659fe4d318b19c39917139615c69e4933d149a952f", kill_on_drop: false }`
[INFO] [stderr] warning: unnecessary parentheses around type
[INFO] [stderr]    --> src/config.rs:103:24
[INFO] [stderr]     |
[INFO] [stderr] 103 |     fn from(value: Box<(dyn Error + 'static)>) -> Self {
[INFO] [stderr]     |                        ^                   ^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 103 -     fn from(value: Box<(dyn Error + 'static)>) -> Self {
[INFO] [stderr] 103 +     fn from(value: Box<dyn Error + 'static >) -> Self {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: `remote_config` (lib) generated 1 warning (run `cargo fix --lib -p remote_config` to apply 1 suggestion)
[INFO] [stderr] warning: `remote_config` (lib test) generated 1 warning (1 duplicate)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.17s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/remote_config-93664fd3e5007fde)
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test data_providers::http::tests::http_error ... ok
[INFO] [stdout] test data_providers::http::tests::deserialize_json ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.51s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/integration_test.rs (/opt/rustwide/target/debug/deps/integration_test-3745f227bc21aa3a)
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test test_without_must_revalidate ... ok
[INFO] [stdout] test test_with_must_revalidate ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 1.29s
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests remote_config
[INFO] [stderr] warning: unnecessary parentheses around type
[INFO] [stderr]    --> src/config.rs:103:24
[INFO] [stderr]     |
[INFO] [stderr] 103 |     fn from(value: Box<(dyn Error + 'static)>) -> Self {
[INFO] [stderr]     |                        ^                   ^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 103 -     fn from(value: Box<(dyn Error + 'static)>) -> Self {
[INFO] [stderr] 103 +     fn from(value: Box<dyn Error + 'static >) -> Self {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: 1 warning emitted
[INFO] [stderr] 
[INFO] [stdout] 
[INFO] [stdout] running 3 tests
[INFO] [stdout] test src/config.rs - config::RemoteConfig (line 27) ... FAILED
[INFO] [stdout] test src/lib.rs - (line 54) ... FAILED
[INFO] [stdout] test src/data_providers/http.rs - data_providers::http::HttpDataProvider (line 22) ... ok
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- src/config.rs - config::RemoteConfig (line 27) stdout ----
[INFO] [stdout] error[E0277]: the trait bound `std::string::String: DataProvider<_>` is not satisfied
[INFO] [stdout]   --> src/config.rs:51:12
[INFO] [stdout]    |
[INFO] [stdout] 51 |     return RemoteConfig::new("Example named config".to_owned(), data_provider, Duration::from_secs(5)).await.unwrap();
[INFO] [stdout]    |            ^^^^^^^^^^^^ the trait `DataProvider<_>` is not implemented for `std::string::String`
[INFO] [stdout]    |
[INFO] [stdout] help: the trait `DataProvider<Data>` is implemented for `HttpDataProvider<Data, Extractor>`
[INFO] [stdout]   --> src/data_providers/http.rs:41:1
[INFO] [stdout]    |
[INFO] [stdout] 41 | impl <Data: Send + Sync, Extractor: HttpDataExtractor<Data> + Sync> DataProvider<Data> for HttpDataProvider<Data, Extractor> {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] note: required by a bound in `RemoteConfig`
[INFO] [stdout]   --> src/config.rs:67:54
[INFO] [stdout]    |
[INFO] [stdout] 67 | pub struct RemoteConfig<Data: Send + Sync, Provider: DataProvider<Data> + Send> {
[INFO] [stdout]    |                                                      ^^^^^^^^^^^^^^^^^^ required by this bound in `RemoteConfig`
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `std::string::String: DataProvider<_>` is not satisfied
[INFO] [stdout]    --> src/config.rs:51:30
[INFO] [stdout]     |
[INFO] [stdout]  51 |     return RemoteConfig::new("Example named config".to_owned(), data_provider, Duration::from_secs(5)).await.unwrap();
[INFO] [stdout]     |            ----------------- ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `DataProvider<_>` is not implemented for `std::string::String`
[INFO] [stdout]     |            |
[INFO] [stdout]     |            required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] help: the trait `DataProvider<Data>` is implemented for `HttpDataProvider<Data, Extractor>`
[INFO] [stdout]    --> src/data_providers/http.rs:41:1
[INFO] [stdout]     |
[INFO] [stdout]  41 | impl <Data: Send + Sync, Extractor: HttpDataExtractor<Data> + Sync> DataProvider<Data> for HttpDataProvider<Data, Extractor> {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] note: required by a bound in `RemoteConfig::<Data, Provider>::new`
[INFO] [stdout]    --> src/config.rs:124:36
[INFO] [stdout]     |
[INFO] [stdout] 124 | impl <Data: Send + Sync, Provider: DataProvider<Data> + Send> RemoteConfig<Data, Provider> {
[INFO] [stdout]     |                                    ^^^^^^^^^^^^^^^^^^ required by this bound in `RemoteConfig::<Data, Provider>::new`
[INFO] [stdout] ...
[INFO] [stdout] 129 |     pub async fn new(
[INFO] [stdout]     |                  --- required by a bound in this associated function
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this function takes 2 arguments but 3 arguments were supplied
[INFO] [stdout]    --> src/config.rs:51:12
[INFO] [stdout]     |
[INFO] [stdout]  51 |     return RemoteConfig::new("Example named config".to_owned(), data_provider, Duration::from_secs(5)).await.unwrap();
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^                                    ------------- unexpected argument #2 of type `HttpDataProvider<_, SerdeDataExtractor<_>>`
[INFO] [stdout]     |
[INFO] [stdout] note: associated function defined here
[INFO] [stdout]    --> src/config.rs:129:18
[INFO] [stdout]     |
[INFO] [stdout] 129 |     pub async fn new(
[INFO] [stdout]     |                  ^^^
[INFO] [stdout] help: remove the extra argument
[INFO] [stdout]     |
[INFO] [stdout]  51 -     return RemoteConfig::new("Example named config".to_owned(), data_provider, Duration::from_secs(5)).await.unwrap();
[INFO] [stdout]  51 +     return RemoteConfig::new("Example named config".to_owned(), Duration::from_secs(5)).await.unwrap();
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `std::string::String: DataProvider<_>` is not satisfied
[INFO] [stdout]    --> src/config.rs:51:12
[INFO] [stdout]     |
[INFO] [stdout]  51 |     return RemoteConfig::new("Example named config".to_owned(), data_provider, Duration::from_secs(5)).await.unwrap();
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `DataProvider<_>` is not implemented for `std::string::String`
[INFO] [stdout]     |
[INFO] [stdout] help: the trait `DataProvider<Data>` is implemented for `HttpDataProvider<Data, Extractor>`
[INFO] [stdout]    --> src/data_providers/http.rs:41:1
[INFO] [stdout]     |
[INFO] [stdout]  41 | impl <Data: Send + Sync, Extractor: HttpDataExtractor<Data> + Sync> DataProvider<Data> for HttpDataProvider<Data, Extractor> {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] note: required by a bound in `RemoteConfig<Data, Provider>`
[INFO] [stdout]    --> src/config.rs:124:36
[INFO] [stdout]     |
[INFO] [stdout] 124 | impl <Data: Send + Sync, Provider: DataProvider<Data> + Send> RemoteConfig<Data, Provider> {
[INFO] [stdout]     |                                    ^^^^^^^^^^^^^^^^^^ required by this bound in `RemoteConfig<Data, Provider>`
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `std::string::String: DataProvider<_>` is not satisfied
[INFO] [stdout]    --> src/config.rs:51:104
[INFO] [stdout]     |
[INFO] [stdout]  51 |     return RemoteConfig::new("Example named config".to_owned(), data_provider, Duration::from_secs(5)).await.unwrap();
[INFO] [stdout]     |                                                                                                        ^^^^^ the trait `DataProvider<_>` is not implemented for `std::string::String`
[INFO] [stdout]     |
[INFO] [stdout] help: the trait `DataProvider<Data>` is implemented for `HttpDataProvider<Data, Extractor>`
[INFO] [stdout]    --> src/data_providers/http.rs:41:1
[INFO] [stdout]     |
[INFO] [stdout]  41 | impl <Data: Send + Sync, Extractor: HttpDataExtractor<Data> + Sync> DataProvider<Data> for HttpDataProvider<Data, Extractor> {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] note: required by a bound in `RemoteConfig<Data, Provider>`
[INFO] [stdout]    --> src/config.rs:124:36
[INFO] [stdout]     |
[INFO] [stdout] 124 | impl <Data: Send + Sync, Provider: DataProvider<Data> + Send> RemoteConfig<Data, Provider> {
[INFO] [stdout]     |                                    ^^^^^^^^^^^^^^^^^^ required by this bound in `RemoteConfig<Data, Provider>`
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `std::string::String: DataProvider<_>` is not satisfied
[INFO] [stdout]   --> src/config.rs:51:12
[INFO] [stdout]    |
[INFO] [stdout] 51 |     return RemoteConfig::new("Example named config".to_owned(), data_provider, Duration::from_secs(5)).await.unwrap();
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `DataProvider<_>` is not implemented for `std::string::String`
[INFO] [stdout]    |
[INFO] [stdout] help: the trait `DataProvider<Data>` is implemented for `HttpDataProvider<Data, Extractor>`
[INFO] [stdout]   --> src/data_providers/http.rs:41:1
[INFO] [stdout]    |
[INFO] [stdout] 41 | impl <Data: Send + Sync, Extractor: HttpDataExtractor<Data> + Sync> DataProvider<Data> for HttpDataProvider<Data, Extractor> {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] note: required by a bound in `RemoteConfig`
[INFO] [stdout]   --> src/config.rs:67:54
[INFO] [stdout]    |
[INFO] [stdout] 67 | pub struct RemoteConfig<Data: Send + Sync, Provider: DataProvider<Data> + Send> {
[INFO] [stdout]    |                                                      ^^^^^^^^^^^^^^^^^^ required by this bound in `RemoteConfig`
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]   --> src/config.rs:51:12
[INFO] [stdout]    |
[INFO] [stdout] 51 |     return RemoteConfig::new("Example named config".to_owned(), data_provider, Duration::from_secs(5)).await.unwrap();
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected `RemoteConfig<HashMap<String, ...>, ...>`, found `RemoteConfig<_, String>`
[INFO] [stdout]    |
[INFO] [stdout]    = note: expected struct `RemoteConfig<HashMap<String, String>, HttpDataProvider<..., ...>>`
[INFO] [stdout]               found struct `RemoteConfig<_, std::string::String>`
[INFO] [stdout]    = note: the full name for the type has been written to '/tmp/rustdoctestDuSNHo/rust_out.long-type-3868785803129443635.txt'
[INFO] [stdout]    = note: consider using `--verbose` to print the full type name to the console
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 7 previous errors
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0061, E0277, E0308.
[INFO] [stdout] For more information about an error, try `rustc --explain E0061`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/lib.rs - (line 54) stdout ----
[INFO] [stdout] error[E0277]: the trait bound `std::string::String: DataProvider<_>` is not satisfied
[INFO] [stdout]   --> src/lib.rs:78:12
[INFO] [stdout]    |
[INFO] [stdout] 78 |     return RemoteConfig::new("Example named config".to_owned(), data_provider, Duration::from_secs(5)).await.unwrap();
[INFO] [stdout]    |            ^^^^^^^^^^^^ the trait `DataProvider<_>` is not implemented for `std::string::String`
[INFO] [stdout]    |
[INFO] [stdout] help: the trait `DataProvider<Data>` is implemented for `HttpDataProvider<Data, Extractor>`
[INFO] [stdout]   --> src/data_providers/http.rs:41:1
[INFO] [stdout]    |
[INFO] [stdout] 41 | impl <Data: Send + Sync, Extractor: HttpDataExtractor<Data> + Sync> DataProvider<Data> for HttpDataProvider<Data, Extractor> {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] note: required by a bound in `RemoteConfig`
[INFO] [stdout]   --> src/config.rs:67:54
[INFO] [stdout]    |
[INFO] [stdout] 67 | pub struct RemoteConfig<Data: Send + Sync, Provider: DataProvider<Data> + Send> {
[INFO] [stdout]    |                                                      ^^^^^^^^^^^^^^^^^^ required by this bound in `RemoteConfig`
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `std::string::String: DataProvider<_>` is not satisfied
[INFO] [stdout]    --> src/lib.rs:78:30
[INFO] [stdout]     |
[INFO] [stdout]  78 |     return RemoteConfig::new("Example named config".to_owned(), data_provider, Duration::from_secs(5)).await.unwrap();
[INFO] [stdout]     |            ----------------- ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `DataProvider<_>` is not implemented for `std::string::String`
[INFO] [stdout]     |            |
[INFO] [stdout]     |            required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] help: the trait `DataProvider<Data>` is implemented for `HttpDataProvider<Data, Extractor>`
[INFO] [stdout]    --> src/data_providers/http.rs:41:1
[INFO] [stdout]     |
[INFO] [stdout]  41 | impl <Data: Send + Sync, Extractor: HttpDataExtractor<Data> + Sync> DataProvider<Data> for HttpDataProvider<Data, Extractor> {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] note: required by a bound in `RemoteConfig::<Data, Provider>::new`
[INFO] [stdout]    --> src/config.rs:124:36
[INFO] [stdout]     |
[INFO] [stdout] 124 | impl <Data: Send + Sync, Provider: DataProvider<Data> + Send> RemoteConfig<Data, Provider> {
[INFO] [stdout]     |                                    ^^^^^^^^^^^^^^^^^^ required by this bound in `RemoteConfig::<Data, Provider>::new`
[INFO] [stdout] ...
[INFO] [stdout] 129 |     pub async fn new(
[INFO] [stdout]     |                  --- required by a bound in this associated function
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this function takes 2 arguments but 3 arguments were supplied
[INFO] [stdout]    --> src/lib.rs:78:12
[INFO] [stdout]     |
[INFO] [stdout]  78 |     return RemoteConfig::new("Example named config".to_owned(), data_provider, Duration::from_secs(5)).await.unwrap();
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^                                    ------------- unexpected argument #2 of type `HttpDataProvider<_, SerdeDataExtractor<_>>`
[INFO] [stdout]     |
[INFO] [stdout] note: associated function defined here
[INFO] [stdout]    --> src/config.rs:129:18
[INFO] [stdout]     |
[INFO] [stdout] 129 |     pub async fn new(
[INFO] [stdout]     |                  ^^^
[INFO] [stdout] help: remove the extra argument
[INFO] [stdout]     |
[INFO] [stdout]  78 -     return RemoteConfig::new("Example named config".to_owned(), data_provider, Duration::from_secs(5)).await.unwrap();
[INFO] [stdout]  78 +     return RemoteConfig::new("Example named config".to_owned(), Duration::from_secs(5)).await.unwrap();
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `std::string::String: DataProvider<_>` is not satisfied
[INFO] [stdout]    --> src/lib.rs:78:12
[INFO] [stdout]     |
[INFO] [stdout]  78 |     return RemoteConfig::new("Example named config".to_owned(), data_provider, Duration::from_secs(5)).await.unwrap();
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `DataProvider<_>` is not implemented for `std::string::String`
[INFO] [stdout]     |
[INFO] [stdout] help: the trait `DataProvider<Data>` is implemented for `HttpDataProvider<Data, Extractor>`
[INFO] [stdout]    --> src/data_providers/http.rs:41:1
[INFO] [stdout]     |
[INFO] [stdout]  41 | impl <Data: Send + Sync, Extractor: HttpDataExtractor<Data> + Sync> DataProvider<Data> for HttpDataProvider<Data, Extractor> {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] note: required by a bound in `RemoteConfig<Data, Provider>`
[INFO] [stdout]    --> src/config.rs:124:36
[INFO] [stdout]     |
[INFO] [stdout] 124 | impl <Data: Send + Sync, Provider: DataProvider<Data> + Send> RemoteConfig<Data, Provider> {
[INFO] [stdout]     |                                    ^^^^^^^^^^^^^^^^^^ required by this bound in `RemoteConfig<Data, Provider>`
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `std::string::String: DataProvider<_>` is not satisfied
[INFO] [stdout]    --> src/lib.rs:78:104
[INFO] [stdout]     |
[INFO] [stdout]  78 |     return RemoteConfig::new("Example named config".to_owned(), data_provider, Duration::from_secs(5)).await.unwrap();
[INFO] [stdout]     |                                                                                                        ^^^^^ the trait `DataProvider<_>` is not implemented for `std::string::String`
[INFO] [stdout]     |
[INFO] [stdout] help: the trait `DataProvider<Data>` is implemented for `HttpDataProvider<Data, Extractor>`
[INFO] [stdout]    --> src/data_providers/http.rs:41:1
[INFO] [stdout]     |
[INFO] [stdout]  41 | impl <Data: Send + Sync, Extractor: HttpDataExtractor<Data> + Sync> DataProvider<Data> for HttpDataProvider<Data, Extractor> {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] note: required by a bound in `RemoteConfig<Data, Provider>`
[INFO] [stdout]    --> src/config.rs:124:36
[INFO] [stdout]     |
[INFO] [stdout] 124 | impl <Data: Send + Sync, Provider: DataProvider<Data> + Send> RemoteConfig<Data, Provider> {
[INFO] [stdout]     |                                    ^^^^^^^^^^^^^^^^^^ required by this bound in `RemoteConfig<Data, Provider>`
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the trait bound `std::string::String: DataProvider<_>` is not satisfied
[INFO] [stdout]   --> src/lib.rs:78:12
[INFO] [stdout]    |
[INFO] [stdout] 78 |     return RemoteConfig::new("Example named config".to_owned(), data_provider, Duration::from_secs(5)).await.unwrap();
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `DataProvider<_>` is not implemented for `std::string::String`
[INFO] [stdout]    |
[INFO] [stdout] help: the trait `DataProvider<Data>` is implemented for `HttpDataProvider<Data, Extractor>`
[INFO] [stdout]   --> src/data_providers/http.rs:41:1
[INFO] [stdout]    |
[INFO] [stdout] 41 | impl <Data: Send + Sync, Extractor: HttpDataExtractor<Data> + Sync> DataProvider<Data> for HttpDataProvider<Data, Extractor> {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] note: required by a bound in `RemoteConfig`
[INFO] [stdout]   --> src/config.rs:67:54
[INFO] [stdout]    |
[INFO] [stdout] 67 | pub struct RemoteConfig<Data: Send + Sync, Provider: DataProvider<Data> + Send> {
[INFO] [stdout]    |                                                      ^^^^^^^^^^^^^^^^^^ required by this bound in `RemoteConfig`
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]   --> src/lib.rs:78:12
[INFO] [stdout]    |
[INFO] [stdout] 78 |     return RemoteConfig::new("Example named config".to_owned(), data_provider, Duration::from_secs(5)).await.unwrap();
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected `RemoteConfig<HashMap<String, ...>, ...>`, found `RemoteConfig<_, String>`
[INFO] [stdout]    |
[INFO] [stdout]    = note: expected struct `RemoteConfig<HashMap<String, String>, HttpDataProvider<..., ...>>`
[INFO] [stdout]               found struct `RemoteConfig<_, std::string::String>`
[INFO] [stdout]    = note: the full name for the type has been written to '/tmp/rustdoctestTBdZCu/rust_out.long-type-11380946850050454968.txt'
[INFO] [stdout]    = note: consider using `--verbose` to print the full type name to the console
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 7 previous errors
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0061, E0277, E0308.
[INFO] [stdout] For more information about an error, try `rustc --explain E0061`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     src/config.rs - config::RemoteConfig (line 27)
[INFO] [stdout]     src/lib.rs - (line 54)
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 1 passed; 2 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.84s
[INFO] [stdout] 
[INFO] [stderr] error: doctest failed, to rerun pass `--doc`
[INFO] running `Command { std: "docker" "inspect" "7305a2465ea5e14185c8e5659fe4d318b19c39917139615c69e4933d149a952f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7305a2465ea5e14185c8e5659fe4d318b19c39917139615c69e4933d149a952f", kill_on_drop: false }`
[INFO] [stdout] 7305a2465ea5e14185c8e5659fe4d318b19c39917139615c69e4933d149a952f
