[INFO] fetching crate mongodb-macro 1.0.4...
[INFO] testing mongodb-macro-1.0.4 against master#c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38 for pr-146098-8
[INFO] extracting crate mongodb-macro 1.0.4 into /workspace/builds/worker-0-tc1/source
[INFO] started tweaking crates.io crate mongodb-macro 1.0.4
[INFO] finished tweaking crates.io crate mongodb-macro 1.0.4
[INFO] tweaked toml for crates.io crate mongodb-macro 1.0.4 written to /workspace/builds/worker-0-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate mongodb-macro 1.0.4 on toolchain c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "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" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "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 258 packages to latest compatible versions
[INFO] [stderr]       Adding generic-array v0.14.7 (available: v0.14.9)
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded macro_magic v0.5.1
[INFO] [stderr]   Downloaded rustc_version_runtime v0.3.0
[INFO] [stderr]   Downloaded unicode-properties v0.1.4
[INFO] [stderr]   Downloaded nested-env-parser v1.1.0
[INFO] [stderr]   Downloaded fsio v0.4.1
[INFO] [stderr]   Downloaded macro_magic_core_macros v0.5.1
[INFO] [stderr]   Downloaded mongodb-internal-macros v3.3.0
[INFO] [stderr]   Downloaded resolv-conf v0.7.5
[INFO] [stderr]   Downloaded anstyle-wincon v3.0.11
[INFO] [stderr]   Downloaded mongocrypt-sys v0.1.4+1.12.0
[INFO] [stderr]   Downloaded mongocrypt v0.3.1
[INFO] [stderr]   Downloaded derive-syn-parse v0.2.0
[INFO] [stderr]   Downloaded macro_magic_core v0.5.1
[INFO] [stderr]   Downloaded macro_magic_macros v0.5.1
[INFO] [stderr]   Downloaded hickory-resolver v0.24.4
[INFO] [stderr]   Downloaded bson v2.15.0
[INFO] [stderr]   Downloaded webpki-roots v1.0.4
[INFO] [stderr]   Downloaded mongodb v3.3.0
[INFO] [stderr]   Downloaded hickory-proto v0.24.4
[INFO] [stderr]   Downloaded envmnt v0.10.4
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 9ad747d14294795ae50b03798db020e80769a15829e683b01eb0737c6863374f
[INFO] running `Command { std: "docker" "start" "-a" "9ad747d14294795ae50b03798db020e80769a15829e683b01eb0737c6863374f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "9ad747d14294795ae50b03798db020e80769a15829e683b01eb0737c6863374f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9ad747d14294795ae50b03798db020e80769a15829e683b01eb0737c6863374f", kill_on_drop: false }`
[INFO] [stdout] 9ad747d14294795ae50b03798db020e80769a15829e683b01eb0737c6863374f
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 0efdf19a58fc51393ba81e6bcdb7dfd2edee7d5a1776556279a4d401a0354698
[INFO] running `Command { std: "docker" "start" "-a" "0efdf19a58fc51393ba81e6bcdb7dfd2edee7d5a1776556279a4d401a0354698", kill_on_drop: false }`
[INFO] [stderr]    Compiling utf8parse v0.2.2
[INFO] [stderr]    Compiling is_terminal_polyfill v1.70.2
[INFO] [stderr]    Compiling anstyle-query v1.1.5
[INFO] [stderr]    Compiling colorchoice v1.0.4
[INFO] [stderr]    Compiling clap_lex v0.7.6
[INFO] [stderr]    Compiling fsio v0.4.1
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]    Compiling syn v2.0.110
[INFO] [stderr]    Compiling anstyle-parse v0.2.7
[INFO] [stderr]    Compiling anstream v0.6.21
[INFO] [stderr]    Compiling clap_builder v4.5.51
[INFO] [stderr]    Compiling envmnt v0.10.4
[INFO] [stderr]    Compiling nested-env-parser v1.1.0
[INFO] [stderr]    Compiling clap_derive v4.5.49
[INFO] [stderr]    Compiling clap v4.5.51
[INFO] [stderr]    Compiling mongodb-macro v1.0.4 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 9.80s
[INFO] running `Command { std: "docker" "inspect" "0efdf19a58fc51393ba81e6bcdb7dfd2edee7d5a1776556279a4d401a0354698", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0efdf19a58fc51393ba81e6bcdb7dfd2edee7d5a1776556279a4d401a0354698", kill_on_drop: false }`
[INFO] [stdout] 0efdf19a58fc51393ba81e6bcdb7dfd2edee7d5a1776556279a4d401a0354698
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] c3d8de63dddb5f03f719b7f463355c401f583e6ee56a62cba51707c17991eb23
[INFO] running `Command { std: "docker" "start" "-a" "c3d8de63dddb5f03f719b7f463355c401f583e6ee56a62cba51707c17991eb23", kill_on_drop: false }`
[INFO] [stderr]    Compiling crunchy v0.2.4
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]    Compiling getrandom v0.2.16
[INFO] [stderr]    Compiling generic-array v0.14.7
[INFO] [stderr]    Compiling once_cell v1.21.3
[INFO] [stderr]    Compiling zeroize v1.8.2
[INFO] [stderr]    Compiling socket2 v0.6.1
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling macro_magic_core_macros v0.5.1
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling derive-syn-parse v0.2.0
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling mio v1.1.0
[INFO] [stderr]    Compiling tinyvec v1.10.0
[INFO] [stderr]    Compiling darling_core v0.21.3
[INFO] [stderr]    Compiling rustls-pki-types v1.13.0
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling time-core v0.1.6
[INFO] [stderr]    Compiling semver v1.0.27
[INFO] [stderr]    Compiling percent-encoding v2.3.2
[INFO] [stderr]    Compiling tiny-keccak v2.0.2
[INFO] [stderr]    Compiling untrusted v0.9.0
[INFO] [stderr]    Compiling const-random-macro v0.1.16
[INFO] [stderr]    Compiling rand_core v0.9.3
[INFO] [stderr]    Compiling serde_json v1.0.145
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling rustc_version v0.4.1
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling time-macros v0.2.24
[INFO] [stderr]    Compiling const-random v0.1.18
[INFO] [stderr]    Compiling form_urlencoded v1.2.2
[INFO] [stderr]    Compiling deranged v0.5.5
[INFO] [stderr]    Compiling crypto-common v0.1.7
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]    Compiling tokio v1.48.0
[INFO] [stderr]    Compiling macro_magic_core v0.5.1
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling tracing-attributes v0.1.30
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling rustls v0.23.35
[INFO] [stderr]    Compiling mongocrypt-sys v0.1.4+1.12.0
[INFO] [stderr]    Compiling bitvec v1.0.1
[INFO] [stderr]    Compiling rustc_version_runtime v0.3.0
[INFO] [stderr]    Compiling url v2.5.7
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]    Compiling rand v0.9.2
[INFO] [stderr]    Compiling macro_magic_macros v0.5.1
[INFO] [stderr]    Compiling uuid v1.18.1
[INFO] [stderr]    Compiling futures-channel v0.3.31
[INFO] [stderr]    Compiling enum-as-inner v0.6.1
[INFO] [stderr]    Compiling serde_bytes v0.11.19
[INFO] [stderr]    Compiling rustversion v1.0.22
[INFO] [stderr]    Compiling ipnet v2.11.0
[INFO] [stderr]    Compiling lru-cache v0.1.2
[INFO] [stderr]    Compiling macro_magic v0.5.1
[INFO] [stderr]    Compiling unicode-normalization v0.1.25
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling webpki-roots v1.0.4
[INFO] [stderr]    Compiling typed-builder-macro v0.20.1
[INFO] [stderr]    Compiling clap_derive v4.5.49
[INFO] [stderr]    Compiling iana-time-zone v0.1.64
[INFO] [stderr]    Compiling unicode-properties v0.1.4
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling time v0.3.44
[INFO] [stderr]    Compiling resolv-conf v0.7.5
[INFO] [stderr]    Compiling derive_more v0.99.20
[INFO] [stderr]    Compiling webpki-roots v0.26.11
[INFO] [stderr]    Compiling stringprep v0.1.5
[INFO] [stderr]    Compiling mongodb-internal-macros v3.3.0
[INFO] [stderr]    Compiling sha1 v0.10.6
[INFO] [stderr]    Compiling sha2 v0.10.9
[INFO] [stderr]    Compiling md-5 v0.10.6
[INFO] [stderr]    Compiling pbkdf2 v0.11.0
[INFO] [stderr]    Compiling hmac v0.12.1
[INFO] [stderr]    Compiling derive-where v1.6.0
[INFO] [stderr]    Compiling socket2 v0.5.10
[INFO] [stderr]    Compiling take_mut v0.2.2
[INFO] [stderr]    Compiling chrono v0.4.42
[INFO] [stderr]    Compiling darling_macro v0.21.3
[INFO] [stderr]    Compiling typed-builder v0.20.1
[INFO] [stderr]    Compiling darling v0.21.3
[INFO] [stderr]    Compiling serde_with_macros v3.15.1
[INFO] [stderr]    Compiling clap v4.5.51
[INFO] [stderr]    Compiling mongodb-macro v1.0.4 (/opt/rustwide/workdir)
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling rustls-webpki v0.103.8
[INFO] [stderr]    Compiling bson v2.15.0
[INFO] [stderr]    Compiling serde_with v3.15.1
[INFO] [stderr]    Compiling hickory-proto v0.24.4
[INFO] [stderr]    Compiling tokio-util v0.7.17
[INFO] [stderr]    Compiling mongocrypt v0.3.1
[INFO] [stderr]    Compiling hickory-resolver v0.24.4
[INFO] [stderr]    Compiling tokio-rustls v0.26.4
[INFO] [stderr]    Compiling mongodb v3.3.0
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1m 30s
[INFO] running `Command { std: "docker" "inspect" "c3d8de63dddb5f03f719b7f463355c401f583e6ee56a62cba51707c17991eb23", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c3d8de63dddb5f03f719b7f463355c401f583e6ee56a62cba51707c17991eb23", kill_on_drop: false }`
[INFO] [stdout] c3d8de63dddb5f03f719b7f463355c401f583e6ee56a62cba51707c17991eb23
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] e4fb7125ad6c941055f73e92364a853d09c9e20d2a95a2d4bae70efe29e7cfe5
[INFO] running `Command { std: "docker" "start" "-a" "e4fb7125ad6c941055f73e92364a853d09c9e20d2a95a2d4bae70efe29e7cfe5", kill_on_drop: false }`
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.34s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/mongodb_macro-eb4db645616e3414)
[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; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests mongodb_macro
[INFO] [stdout] 
[INFO] [stdout] running 20 tests
[INFO] [stdout] test src/lib.rs - (line 42) - compile ... FAILED
[INFO] [stdout] test src/database.rs - database::database_config (line 7) ... ok
[INFO] [stdout] test src/lib.rs - (line 17) - compile ... FAILED
[INFO] [stdout] test src/collection.rs - collection::collection (line 78) ... FAILED
[INFO] [stdout] test src/lib.rs - (line 68) - compile ... FAILED
[INFO] [stdout] test src/client.rs - client::client_config (line 23) ... ok
[INFO] [stdout] test src/client.rs - client::client_config (line 7) ... ok
[INFO] [stdout] test src/collection.rs - collection::collection (line 46) ... FAILED
[INFO] [stdout] test src/database.rs - database::database_config (line 24) ... ok
[INFO] [stdout] test src/collection.rs - collection::collection_config (line 7) ... ok
[INFO] [stdout] test src/collection.rs - collection::collection_config (line 22) ... ok
[INFO] [stdout] test src/collection.rs - collection::collection (line 62) ... FAILED
[INFO] [stdout] test src/lib.rs - (line 94) - compile ... FAILED
[INFO] [stdout] test src/client.rs - client::client (line 72) ... ok
[INFO] [stdout] test src/client.rs - client::client (line 55) ... ok
[INFO] [stdout] test src/opts.rs - opts::config (line 22) ... ok
[INFO] [stdout] test src/opts.rs - opts::config (line 37) ... ok
[INFO] [stdout] test src/opts.rs - opts::config (line 5) ... ok
[INFO] [stdout] test src/database.rs - database::database (line 79) ... ok
[INFO] [stdout] test src/database.rs - database::database (line 61) ... ok
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- src/lib.rs - (line 42) stdout ----
[INFO] [stdout] error: unexpected token: `...`
[INFO] [stdout]   --> src/lib.rs:63:5
[INFO] [stdout]    |
[INFO] [stdout] 63 |     ...
[INFO] [stdout]    |     ^^^
[INFO] [stdout]    |
[INFO] [stdout] help: use `..` for an exclusive range
[INFO] [stdout]    |
[INFO] [stdout] 63 -     ...
[INFO] [stdout] 63 +     ..
[INFO] [stdout]    |
[INFO] [stdout] help: or `..=` for an inclusive range
[INFO] [stdout]    |
[INFO] [stdout] 63 -     ...
[INFO] [stdout] 63 +     ..=
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error[E0586]: inclusive range with no end
[INFO] [stdout]   --> src/lib.rs:63:5
[INFO] [stdout]    |
[INFO] [stdout] 63 |     ...
[INFO] [stdout]    |     ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: inclusive ranges must be bounded at the end (`..=b` or `a..=b`)
[INFO] [stdout] help: use `..` instead
[INFO] [stdout]    |
[INFO] [stdout] 63 -     ...
[INFO] [stdout] 63 +     ..
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error[E0752]: `main` function is not allowed to be `async`
[INFO] [stdout]   --> src/lib.rs:52:1
[INFO] [stdout]    |
[INFO] [stdout] 52 | async fn main() -> std::io::Result<()> {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `main` function is not allowed to be `async`
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 3 previous errors
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0586, E0752.
[INFO] [stdout] For more information about an error, try `rustc --explain E0586`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/lib.rs - (line 17) stdout ----
[INFO] [stdout] error: unexpected token: `...`
[INFO] [stdout]   --> src/lib.rs:37:5
[INFO] [stdout]    |
[INFO] [stdout] 37 |     ...
[INFO] [stdout]    |     ^^^
[INFO] [stdout]    |
[INFO] [stdout] help: use `..` for an exclusive range
[INFO] [stdout]    |
[INFO] [stdout] 37 -     ...
[INFO] [stdout] 37 +     ..
[INFO] [stdout]    |
[INFO] [stdout] help: or `..=` for an inclusive range
[INFO] [stdout]    |
[INFO] [stdout] 37 -     ...
[INFO] [stdout] 37 +     ..=
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error[E0586]: inclusive range with no end
[INFO] [stdout]   --> src/lib.rs:37:5
[INFO] [stdout]    |
[INFO] [stdout] 37 |     ...
[INFO] [stdout]    |     ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: inclusive ranges must be bounded at the end (`..=b` or `a..=b`)
[INFO] [stdout] help: use `..` instead
[INFO] [stdout]    |
[INFO] [stdout] 37 -     ...
[INFO] [stdout] 37 +     ..
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be sent between threads safely
[INFO] [stdout]    --> src/lib.rs:24:1
[INFO] [stdout]     |
[INFO] [stdout]  24 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be sent between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:8
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |        ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Send`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Send>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be shared between threads safely
[INFO] [stdout]    --> src/lib.rs:24:1
[INFO] [stdout]     |
[INFO] [stdout]  24 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be shared between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:15
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |               ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Sync`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Sync>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be sent between threads safely
[INFO] [stdout]    --> src/lib.rs:24:1
[INFO] [stdout]     |
[INFO] [stdout]  24 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     | |
[INFO] [stdout]     | `T` cannot be sent between threads safely
[INFO] [stdout]     | required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `Database::collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/db.rs:120:26
[INFO] [stdout]     |
[INFO] [stdout] 120 |     pub fn collection<T: Send + Sync>(&self, name: &str) -> Collection<T> {
[INFO] [stdout]     |                          ^^^^ required by this bound in `Database::collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Send`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Send>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be shared between threads safely
[INFO] [stdout]    --> src/lib.rs:24:1
[INFO] [stdout]     |
[INFO] [stdout]  24 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     | |
[INFO] [stdout]     | `T` cannot be shared between threads safely
[INFO] [stdout]     | required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `Database::collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/db.rs:120:33
[INFO] [stdout]     |
[INFO] [stdout] 120 |     pub fn collection<T: Send + Sync>(&self, name: &str) -> Collection<T> {
[INFO] [stdout]     |                                 ^^^^ required by this bound in `Database::collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Sync`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Sync>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be sent between threads safely
[INFO] [stdout]    --> src/lib.rs:24:1
[INFO] [stdout]     |
[INFO] [stdout]  24 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be sent between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:8
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |        ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Send`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Send>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be shared between threads safely
[INFO] [stdout]    --> src/lib.rs:24:1
[INFO] [stdout]     |
[INFO] [stdout]  24 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be shared between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:15
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |               ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Sync`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Sync>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be sent between threads safely
[INFO] [stdout]    --> src/lib.rs:24:1
[INFO] [stdout]     |
[INFO] [stdout]  24 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be sent between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:8
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |        ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Send`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Send>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be shared between threads safely
[INFO] [stdout]    --> src/lib.rs:24:1
[INFO] [stdout]     |
[INFO] [stdout]  24 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be shared between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:15
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |               ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Sync`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Sync>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be sent between threads safely
[INFO] [stdout]    --> src/lib.rs:24:1
[INFO] [stdout]     |
[INFO] [stdout]  24 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be sent between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:8
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |        ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Send`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Send>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be shared between threads safely
[INFO] [stdout]    --> src/lib.rs:24:1
[INFO] [stdout]     |
[INFO] [stdout]  24 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be shared between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:15
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |               ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Sync`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Sync>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0752]: `main` function is not allowed to be `async`
[INFO] [stdout]   --> src/lib.rs:28:1
[INFO] [stdout]    |
[INFO] [stdout] 28 | async fn main() -> std::io::Result<()> {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `main` function is not allowed to be `async`
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 13 previous errors
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0277, E0586, E0752.
[INFO] [stdout] For more information about an error, try `rustc --explain E0277`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/collection.rs - collection::collection (line 78) stdout ----
[INFO] [stdout] error[E0277]: `T` cannot be sent between threads safely
[INFO] [stdout]    --> src/collection.rs:80:1
[INFO] [stdout]     |
[INFO] [stdout]  80 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be sent between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:8
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |        ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Send`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Send>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be shared between threads safely
[INFO] [stdout]    --> src/collection.rs:80:1
[INFO] [stdout]     |
[INFO] [stdout]  80 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be shared between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:15
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |               ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Sync`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Sync>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be sent between threads safely
[INFO] [stdout]    --> src/collection.rs:80:1
[INFO] [stdout]     |
[INFO] [stdout]  80 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     | |
[INFO] [stdout]     | `T` cannot be sent between threads safely
[INFO] [stdout]     | required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `Database::collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/db.rs:120:26
[INFO] [stdout]     |
[INFO] [stdout] 120 |     pub fn collection<T: Send + Sync>(&self, name: &str) -> Collection<T> {
[INFO] [stdout]     |                          ^^^^ required by this bound in `Database::collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Send`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Send>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be shared between threads safely
[INFO] [stdout]    --> src/collection.rs:80:1
[INFO] [stdout]     |
[INFO] [stdout]  80 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     | |
[INFO] [stdout]     | `T` cannot be shared between threads safely
[INFO] [stdout]     | required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `Database::collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/db.rs:120:33
[INFO] [stdout]     |
[INFO] [stdout] 120 |     pub fn collection<T: Send + Sync>(&self, name: &str) -> Collection<T> {
[INFO] [stdout]     |                                 ^^^^ required by this bound in `Database::collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Sync`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Sync>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be sent between threads safely
[INFO] [stdout]    --> src/collection.rs:80:1
[INFO] [stdout]     |
[INFO] [stdout]  80 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be sent between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:8
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |        ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Send`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Send>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be shared between threads safely
[INFO] [stdout]    --> src/collection.rs:80:1
[INFO] [stdout]     |
[INFO] [stdout]  80 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be shared between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:15
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |               ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Sync`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Sync>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be sent between threads safely
[INFO] [stdout]    --> src/collection.rs:80:1
[INFO] [stdout]     |
[INFO] [stdout]  80 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be sent between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:8
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |        ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Send`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Send>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be shared between threads safely
[INFO] [stdout]    --> src/collection.rs:80:1
[INFO] [stdout]     |
[INFO] [stdout]  80 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be shared between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:15
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |               ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Sync`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Sync>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be sent between threads safely
[INFO] [stdout]    --> src/collection.rs:80:1
[INFO] [stdout]     |
[INFO] [stdout]  80 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be sent between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:8
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |        ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Send`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Send>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be shared between threads safely
[INFO] [stdout]    --> src/collection.rs:80:1
[INFO] [stdout]     |
[INFO] [stdout]  80 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be shared between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:15
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |               ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Sync`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Sync>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 10 previous errors
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0277`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/lib.rs - (line 68) stdout ----
[INFO] [stdout] error: unexpected token: `...`
[INFO] [stdout]   --> src/lib.rs:89:5
[INFO] [stdout]    |
[INFO] [stdout] 89 |     ...
[INFO] [stdout]    |     ^^^
[INFO] [stdout]    |
[INFO] [stdout] help: use `..` for an exclusive range
[INFO] [stdout]    |
[INFO] [stdout] 89 -     ...
[INFO] [stdout] 89 +     ..
[INFO] [stdout]    |
[INFO] [stdout] help: or `..=` for an inclusive range
[INFO] [stdout]    |
[INFO] [stdout] 89 -     ...
[INFO] [stdout] 89 +     ..=
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error[E0586]: inclusive range with no end
[INFO] [stdout]   --> src/lib.rs:89:5
[INFO] [stdout]    |
[INFO] [stdout] 89 |     ...
[INFO] [stdout]    |     ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: inclusive ranges must be bounded at the end (`..=b` or `a..=b`)
[INFO] [stdout] help: use `..` instead
[INFO] [stdout]    |
[INFO] [stdout] 89 -     ...
[INFO] [stdout] 89 +     ..
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error[E0752]: `main` function is not allowed to be `async`
[INFO] [stdout]   --> src/lib.rs:77:1
[INFO] [stdout]    |
[INFO] [stdout] 77 | async fn main() -> std::io::Result<()> {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `main` function is not allowed to be `async`
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 3 previous errors
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0586, E0752.
[INFO] [stdout] For more information about an error, try `rustc --explain E0586`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/collection.rs - collection::collection (line 46) stdout ----
[INFO] [stdout] error[E0277]: `T` cannot be sent between threads safely
[INFO] [stdout]    --> src/collection.rs:48:1
[INFO] [stdout]     |
[INFO] [stdout]  48 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be sent between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:8
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |        ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Send`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Send>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be shared between threads safely
[INFO] [stdout]    --> src/collection.rs:48:1
[INFO] [stdout]     |
[INFO] [stdout]  48 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be shared between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:15
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |               ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Sync`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Sync>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be sent between threads safely
[INFO] [stdout]    --> src/collection.rs:48:1
[INFO] [stdout]     |
[INFO] [stdout]  48 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     | |
[INFO] [stdout]     | `T` cannot be sent between threads safely
[INFO] [stdout]     | required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `Database::collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/db.rs:120:26
[INFO] [stdout]     |
[INFO] [stdout] 120 |     pub fn collection<T: Send + Sync>(&self, name: &str) -> Collection<T> {
[INFO] [stdout]     |                          ^^^^ required by this bound in `Database::collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Send`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Send>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be shared between threads safely
[INFO] [stdout]    --> src/collection.rs:48:1
[INFO] [stdout]     |
[INFO] [stdout]  48 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     | |
[INFO] [stdout]     | `T` cannot be shared between threads safely
[INFO] [stdout]     | required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `Database::collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/db.rs:120:33
[INFO] [stdout]     |
[INFO] [stdout] 120 |     pub fn collection<T: Send + Sync>(&self, name: &str) -> Collection<T> {
[INFO] [stdout]     |                                 ^^^^ required by this bound in `Database::collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Sync`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Sync>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be sent between threads safely
[INFO] [stdout]    --> src/collection.rs:48:1
[INFO] [stdout]     |
[INFO] [stdout]  48 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be sent between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:8
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |        ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Send`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Send>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be shared between threads safely
[INFO] [stdout]    --> src/collection.rs:48:1
[INFO] [stdout]     |
[INFO] [stdout]  48 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be shared between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:15
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stderr] error: doctest failed, to rerun pass `--doc`
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |               ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Sync`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Sync>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be sent between threads safely
[INFO] [stdout]    --> src/collection.rs:48:1
[INFO] [stdout]     |
[INFO] [stdout]  48 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be sent between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:8
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |        ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Send`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Send>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be shared between threads safely
[INFO] [stdout]    --> src/collection.rs:48:1
[INFO] [stdout]     |
[INFO] [stdout]  48 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be shared between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:15
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |               ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Sync`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Sync>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be sent between threads safely
[INFO] [stdout]    --> src/collection.rs:48:1
[INFO] [stdout]     |
[INFO] [stdout]  48 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be sent between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:8
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |        ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Send`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Send>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be shared between threads safely
[INFO] [stdout]    --> src/collection.rs:48:1
[INFO] [stdout]     |
[INFO] [stdout]  48 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts);
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be shared between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:15
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |               ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `$crate::collection` which comes from the expansion of the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Sync`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Sync>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 10 previous errors
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0277`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/collection.rs - collection::collection (line 62) stdout ----
[INFO] [stdout] error[E0277]: `T` cannot be sent between threads safely
[INFO] [stdout]    --> src/collection.rs:64:1
[INFO] [stdout]     |
[INFO] [stdout]  64 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts; ("MONGO_DB_URL", "MONGO_DB_NAME", "MONGO_COLLECTION_NAME"));
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be sent between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:8
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |        ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Send`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Send>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be shared between threads safely
[INFO] [stdout]    --> src/collection.rs:64:1
[INFO] [stdout]     |
[INFO] [stdout]  64 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts; ("MONGO_DB_URL", "MONGO_DB_NAME", "MONGO_COLLECTION_NAME"));
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be shared between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:15
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |               ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Sync`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Sync>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be sent between threads safely
[INFO] [stdout]    --> src/collection.rs:64:1
[INFO] [stdout]     |
[INFO] [stdout]  64 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts; ("MONGO_DB_URL", "MONGO_DB_NAME", "MONGO_COLLECTION_NAME"));
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     | |
[INFO] [stdout]     | `T` cannot be sent between threads safely
[INFO] [stdout]     | required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `Database::collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/db.rs:120:26
[INFO] [stdout]     |
[INFO] [stdout] 120 |     pub fn collection<T: Send + Sync>(&self, name: &str) -> Collection<T> {
[INFO] [stdout]     |                          ^^^^ required by this bound in `Database::collection`
[INFO] [stdout]     = note: this error originates in the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Send`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Send>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be shared between threads safely
[INFO] [stdout]    --> src/collection.rs:64:1
[INFO] [stdout]     |
[INFO] [stdout]  64 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts; ("MONGO_DB_URL", "MONGO_DB_NAME", "MONGO_COLLECTION_NAME"));
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     | |
[INFO] [stdout]     | `T` cannot be shared between threads safely
[INFO] [stdout]     | required by a bound introduced by this call
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `Database::collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/db.rs:120:33
[INFO] [stdout]     |
[INFO] [stdout] 120 |     pub fn collection<T: Send + Sync>(&self, name: &str) -> Collection<T> {
[INFO] [stdout]     |                                 ^^^^ required by this bound in `Database::collection`
[INFO] [stdout]     = note: this error originates in the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Sync`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Sync>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be sent between threads safely
[INFO] [stdout]    --> src/collection.rs:64:1
[INFO] [stdout]     |
[INFO] [stdout]  64 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts; ("MONGO_DB_URL", "MONGO_DB_NAME", "MONGO_COLLECTION_NAME"));
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be sent between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:8
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |        ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Send`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Send>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be shared between threads safely
[INFO] [stdout]    --> src/collection.rs:64:1
[INFO] [stdout]     |
[INFO] [stdout]  64 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts; ("MONGO_DB_URL", "MONGO_DB_NAME", "MONGO_COLLECTION_NAME"));
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be shared between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:15
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |               ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Sync`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Sync>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be sent between threads safely
[INFO] [stdout]    --> src/collection.rs:64:1
[INFO] [stdout]     |
[INFO] [stdout]  64 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts; ("MONGO_DB_URL", "MONGO_DB_NAME", "MONGO_COLLECTION_NAME"));
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be sent between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:8
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |        ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Send`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Send>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be shared between threads safely
[INFO] [stdout]    --> src/collection.rs:64:1
[INFO] [stdout]     |
[INFO] [stdout]  64 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts; ("MONGO_DB_URL", "MONGO_DB_NAME", "MONGO_COLLECTION_NAME"));
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be shared between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:15
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |               ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Sync`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Sync>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be sent between threads safely
[INFO] [stdout]    --> src/collection.rs:64:1
[INFO] [stdout]     |
[INFO] [stdout]  64 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts; ("MONGO_DB_URL", "MONGO_DB_NAME", "MONGO_COLLECTION_NAME"));
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be sent between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:8
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |        ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Send`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Send>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: `T` cannot be shared between threads safely
[INFO] [stdout]    --> src/collection.rs:64:1
[INFO] [stdout]     |
[INFO] [stdout]  64 | mongodb_macro::collection!(CollectionFactory; CollectionFactoryOpts; ("MONGO_DB_URL", "MONGO_DB_NAME", "MONGO_COLLECTION_NAME"));
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `T` cannot be shared between threads safely
[INFO] [stdout]     |
[INFO] [stdout] note: required by a bound in `mongodb::Collection`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/mongodb-3.3.0/src/coll.rs:76:15
[INFO] [stdout]     |
[INFO] [stdout]  74 | pub struct Collection<T>
[INFO] [stdout]     |            ---------- required by a bound in this struct
[INFO] [stdout]  75 | where
[INFO] [stdout]  76 |     T: Send + Sync,
[INFO] [stdout]     |               ^^^^ required by this bound in `Collection`
[INFO] [stdout]     = note: this error originates in the macro `mongodb_macro::collection` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: consider restricting type parameter `T` with trait `Sync`
[INFO] [stdout]    --> /opt/rustwide/workdir/src/collection.rs:118:34
[INFO] [stdout]     |
[INFO] [stdout] 118 |             pub async fn create<T: std::marker::Sync>(&self) -> Result<::mongodb::Collection<T>, ::mongodb::error::Error> {
[INFO] [stdout]     |                                  +++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 10 previous errors
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0277`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/lib.rs - (line 94) stdout ----
[INFO] [stdout] error: unexpected token: `...`
[INFO] [stdout]    --> src/lib.rs:120:5
[INFO] [stdout]     |
[INFO] [stdout] 120 |     ...
[INFO] [stdout]     |     ^^^
[INFO] [stdout]     |
[INFO] [stdout] help: use `..` for an exclusive range
[INFO] [stdout]     |
[INFO] [stdout] 120 -     ...
[INFO] [stdout] 120 +     ..
[INFO] [stdout]     |
[INFO] [stdout] help: or `..=` for an inclusive range
[INFO] [stdout]     |
[INFO] [stdout] 120 -     ...
[INFO] [stdout] 120 +     ..=
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] error[E0586]: inclusive range with no end
[INFO] [stdout]    --> src/lib.rs:120:5
[INFO] [stdout]     |
[INFO] [stdout] 120 |     ...
[INFO] [stdout]     |     ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: inclusive ranges must be bounded at the end (`..=b` or `a..=b`)
[INFO] [stdout] help: use `..` instead
[INFO] [stdout]     |
[INFO] [stdout] 120 -     ...
[INFO] [stdout] 120 +     ..
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] error[E0752]: `main` function is not allowed to be `async`
[INFO] [stdout]    --> src/lib.rs:109:1
[INFO] [stdout]     |
[INFO] [stdout] 109 | async fn main() -> std::io::Result<()> {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `main` function is not allowed to be `async`
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 3 previous errors
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0586, E0752.
[INFO] [stdout] For more information about an error, try `rustc --explain E0586`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     src/collection.rs - collection::collection (line 46)
[INFO] [stdout]     src/collection.rs - collection::collection (line 62)
[INFO] [stdout]     src/collection.rs - collection::collection (line 78)
[INFO] [stdout]     src/lib.rs - (line 17)
[INFO] [stdout]     src/lib.rs - (line 42)
[INFO] [stdout]     src/lib.rs - (line 68)
[INFO] [stdout]     src/lib.rs - (line 94)
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 13 passed; 7 failed; 0 ignored; 0 measured; 0 filtered out; finished in 3.19s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "e4fb7125ad6c941055f73e92364a853d09c9e20d2a95a2d4bae70efe29e7cfe5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e4fb7125ad6c941055f73e92364a853d09c9e20d2a95a2d4bae70efe29e7cfe5", kill_on_drop: false }`
[INFO] [stdout] e4fb7125ad6c941055f73e92364a853d09c9e20d2a95a2d4bae70efe29e7cfe5
