[INFO] cloning repository https://github.com/cheedonghu/news2tg
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/cheedonghu/news2tg" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fcheedonghu%2Fnews2tg", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fcheedonghu%2Fnews2tg'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] d5053539360a6fbf86619cb63ffbffe03c706beb
[INFO] checking cheedonghu/news2tg/d5053539360a6fbf86619cb63ffbffe03c706beb against master#04ff05c9c0cfbca33115c5f1b8bb20a66a54b799 for pr-147834
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fcheedonghu%2Fnews2tg" "/workspace/builds/worker-3-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/cheedonghu/news2tg
[INFO] finished tweaking git repo https://github.com/cheedonghu/news2tg
[INFO] tweaked toml for git repo https://github.com/cheedonghu/news2tg written to /workspace/builds/worker-3-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/cheedonghu/news2tg on toolchain 04ff05c9c0cfbca33115c5f1b8bb20a66a54b799
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+04ff05c9c0cfbca33115c5f1b8bb20a66a54b799" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/cheedonghu/news2tg already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+04ff05c9c0cfbca33115c5f1b8bb20a66a54b799" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded uuid v1.18.0
[INFO] [stderr]   Downloaded rc-box v1.3.0
[INFO] [stderr]   Downloaded takecell v0.1.1
[INFO] [stderr]   Downloaded prettyplease v0.2.36
[INFO] [stderr]   Downloaded getset v0.1.6
[INFO] [stderr]   Downloaded getopts v0.2.23
[INFO] [stderr]   Downloaded clap_derive v4.5.45
[INFO] [stderr]   Downloaded openai_dive v0.4.9
[INFO] [stderr]   Downloaded clap v4.5.45
[INFO] [stderr]   Downloaded minifier v0.0.41
[INFO] [stderr]   Downloaded html5ever v0.27.0
[INFO] [stderr]   Downloaded cssparser v0.31.2
[INFO] [stderr]   Downloaded selectors v0.25.0
[INFO] [stderr]   Downloaded clap_builder v4.5.44
[INFO] [stderr]   Downloaded markup5ever v0.12.1
[INFO] [stderr]   Downloaded teloxide v0.12.2
[INFO] [stderr]   Downloaded flexi_logger v0.28.5
[INFO] [stderr]   Downloaded aquamarine v0.1.12
[INFO] [stderr]   Downloaded teloxide-core v0.9.1
[INFO] [stderr]   Downloaded phf_macros v0.11.3
[INFO] [stderr]   Downloaded scraper v0.19.1
[INFO] [stderr]   Downloaded dptree v0.3.0
[INFO] [stderr]   Downloaded servo_arc v0.3.0
[INFO] [stderr]   Downloaded erasable v1.3.0
[INFO] [stderr]   Downloaded macro-utils v0.1.3
[INFO] [stderr]   Downloaded ego-tree v0.6.3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+04ff05c9c0cfbca33115c5f1b8bb20a66a54b799" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] d6d0b66f336d39126b96426ad71e8d2ca3c62ad3d04759d4fb6e615cb90b4256
[INFO] running `Command { std: "docker" "start" "-a" "d6d0b66f336d39126b96426ad71e8d2ca3c62ad3d04759d4fb6e615cb90b4256", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "d6d0b66f336d39126b96426ad71e8d2ca3c62ad3d04759d4fb6e615cb90b4256", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d6d0b66f336d39126b96426ad71e8d2ca3c62ad3d04759d4fb6e615cb90b4256", kill_on_drop: false }`
[INFO] [stdout] d6d0b66f336d39126b96426ad71e8d2ca3c62ad3d04759d4fb6e615cb90b4256
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+04ff05c9c0cfbca33115c5f1b8bb20a66a54b799" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 8e9e10d097a21ff204ff81d630262ba2b1f29b696ccc38305b904a3779619348
[INFO] running `Command { std: "docker" "start" "-a" "8e9e10d097a21ff204ff81d630262ba2b1f29b696ccc38305b904a3779619348", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.97
[INFO] [stderr]     Checking futures-io v0.3.31
[INFO] [stderr]    Compiling libc v0.2.175
[INFO] [stderr]    Compiling cc v1.2.32
[INFO] [stderr]     Checking log v0.4.27
[INFO] [stderr]    Compiling siphasher v1.0.1
[INFO] [stderr]     Checking phf_shared v0.11.3
[INFO] [stderr]    Compiling serde_json v1.0.142
[INFO] [stderr]    Compiling siphasher v0.3.11
[INFO] [stderr]    Compiling getrandom v0.3.3
[INFO] [stderr]     Checking new_debug_unreachable v1.0.6
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling strsim v0.10.0
[INFO] [stderr]    Compiling proc-macro-error-attr v1.0.4
[INFO] [stderr]    Compiling erasable v1.3.0
[INFO] [stderr]    Compiling anyhow v1.0.99
[INFO] [stderr]     Checking futf v0.1.5
[INFO] [stderr]    Compiling proc-macro-error v1.0.4
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]     Checking dtoa v1.0.10
[INFO] [stderr]     Checking anstyle-parse v0.2.7
[INFO] [stderr]     Checking tendril v0.4.3
[INFO] [stderr]     Checking dtoa-short v0.3.5
[INFO] [stderr]     Checking phf_shared v0.10.0
[INFO] [stderr]    Compiling itertools v0.14.0
[INFO] [stderr]     Checking zeroize v1.8.1
[INFO] [stderr]     Checking anstyle v1.0.11
[INFO] [stderr]     Checking anstyle-query v1.1.4
[INFO] [stderr]     Checking colorchoice v1.0.4
[INFO] [stderr]     Checking fxhash v0.2.1
[INFO] [stderr]     Checking regex-automata v0.4.9
[INFO] [stderr]     Checking rustls-pki-types v1.12.0
[INFO] [stderr]     Checking rc-box v1.3.0
[INFO] [stderr]     Checking phf v0.10.1
[INFO] [stderr]    Compiling itertools v0.9.0
[INFO] [stderr]     Checking servo_arc v0.3.0
[INFO] [stderr]     Checking anstream v0.6.20
[INFO] [stderr]     Checking either v1.15.0
[INFO] [stderr]     Checking matchit v0.7.3
[INFO] [stderr]     Checking takecell v0.1.1
[INFO] [stderr]     Checking take_mut v0.2.2
[INFO] [stderr]     Checking never v0.1.0
[INFO] [stderr]     Checking clap_lex v0.7.5
[INFO] [stderr]     Checking getopts v0.2.23
[INFO] [stderr]     Checking glob v0.3.3
[INFO] [stderr]     Checking macro-utils v0.1.3
[INFO] [stderr]     Checking clap_builder v4.5.44
[INFO] [stderr]     Checking strum v0.26.3
[INFO] [stderr]     Checking ego-tree v0.6.3
[INFO] [stderr]     Checking minifier v0.0.41
[INFO] [stderr]     Checking chrono v0.4.41
[INFO] [stderr]    Compiling quote v1.0.40
[INFO] [stderr]     Checking parking_lot_core v0.9.11
[INFO] [stderr]     Checking signal-hook-registry v1.4.6
[INFO] [stderr]     Checking mio v1.0.4
[INFO] [stderr]     Checking socket2 v0.6.0
[INFO] [stderr]     Checking socket2 v0.5.10
[INFO] [stderr]     Checking getrandom v0.2.16
[INFO] [stderr]    Compiling syn v2.0.106
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]     Checking parking_lot v0.12.4
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking uuid v1.18.0
[INFO] [stderr]    Compiling proc-macro-error-attr2 v2.0.0
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking ahash v0.8.12
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]    Compiling openssl-sys v0.9.109
[INFO] [stderr]    Compiling openssl v0.10.73
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]     Checking regex v1.11.1
[INFO] [stderr]    Compiling phf_generator v0.11.3
[INFO] [stderr]    Compiling phf_generator v0.10.0
[INFO] [stderr]    Compiling phf_codegen v0.10.0
[INFO] [stderr]    Compiling string_cache_codegen v0.5.4
[INFO] [stderr]    Compiling phf_codegen v0.11.3
[INFO] [stderr]    Compiling selectors v0.25.0
[INFO] [stderr]    Compiling markup5ever v0.12.1
[INFO] [stderr]    Compiling darling_core v0.13.4
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling proc-macro-error2 v2.0.1
[INFO] [stderr]    Compiling aquamarine v0.1.12
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling tracing-attributes v0.1.30
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]    Compiling zerovec-derive v0.11.1
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling phf_macros v0.11.3
[INFO] [stderr]    Compiling pin-project-internal v1.1.10
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling derive_more v0.99.20
[INFO] [stderr]    Compiling cssparser-macros v0.6.1
[INFO] [stderr]    Compiling html5ever v0.27.0
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.0
[INFO] [stderr]     Checking tokio v1.47.1
[INFO] [stderr]    Compiling prost-derive v0.13.5
[INFO] [stderr]     Checking phf v0.11.3
[INFO] [stderr]    Compiling async-stream-impl v0.3.6
[INFO] [stderr]     Checking cssparser v0.31.2
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]     Checking pin-project v1.1.10
[INFO] [stderr]     Checking async-stream v0.3.6
[INFO] [stderr]    Compiling clap_derive v4.5.45
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]    Compiling getset v0.1.6
[INFO] [stderr]     Checking zerofrom v0.1.6
[INFO] [stderr]     Checking tracing v0.1.41
[INFO] [stderr]     Checking yoke v0.8.0
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]    Compiling darling_macro v0.13.4
[INFO] [stderr]     Checking flexi_logger v0.28.5
[INFO] [stderr]     Checking zerovec v0.11.4
[INFO] [stderr]     Checking zerotrie v0.2.2
[INFO] [stderr]    Compiling darling v0.13.4
[INFO] [stderr]    Compiling serde_with_macros v1.5.2
[INFO] [stderr]     Checking prost v0.13.5
[INFO] [stderr]     Checking tinystr v0.8.1
[INFO] [stderr]     Checking potential_utf v0.1.2
[INFO] [stderr]     Checking icu_collections v2.0.0
[INFO] [stderr]     Checking icu_locale_core v2.0.0
[INFO] [stderr]     Checking serde v1.0.219
[INFO] [stderr]     Checking clap v4.5.45
[INFO] [stderr]     Checking icu_provider v2.0.0
[INFO] [stderr]     Checking icu_normalizer v2.0.0
[INFO] [stderr]     Checking icu_properties v2.0.1
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]     Checking axum-core v0.4.5
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]     Checking dptree v0.3.0
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking idna v1.0.3
[INFO] [stderr]     Checking tokio-util v0.7.16
[INFO] [stderr]     Checking tokio-native-tls v0.3.1
[INFO] [stderr]     Checking tower v0.5.2
[INFO] [stderr]     Checking tokio-stream v0.1.17
[INFO] [stderr]     Checking tokio-util v0.6.10
[INFO] [stderr]     Checking url v2.5.4
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking string_cache v0.8.9
[INFO] [stderr]     Checking toml v0.5.11
[INFO] [stderr]     Checking tower-http v0.6.6
[INFO] [stderr]     Checking axum v0.7.9
[INFO] [stderr]     Checking h2 v0.4.12
[INFO] [stderr]     Checking h2 v0.3.27
[INFO] [stderr]     Checking tower v0.4.13
[INFO] [stderr]     Checking scraper v0.19.1
[INFO] [stderr]     Checking hyper v1.6.0
[INFO] [stderr]     Checking hyper v0.14.32
[INFO] [stderr]     Checking hyper-util v0.1.16
[INFO] [stderr]     Checking hyper-tls v0.6.0
[INFO] [stderr]     Checking hyper-timeout v0.5.2
[INFO] [stderr]     Checking hyper-tls v0.5.0
[INFO] [stderr]     Checking reqwest v0.12.23
[INFO] [stderr]     Checking reqwest v0.11.27
[INFO] [stderr]     Checking tonic v0.12.3
[INFO] [stderr]     Checking teloxide-core v0.9.1
[INFO] [stderr]     Checking openai_dive v0.4.9
[INFO] [stderr]     Checking teloxide v0.12.2
[INFO] [stderr]     Checking news2tg v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `error`, `info`, and `warn`
[INFO] [stdout]  --> src/bin/client.rs:1:11
[INFO] [stdout]   |
[INFO] [stdout] 1 | use log::{info, warn,error};
[INFO] [stdout]   |           ^^^^  ^^^^ ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tonic::transport::Channel`
[INFO] [stdout]  --> src/bin/client.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use tonic::transport::Channel;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Duration`
[INFO] [stdout]  --> src/bin/client.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::time::Duration;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Cleanup`, `Criterion`, `Duplicate`, `FileSpec`, `LevelFilter`, `LogSpecification`, `Logger`, `Naming`, `WriteMode`, and `detailed_format`
[INFO] [stdout]  --> src/bin/client.rs:6:20
[INFO] [stdout]   |
[INFO] [stdout] 6 | use flexi_logger::{LogSpecification,LevelFilter, Duplicate, FileSpec, Logger, WriteMode, Criterion, Naming, Cleanup, detailed_format};
[INFO] [stdout]   |                    ^^^^^^^^^^^^^^^^ ^^^^^^^^^^^  ^^^^^^^^^  ^^^^^^^^  ^^^^^^  ^^^^^^^^^  ^^^^^^^^^  ^^^^^^  ^^^^^^^  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `flexi_logger::LoggerHandle`
[INFO] [stdout]  --> src/bin/client.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use flexi_logger::LoggerHandle;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `collections::HashMap` and `env`
[INFO] [stdout]  --> src/bin/client.rs:8:11
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::{collections::HashMap, env};
[INFO] [stdout]   |           ^^^^^^^^^^^^^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `error`, `info`, and `warn`
[INFO] [stdout]  --> src/bin/client.rs:1:11
[INFO] [stdout]   |
[INFO] [stdout] 1 | use log::{info, warn,error};
[INFO] [stdout]   |           ^^^^  ^^^^ ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tonic::transport::Channel`
[INFO] [stdout]  --> src/bin/client.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use tonic::transport::Channel;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Duration`
[INFO] [stdout]  --> src/bin/client.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::time::Duration;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Cleanup`, `Criterion`, `Duplicate`, `FileSpec`, `LevelFilter`, `LogSpecification`, `Logger`, `Naming`, `WriteMode`, and `detailed_format`
[INFO] [stdout]  --> src/bin/client.rs:6:20
[INFO] [stdout]   |
[INFO] [stdout] 6 | use flexi_logger::{LogSpecification,LevelFilter, Duplicate, FileSpec, Logger, WriteMode, Criterion, Naming, Cleanup, detailed_format};
[INFO] [stdout]   |                    ^^^^^^^^^^^^^^^^ ^^^^^^^^^^^  ^^^^^^^^^  ^^^^^^^^  ^^^^^^  ^^^^^^^^^  ^^^^^^^^^  ^^^^^^  ^^^^^^^  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `flexi_logger::LoggerHandle`
[INFO] [stdout]  --> src/bin/client.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use flexi_logger::LoggerHandle;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `collections::HashMap` and `env`
[INFO] [stdout]  --> src/bin/client.rs:8:11
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::{collections::HashMap, env};
[INFO] [stdout]   |           ^^^^^^^^^^^^^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::common::models::News2tgNotifyBase`
[INFO] [stdout]  --> src/traits/news2tg.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::common::models::News2tgNotifyBase;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::ai_helper`
[INFO] [stdout]  --> src/traits/news2tg.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use super::ai_helper;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::ai_helper::AIHelper`
[INFO] [stdout]  --> src/traits/news2tg.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use super::ai_helper::AIHelper;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::monitor::Monitor`
[INFO] [stdout]  --> src/traits/news2tg.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use super::monitor::Monitor;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::notify::Notify`
[INFO] [stdout]  --> src/traits/news2tg.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use super::notify::Notify;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::traits::ai_helper::AIHelper`
[INFO] [stdout]   --> src/implementations/monitor_v2ex.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use crate::traits::ai_helper::AIHelper;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::Result`
[INFO] [stdout]    --> src/common/tools.rs:242:9
[INFO] [stdout]     |
[INFO] [stdout] 242 |     use std::io::Result;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `CopyGetters`
[INFO] [stdout]  --> src/common/models.rs:5:14
[INFO] [stdout]   |
[INFO] [stdout] 5 | use getset::{CopyGetters, Getters, MutGetters, Setters};
[INFO] [stdout]   |              ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::common::models::News2tgNotifyBase`
[INFO] [stdout]  --> src/traits/news2tg.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::common::models::News2tgNotifyBase;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::ai_helper`
[INFO] [stdout]  --> src/traits/news2tg.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use super::ai_helper;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::ai_helper::AIHelper`
[INFO] [stdout]  --> src/traits/news2tg.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use super::ai_helper::AIHelper;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::monitor::Monitor`
[INFO] [stdout]  --> src/traits/news2tg.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use super::monitor::Monitor;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::notify::Notify`
[INFO] [stdout]  --> src/traits/news2tg.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use super::notify::Notify;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::traits::ai_helper::AIHelper`
[INFO] [stdout]   --> src/implementations/monitor_v2ex.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use crate::traits::ai_helper::AIHelper;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tonic::transport::Channel`
[INFO] [stdout]   --> src/implementations/monitor_hackernews.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use tonic::transport::Channel;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `CopyGetters`
[INFO] [stdout]  --> src/common/models.rs:5:14
[INFO] [stdout]   |
[INFO] [stdout] 5 | use getset::{CopyGetters, Getters, MutGetters, Setters};
[INFO] [stdout]   |              ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `DigestClient`
[INFO] [stdout]    --> src/implementations/monitor_hackernews.rs:426:26
[INFO] [stdout]     |
[INFO] [stdout] 426 |         let rpc_client = DigestClient::new(channel);
[INFO] [stdout]     |                          ^^^^^^^^^^^^ use of undeclared type `DigestClient`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this function takes 3 arguments but 4 arguments were supplied
[INFO] [stdout]    --> src/implementations/monitor_hackernews.rs:432:25
[INFO] [stdout]     |
[INFO] [stdout] 432 |         let mut monitor=MonitorHackerNews::new(http_client, tg_client, ai_client, rpc_client);
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^^^^^^^^                                    ---------- unexpected argument #4
[INFO] [stdout]     |
[INFO] [stdout] note: associated function defined here
[INFO] [stdout]    --> src/implementations/monitor_hackernews.rs:51:12
[INFO] [stdout]     |
[INFO] [stdout]  51 |     pub fn new(http_client: Client, notify_client: N, ai_client: A) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] help: remove the extra argument
[INFO] [stdout]     |
[INFO] [stdout] 432 -         let mut monitor=MonitorHackerNews::new(http_client, tg_client, ai_client, rpc_client);
[INFO] [stdout] 432 +         let mut monitor=MonitorHackerNews::new(http_client, tg_client, ai_client);
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/implementations/monitor_v2ex.rs:256:13
[INFO] [stdout]     |
[INFO] [stdout] 256 |         let mut monitor=MonitorV2EX::new(client,tg_client );
[INFO] [stdout]     |             ----^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `err`
[INFO] [stdout]    --> src/implementations/monitor_hackernews.rs:185:26
[INFO] [stdout]     |
[INFO] [stdout] 185 |         .text().map_err(|err| News2tgError::RuntimeError("提取hackernews帖子文本失败".to_string())).await.unwrap();
[INFO] [stdout]     |                          ^^^ help: if this is intentional, prefix it with an underscore: `_err`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `err`
[INFO] [stdout]    --> src/implementations/monitor_hackernews.rs:183:19
[INFO] [stdout]     |
[INFO] [stdout] 183 |         .map_err(|err| News2tgError::RuntimeError("获取hackernews帖子内容请求发送失败".to_string()))
[INFO] [stdout]     |                   ^^^ help: if this is intentional, prefix it with an underscore: `_err`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `err`
[INFO] [stdout]    --> src/implementations/monitor_hackernews.rs:185:26
[INFO] [stdout]     |
[INFO] [stdout] 185 |         .text().map_err(|err| News2tgError::RuntimeError("提取hackernews帖子文本失败".to_string())).await.unwrap();
[INFO] [stdout]     |                          ^^^ help: if this is intentional, prefix it with an underscore: `_err`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `err`
[INFO] [stdout]    --> src/implementations/monitor_hackernews.rs:183:19
[INFO] [stdout]     |
[INFO] [stdout] 183 |         .map_err(|err| News2tgError::RuntimeError("获取hackernews帖子内容请求发送失败".to_string()))
[INFO] [stdout]     |                   ^^^ help: if this is intentional, prefix it with an underscore: `_err`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0061, E0433.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0061`.
[INFO] [stdout] 
[INFO] [stdout] warning: method `translate` is never used
[INFO] [stdout]   --> src/traits/ai_helper.rs:13:14
[INFO] [stdout]    |
[INFO] [stdout]  6 | pub trait AIHelper: Send + Sync{
[INFO] [stdout]    |           -------- method in this trait
[INFO] [stdout] ...
[INFO] [stdout] 13 |     async fn translate(&self) -> Result<Self::Output, News2tgError>;
[INFO] [stdout]    |              ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `notify` is never used
[INFO] [stdout]   --> src/traits/notify.rs:14:14
[INFO] [stdout]    |
[INFO] [stdout]  7 | pub trait Notify: Send + Sync{
[INFO] [stdout]    |           ------ method in this trait
[INFO] [stdout] ...
[INFO] [stdout] 14 |     async fn notify(&self, content: &String) -> Result<Self::Output, Self::NotifyError>;
[INFO] [stdout]    |              ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `write_content_to_file` is never used
[INFO] [stdout]   --> src/common/tools.rs:31:8
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub fn write_content_to_file(section_title: &str, content: &str,append: bool) -> Result<()> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `read_content_from_file` is never used
[INFO] [stdout]   --> src/common/tools.rs:46:8
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub fn read_content_from_file() -> Result<String> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `write_topics_to_file` is never used
[INFO] [stdout]   --> src/common/tools.rs:54:8
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub fn write_topics_to_file(section_title: &str, topics: &[Topic], pushed_urls: &HashMap<String, String>) -> Result<()> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `AIError` and `UnsupportError` are never constructed
[INFO] [stdout]   --> src/common/models.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub enum News2tgError {
[INFO] [stdout]    |          ------------ variants in this enum
[INFO] [stdout] 11 |     AIError(String),
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 14 |     UnsupportError(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `News2tgError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/common/models.rs:59:9
[INFO] [stdout]    |
[INFO] [stdout] 58 | pub struct Node {
[INFO] [stdout]    |            ---- fields in this struct
[INFO] [stdout] 59 |     pub avatar_large: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 60 |     pub name: String,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 61 |     pub avatar_normal: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 62 |     pub title: String,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 63 |     pub url: String,
[INFO] [stdout]    |         ^^^
[INFO] [stdout] 64 |     pub topics: u64,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 65 |     pub footer: Option<String>,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 66 |     pub header: Option<String>,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 67 |     pub title_alternative: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 68 |     pub avatar_mini: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 69 |     pub stars: u64,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 70 |     pub aliases: Vec<String>,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 71 |     pub root: bool,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 72 |     pub id: u64,
[INFO] [stdout]    |         ^^
[INFO] [stdout] 73 |     pub parent_node_name: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Node` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/common/models.rs:79:9
[INFO] [stdout]    |
[INFO] [stdout] 78 | pub struct Member {
[INFO] [stdout]    |            ------ fields in this struct
[INFO] [stdout] 79 |     pub id: u64,
[INFO] [stdout]    |         ^^
[INFO] [stdout] 80 |     pub username: String,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 81 |     pub url: String,
[INFO] [stdout]    |         ^^^
[INFO] [stdout] 82 |     pub website: Option<String>,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 83 |     pub twitter: Option<String>,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 84 |     pub psn: Option<String>,
[INFO] [stdout]    |         ^^^
[INFO] [stdout] 85 |     pub github: Option<String>,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 86 |     pub btc: Option<String>,
[INFO] [stdout]    |         ^^^
[INFO] [stdout] 87 |     pub location: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 88 |     pub tagline: Option<String>,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 89 |     pub bio: Option<String>,
[INFO] [stdout]    |         ^^^
[INFO] [stdout] 90 |     pub avatar_mini: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 91 |     pub avatar_normal: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 92 |     pub avatar_large: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 93 |     pub created: u64,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 94 |     pub last_modified: u64,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Member` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]    --> src/common/models.rs:100:9
[INFO] [stdout]     |
[INFO] [stdout]  99 | pub struct Topic {
[INFO] [stdout]     |            ----- fields in this struct
[INFO] [stdout] 100 |     pub node: Node,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout] 101 |     pub member: Member,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] 102 |     pub last_reply_by: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^
[INFO] [stdout] 103 |     pub last_touched: u64,
[INFO] [stdout]     |         ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 106 |     pub created: u64,
[INFO] [stdout]     |         ^^^^^^^
[INFO] [stdout] 107 |     pub deleted: u64,
[INFO] [stdout]     |         ^^^^^^^
[INFO] [stdout] 108 |     pub content: Option<String>,
[INFO] [stdout]     |         ^^^^^^^
[INFO] [stdout] 109 |     pub content_rendered: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 110 |     pub last_modified: u64,
[INFO] [stdout]     |         ^^^^^^^^^^^^^
[INFO] [stdout] 111 |     pub replies: u64,
[INFO] [stdout]     |         ^^^^^^^
[INFO] [stdout] 112 |     pub id: u64,
[INFO] [stdout]     |         ^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `Topic` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SharedItem` is never constructed
[INFO] [stdout]    --> src/common/models.rs:117:12
[INFO] [stdout]     |
[INFO] [stdout] 117 | pub struct SharedItem{
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/common/models.rs:123:12
[INFO] [stdout]     |
[INFO] [stdout] 122 | impl SharedItem {
[INFO] [stdout]     | --------------- associated function in this implementation
[INFO] [stdout] 123 |     pub fn new() -> SharedItem{
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `news2tg` (bin "news2tg" test) due to 2 previous errors; 11 warnings emitted
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] running `Command { std: "docker" "inspect" "8e9e10d097a21ff204ff81d630262ba2b1f29b696ccc38305b904a3779619348", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8e9e10d097a21ff204ff81d630262ba2b1f29b696ccc38305b904a3779619348", kill_on_drop: false }`
[INFO] [stdout] 8e9e10d097a21ff204ff81d630262ba2b1f29b696ccc38305b904a3779619348
