[INFO] cloning repository https://github.com/gambl0rdan/bondpricer [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/gambl0rdan/bondpricer" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fgambl0rdan%2Fbondpricer", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fgambl0rdan%2Fbondpricer'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] cf47a446460696bd9db20a7175b4074e273f0cfe [INFO] testing gambl0rdan/bondpricer against try#ecabaf78506b7a4668d42dc20268c086b93f0fad for pr-87041 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fgambl0rdan%2Fbondpricer" "/workspace/builds/worker-13/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-13/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/gambl0rdan/bondpricer on toolchain ecabaf78506b7a4668d42dc20268c086b93f0fad [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+ecabaf78506b7a4668d42dc20268c086b93f0fad" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/gambl0rdan/bondpricer [INFO] finished tweaking git repo https://github.com/gambl0rdan/bondpricer [INFO] tweaked toml for git repo https://github.com/gambl0rdan/bondpricer written to /workspace/builds/worker-13/source/Cargo.toml [INFO] crate git repo https://github.com/gambl0rdan/bondpricer already has a lockfile, it will not be regenerated [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+ecabaf78506b7a4668d42dc20268c086b93f0fad" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-13/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-13/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:34b6a614d2c27851fe6cbf88fbd1137609cefab8b10d0615aaeb6fd47975d74e" "/opt/rustwide/cargo-home/bin/cargo" "+ecabaf78506b7a4668d42dc20268c086b93f0fad" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 15b74ddeff081b6ee8818a485bdc56e43f5aa71209faeee09c396fa8ccdb9178 [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "15b74ddeff081b6ee8818a485bdc56e43f5aa71209faeee09c396fa8ccdb9178", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "15b74ddeff081b6ee8818a485bdc56e43f5aa71209faeee09c396fa8ccdb9178", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "15b74ddeff081b6ee8818a485bdc56e43f5aa71209faeee09c396fa8ccdb9178", kill_on_drop: false }` [INFO] [stdout] 15b74ddeff081b6ee8818a485bdc56e43f5aa71209faeee09c396fa8ccdb9178 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-13/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-13/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" "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:34b6a614d2c27851fe6cbf88fbd1137609cefab8b10d0615aaeb6fd47975d74e" "/opt/rustwide/cargo-home/bin/cargo" "+ecabaf78506b7a4668d42dc20268c086b93f0fad" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] bfbb726cc147aaabcccd3a166b6835fbed0d5037ff136b06ad6eb26817a90fd6 [INFO] running `Command { std: "docker" "start" "-a" "bfbb726cc147aaabcccd3a166b6835fbed0d5037ff136b06ad6eb26817a90fd6", kill_on_drop: false }` [INFO] [stderr] Compiling autocfg v1.0.0 [INFO] [stderr] Compiling time v0.1.42 [INFO] [stderr] Compiling num-traits v0.2.11 [INFO] [stderr] Compiling num-integer v0.1.42 [INFO] [stderr] Compiling chrono v0.4.10 [INFO] [stderr] Compiling bondpricer v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `TimeZone` [INFO] [stdout] --> src/bonds/analytics.rs:2:25 [INFO] [stdout] | [INFO] [stdout] 2 | use chrono::{Date, Utc, TimeZone}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `present_value` [INFO] [stdout] --> src/lib.rs:6:48 [INFO] [stdout] | [INFO] [stdout] 6 | use equations::{future_value, future_value_mp, present_value, future_value_cap}; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable expression [INFO] [stdout] --> src/bonds/analytics.rs:152:9 [INFO] [stdout] | [INFO] [stdout] 123 | / loop { [INFO] [stdout] 124 | | let mut i = 0; [INFO] [stdout] 125 | | let cpn_pvs : f64 = pay_dates.iter().map(|dt| { [INFO] [stdout] 126 | | i = i + 1; [INFO] [stdout] ... | [INFO] [stdout] 150 | | } [INFO] [stdout] 151 | | } [INFO] [stdout] | |_________- any code following this expression is unreachable [INFO] [stdout] 152 | return 0. [INFO] [stdout] | ^^^^^^^^^ unreachable expression [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unreachable_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `b` [INFO] [stdout] --> src/bonds/analytics.rs:11:9 [INFO] [stdout] | [INFO] [stdout] 11 | let b = 144.81; // looking for 2% yld and 0% cpn [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_b` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `val_dt` [INFO] [stdout] --> src/bonds/analytics.rs:7:20 [INFO] [stdout] | [INFO] [stdout] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_val_dt` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `mat` [INFO] [stdout] --> src/bonds/analytics.rs:7:40 [INFO] [stdout] | [INFO] [stdout] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_mat` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `freq` [INFO] [stdout] --> src/bonds/analytics.rs:7:51 [INFO] [stdout] | [INFO] [stdout] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_freq` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `price` [INFO] [stdout] --> src/bonds/analytics.rs:7:77 [INFO] [stdout] | [INFO] [stdout] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_price` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `dt` [INFO] [stdout] --> src/bonds/analytics.rs:125:51 [INFO] [stdout] | [INFO] [stdout] 125 | let cpn_pvs : f64 = pay_dates.iter().map(|dt| { [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_dt` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `bdc` [INFO] [stdout] --> src/dates.rs:33:78 [INFO] [stdout] | [INFO] [stdout] 33 | pub fn days_accrued(valuation_date : Date, schedules : &Vec>, bdc : (f64, f64)) -> i64 { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_bdc` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function is never used: `ytm_and_zspread` [INFO] [stdout] --> src/bonds/analytics.rs:7:4 [INFO] [stdout] | [INFO] [stdout] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function is never used: `calculate_yield` [INFO] [stdout] --> src/bonds/analytics.rs:43:5 [INFO] [stdout] | [INFO] [stdout] 43 | fn calculate_yield(init_guess : f64, cashflows : &[f64], year_fracts : &[f64], b : f64) -> f64 { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function is never used: `calculate_z_spread` [INFO] [stdout] --> src/bonds/analytics.rs:77:4 [INFO] [stdout] | [INFO] [stdout] 77 | fn calculate_z_spread(init_guess : f64, cashflows : &[f64], pay_dates : &Vec>, year_fracts : &[f64], b : f64, yc : &YieldCurve)... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function is never used: `calculate_yield_naive_solver` [INFO] [stdout] --> src/bonds/analytics.rs:114:4 [INFO] [stdout] | [INFO] [stdout] 114 | fn calculate_yield_naive_solver(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> f64 { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function is never used: `pv_calced` [INFO] [stdout] --> src/bonds/analytics.rs:157:4 [INFO] [stdout] | [INFO] [stdout] 157 | fn pv_calced(val_dt : Date, mat : f64, freq : f64, coupon : f64, yc : &YieldCurve) -> f64 { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `new` [INFO] [stdout] --> src/bonds/mod.rs:102:8 [INFO] [stdout] | [INFO] [stdout] 102 | fn new(coupon: f64, maturity: f64, p: f64) -> GenericBond { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 16 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 10.28s [INFO] running `Command { std: "docker" "inspect" "bfbb726cc147aaabcccd3a166b6835fbed0d5037ff136b06ad6eb26817a90fd6", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "bfbb726cc147aaabcccd3a166b6835fbed0d5037ff136b06ad6eb26817a90fd6", kill_on_drop: false }` [INFO] [stdout] bfbb726cc147aaabcccd3a166b6835fbed0d5037ff136b06ad6eb26817a90fd6 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-13/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-13/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" "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:34b6a614d2c27851fe6cbf88fbd1137609cefab8b10d0615aaeb6fd47975d74e" "/opt/rustwide/cargo-home/bin/cargo" "+ecabaf78506b7a4668d42dc20268c086b93f0fad" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 4b4062e892aedd9c1b0ba13ab72ec2bf7b6e1958918b0ac072e3ccc644d8b5fb [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "4b4062e892aedd9c1b0ba13ab72ec2bf7b6e1958918b0ac072e3ccc644d8b5fb", kill_on_drop: false }` [INFO] [stdout] warning: unused import: `TimeZone` [INFO] [stdout] --> src/bonds/analytics.rs:2:25 [INFO] [stdout] | [INFO] [stdout] 2 | use chrono::{Date, Utc, TimeZone}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `present_value` [INFO] [stdout] --> src/lib.rs:6:48 [INFO] [stdout] | [INFO] [stdout] 6 | use equations::{future_value, future_value_mp, present_value, future_value_cap}; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable expression [INFO] [stdout] --> src/bonds/analytics.rs:152:9 [INFO] [stdout] | [INFO] [stdout] 123 | / loop { [INFO] [stdout] 124 | | let mut i = 0; [INFO] [stdout] 125 | | let cpn_pvs : f64 = pay_dates.iter().map(|dt| { [INFO] [stdout] 126 | | i = i + 1; [INFO] [stdout] ... | [INFO] [stdout] 150 | | } [INFO] [stdout] 151 | | } [INFO] [stdout] | |_________- any code following this expression is unreachable [INFO] [stdout] 152 | return 0. [INFO] [stdout] | ^^^^^^^^^ unreachable expression [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unreachable_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `b` [INFO] [stdout] --> src/bonds/analytics.rs:11:9 [INFO] [stdout] | [INFO] [stdout] 11 | let b = 144.81; // looking for 2% yld and 0% cpn [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_b` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `val_dt` [INFO] [stdout] --> src/bonds/analytics.rs:7:20 [INFO] [stdout] | [INFO] [stdout] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_val_dt` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `mat` [INFO] [stdout] --> src/bonds/analytics.rs:7:40 [INFO] [stdout] | [INFO] [stdout] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_mat` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `freq` [INFO] [stdout] --> src/bonds/analytics.rs:7:51 [INFO] [stdout] | [INFO] [stdout] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_freq` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `price` [INFO] [stdout] --> src/bonds/analytics.rs:7:77 [INFO] [stdout] | [INFO] [stdout] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_price` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `dt` [INFO] [stdout] --> src/bonds/analytics.rs:125:51 [INFO] [stdout] | [INFO] [stdout] 125 | let cpn_pvs : f64 = pay_dates.iter().map(|dt| { [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_dt` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `bdc` [INFO] [stdout] --> src/dates.rs:33:78 [INFO] [stdout] | [INFO] [stdout] 33 | pub fn days_accrued(valuation_date : Date, schedules : &Vec>, bdc : (f64, f64)) -> i64 { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_bdc` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function is never used: `ytm_and_zspread` [INFO] [stdout] --> src/bonds/analytics.rs:7:4 [INFO] [stdout] | [INFO] [stdout] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function is never used: `calculate_yield` [INFO] [stdout] --> src/bonds/analytics.rs:43:5 [INFO] [stdout] | [INFO] [stdout] 43 | fn calculate_yield(init_guess : f64, cashflows : &[f64], year_fracts : &[f64], b : f64) -> f64 { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function is never used: `calculate_z_spread` [INFO] [stdout] --> src/bonds/analytics.rs:77:4 [INFO] [stdout] | [INFO] [stdout] 77 | fn calculate_z_spread(init_guess : f64, cashflows : &[f64], pay_dates : &Vec>, year_fracts : &[f64], b : f64, yc : &YieldCurve)... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function is never used: `calculate_yield_naive_solver` [INFO] [stdout] --> src/bonds/analytics.rs:114:4 [INFO] [stdout] | [INFO] [stdout] 114 | fn calculate_yield_naive_solver(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> f64 { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function is never used: `pv_calced` [INFO] [stdout] --> src/bonds/analytics.rs:157:4 [INFO] [stdout] | [INFO] [stdout] 157 | fn pv_calced(val_dt : Date, mat : f64, freq : f64, coupon : f64, yc : &YieldCurve) -> f64 { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `new` [INFO] [stdout] --> src/bonds/mod.rs:102:8 [INFO] [stdout] | [INFO] [stdout] 102 | fn new(coupon: f64, maturity: f64, p: f64) -> GenericBond { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 16 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Compiling bondpricer v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `TimeZone` [INFO] [stdout] --> src/bonds/analytics.rs:2:25 [INFO] [stdout] | [INFO] [stdout] 2 | use chrono::{Date, Utc, TimeZone}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DateTime` [INFO] [stdout] --> src/rates/mod.rs:127:18 [INFO] [stdout] | [INFO] [stdout] 127 | use chrono::{DateTime, Duration, Utc, TimeZone}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `bondpricer::equations` [INFO] [stdout] --> tests/integration_tests.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use bondpricer::equations; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime`, `Duration`, `Utc` [INFO] [stdout] --> src/dates.rs:65:18 [INFO] [stdout] | [INFO] [stdout] 65 | use chrono::{DateTime, Duration, Utc, TimeZone}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^ ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `present_value` [INFO] [stdout] --> src/lib.rs:6:48 [INFO] [stdout] | [INFO] [stdout] 6 | use equations::{future_value, future_value_mp, present_value, future_value_cap}; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `res` [INFO] [stdout] --> tests/integration_tests.rs:13:9 [INFO] [stdout] | [INFO] [stdout] 13 | let res = bondpricer::equations::future_value(pv, rate, 1); [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_res` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `assertAlmostEquals` should have a snake case name [INFO] [stdout] --> tests/common/mod.rs:1:8 [INFO] [stdout] | [INFO] [stdout] 1 | pub fn assertAlmostEquals(a : f64, b :f64) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `assert_almost_equals` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable expression [INFO] [stdout] --> src/bonds/analytics.rs:152:9 [INFO] [stdout] | [INFO] [stdout] 123 | / loop { [INFO] [stdout] 124 | | let mut i = 0; [INFO] [stdout] 125 | | let cpn_pvs : f64 = pay_dates.iter().map(|dt| { [INFO] [stdout] 126 | | i = i + 1; [INFO] [stdout] ... | [INFO] [stdout] 150 | | } [INFO] [stdout] 151 | | } [INFO] [stdout] | |_________- any code following this expression is unreachable [INFO] [stdout] 152 | return 0. [INFO] [stdout] | ^^^^^^^^^ unreachable expression [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unreachable_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `b` [INFO] [stdout] --> src/bonds/analytics.rs:11:9 [INFO] [stdout] | [INFO] [stdout] 11 | let b = 144.81; // looking for 2% yld and 0% cpn [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_b` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `val_dt` [INFO] [stdout] --> src/bonds/analytics.rs:7:20 [INFO] [stdout] | [INFO] [stdout] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_val_dt` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `mat` [INFO] [stdout] --> src/bonds/analytics.rs:7:40 [INFO] [stdout] | [INFO] [stdout] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_mat` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `freq` [INFO] [stdout] --> src/bonds/analytics.rs:7:51 [INFO] [stdout] | [INFO] [stdout] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_freq` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `price` [INFO] [stdout] --> src/bonds/analytics.rs:7:77 [INFO] [stdout] | [INFO] [stdout] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_price` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `dt` [INFO] [stdout] --> src/bonds/analytics.rs:125:51 [INFO] [stdout] | [INFO] [stdout] 125 | let cpn_pvs : f64 = pay_dates.iter().map(|dt| { [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_dt` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `bdc` [INFO] [stdout] --> src/dates.rs:33:78 [INFO] [stdout] | [INFO] [stdout] 33 | pub fn days_accrued(valuation_date : Date, schedules : &Vec>, bdc : (f64, f64)) -> i64 { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_bdc` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 3 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 12 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 2.43s [INFO] running `Command { std: "docker" "inspect" "4b4062e892aedd9c1b0ba13ab72ec2bf7b6e1958918b0ac072e3ccc644d8b5fb", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "4b4062e892aedd9c1b0ba13ab72ec2bf7b6e1958918b0ac072e3ccc644d8b5fb", kill_on_drop: false }` [INFO] [stdout] 4b4062e892aedd9c1b0ba13ab72ec2bf7b6e1958918b0ac072e3ccc644d8b5fb [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-13/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-13/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" "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:34b6a614d2c27851fe6cbf88fbd1137609cefab8b10d0615aaeb6fd47975d74e" "/opt/rustwide/cargo-home/bin/cargo" "+ecabaf78506b7a4668d42dc20268c086b93f0fad" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 40f090c214f2c77c452e278f7abfa98bca9744b29df6b864fadbc7a9fe801fc7 [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "40f090c214f2c77c452e278f7abfa98bca9744b29df6b864fadbc7a9fe801fc7", kill_on_drop: false }` [INFO] [stderr] warning: unused import: `TimeZone` [INFO] [stderr] --> src/bonds/analytics.rs:2:25 [INFO] [stderr] | [INFO] [stderr] 2 | use chrono::{Date, Utc, TimeZone}; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `present_value` [INFO] [stderr] --> src/lib.rs:6:48 [INFO] [stderr] | [INFO] [stderr] 6 | use equations::{future_value, future_value_mp, present_value, future_value_cap}; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unreachable expression [INFO] [stderr] --> src/bonds/analytics.rs:152:9 [INFO] [stderr] | [INFO] [stderr] 123 | / loop { [INFO] [stderr] 124 | | let mut i = 0; [INFO] [stderr] 125 | | let cpn_pvs : f64 = pay_dates.iter().map(|dt| { [INFO] [stderr] 126 | | i = i + 1; [INFO] [stderr] ... | [INFO] [stderr] 150 | | } [INFO] [stderr] 151 | | } [INFO] [stderr] | |_________- any code following this expression is unreachable [INFO] [stderr] 152 | return 0. [INFO] [stderr] | ^^^^^^^^^ unreachable expression [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unreachable_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `b` [INFO] [stderr] --> src/bonds/analytics.rs:11:9 [INFO] [stderr] | [INFO] [stderr] 11 | let b = 144.81; // looking for 2% yld and 0% cpn [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_b` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `val_dt` [INFO] [stderr] --> src/bonds/analytics.rs:7:20 [INFO] [stderr] | [INFO] [stderr] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_val_dt` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `mat` [INFO] [stderr] --> src/bonds/analytics.rs:7:40 [INFO] [stderr] | [INFO] [stderr] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_mat` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `freq` [INFO] [stderr] --> src/bonds/analytics.rs:7:51 [INFO] [stderr] | [INFO] [stderr] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_freq` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `price` [INFO] [stderr] --> src/bonds/analytics.rs:7:77 [INFO] [stderr] | [INFO] [stderr] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stderr] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_price` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `dt` [INFO] [stderr] --> src/bonds/analytics.rs:125:51 [INFO] [stderr] | [INFO] [stderr] 125 | let cpn_pvs : f64 = pay_dates.iter().map(|dt| { [INFO] [stderr] | ^^ help: if this is intentional, prefix it with an underscore: `_dt` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `bdc` [INFO] [stderr] --> src/dates.rs:33:78 [INFO] [stderr] | [INFO] [stderr] 33 | pub fn days_accrued(valuation_date : Date, schedules : &Vec>, bdc : (f64, f64)) -> i64 { [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_bdc` [INFO] [stderr] [INFO] [stderr] warning: function is never used: `ytm_and_zspread` [INFO] [stderr] --> src/bonds/analytics.rs:7:4 [INFO] [stderr] | [INFO] [stderr] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: function is never used: `calculate_yield` [INFO] [stderr] --> src/bonds/analytics.rs:43:5 [INFO] [stderr] | [INFO] [stderr] 43 | fn calculate_yield(init_guess : f64, cashflows : &[f64], year_fracts : &[f64], b : f64) -> f64 { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `calculate_z_spread` [INFO] [stderr] --> src/bonds/analytics.rs:77:4 [INFO] [stderr] | [INFO] [stderr] 77 | fn calculate_z_spread(init_guess : f64, cashflows : &[f64], pay_dates : &Vec>, year_fracts : &[f64], b : f64, yc : &YieldCurve)... [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `calculate_yield_naive_solver` [INFO] [stderr] --> src/bonds/analytics.rs:114:4 [INFO] [stderr] | [INFO] [stderr] 114 | fn calculate_yield_naive_solver(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> f64 { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `pv_calced` [INFO] [stderr] --> src/bonds/analytics.rs:157:4 [INFO] [stderr] | [INFO] [stderr] 157 | fn pv_calced(val_dt : Date, mat : f64, freq : f64, coupon : f64, yc : &YieldCurve) -> f64 { [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `new` [INFO] [stderr] --> src/bonds/mod.rs:102:8 [INFO] [stderr] | [INFO] [stderr] 102 | fn new(coupon: f64, maturity: f64, p: f64) -> GenericBond { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: 16 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: unused import: `TimeZone` [INFO] [stderr] --> src/bonds/analytics.rs:2:25 [INFO] [stderr] | [INFO] [stderr] 2 | use chrono::{Date, Utc, TimeZone}; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `DateTime` [INFO] [stderr] --> src/rates/mod.rs:127:18 [INFO] [stderr] | [INFO] [stderr] 127 | use chrono::{DateTime, Duration, Utc, TimeZone}; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `DateTime`, `Duration`, `Utc` [INFO] [stderr] --> src/dates.rs:65:18 [INFO] [stderr] | [INFO] [stderr] 65 | use chrono::{DateTime, Duration, Utc, TimeZone}; [INFO] [stderr] | ^^^^^^^^ ^^^^^^^^ ^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `present_value` [INFO] [stderr] --> src/lib.rs:6:48 [INFO] [stderr] | [INFO] [stderr] 6 | use equations::{future_value, future_value_mp, present_value, future_value_cap}; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unreachable expression [INFO] [stderr] --> src/bonds/analytics.rs:152:9 [INFO] [stderr] | [INFO] [stderr] 123 | / loop { [INFO] [stderr] 124 | | let mut i = 0; [INFO] [stderr] 125 | | let cpn_pvs : f64 = pay_dates.iter().map(|dt| { [INFO] [stderr] 126 | | i = i + 1; [INFO] [stderr] ... | [INFO] [stderr] 150 | | } [INFO] [stderr] 151 | | } [INFO] [stderr] | |_________- any code following this expression is unreachable [INFO] [stderr] 152 | return 0. [INFO] [stderr] | ^^^^^^^^^ unreachable expression [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unreachable_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `b` [INFO] [stderr] --> src/bonds/analytics.rs:11:9 [INFO] [stderr] | [INFO] [stderr] 11 | let b = 144.81; // looking for 2% yld and 0% cpn [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_b` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `val_dt` [INFO] [stderr] --> src/bonds/analytics.rs:7:20 [INFO] [stderr] | [INFO] [stderr] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_val_dt` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `mat` [INFO] [stderr] --> src/bonds/analytics.rs:7:40 [INFO] [stderr] | [INFO] [stderr] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_mat` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `freq` [INFO] [stderr] --> src/bonds/analytics.rs:7:51 [INFO] [stderr] | [INFO] [stderr] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_freq` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `price` [INFO] [stderr] --> src/bonds/analytics.rs:7:77 [INFO] [stderr] | [INFO] [stderr] 7 | fn ytm_and_zspread(val_dt : Date, mat : f64, freq : f64, coupon : f64, price : f64) -> (f64, f64) { [INFO] [stderr] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_price` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `dt` [INFO] [stderr] --> src/bonds/analytics.rs:125:51 [INFO] [stderr] | [INFO] [stderr] 125 | let cpn_pvs : f64 = pay_dates.iter().map(|dt| { [INFO] [stderr] | ^^ help: if this is intentional, prefix it with an underscore: `_dt` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `bdc` [INFO] [stderr] --> src/dates.rs:33:78 [INFO] [stderr] | [INFO] [stderr] 33 | pub fn days_accrued(valuation_date : Date, schedules : &Vec>, bdc : (f64, f64)) -> i64 { [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_bdc` [INFO] [stderr] [INFO] [stderr] warning: 12 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: unused import: `bondpricer::equations` [INFO] [stderr] --> tests/integration_tests.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use bondpricer::equations; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `res` [INFO] [stderr] --> tests/integration_tests.rs:13:9 [INFO] [stderr] | [INFO] [stderr] 13 | let res = bondpricer::equations::future_value(pv, rate, 1); [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_res` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: function `assertAlmostEquals` should have a snake case name [INFO] [stderr] --> tests/common/mod.rs:1:8 [INFO] [stderr] | [INFO] [stderr] 1 | pub fn assertAlmostEquals(a : f64, b :f64) -> bool { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `assert_almost_equals` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: 3 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.02s [INFO] [stderr] Running unittests (/opt/rustwide/target/debug/deps/bondpricer-9ee08bda28e6f6f7) [INFO] [stdout] [INFO] [stdout] running 16 tests [INFO] [stdout] test bonds::analytics::tests::bonds_analytics_comparisons ... ok [INFO] [stdout] test dates::tests::date_accrued_days_broken_dates ... ok [INFO] [stdout] test dates::tests::date_from_1st_jan_2020 ... ok [INFO] [stdout] test dates::tests::date_vec_flows ... ok [INFO] [stdout] test equations::tests::fv_from_pv ... ok [INFO] [stdout] test dates::tests::date_to_year_fract_correct ... ok [INFO] [stdout] test equations::tests::pv_from_fv ... ok [INFO] [stdout] test equations::tests::simple_discount_factors ... ok [INFO] [stdout] test rates::tests::yc_linear_interpolate ... ok [INFO] [stdout] test bonds::tests::bonds_yield_simple ... ok [INFO] [stdout] test bonds::tests::bonds_ai ... ok [INFO] [stdout] test bonds::tests::bonds_price_simple ... ok [INFO] [stdout] test bonds::tests::bonds_pv_simple ... ok [INFO] [stdout] test bonds::analytics::tests::bonds_analytics_ytm_zspread ... ok [INFO] [stdout] test bonds::analytics::tests::bonds_analytics_ytm ... ok [INFO] [stdout] test rates::tests::yc_new_curve ... FAILED [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] [INFO] [stdout] ---- rates::tests::yc_new_curve stdout ---- [INFO] [stdout] Res 1!!! NaN [INFO] [stdout] thread 'rates::tests::yc_new_curve' panicked at 'assertion failed: (res - 0.2).abs() < 0.00001', src/rates/mod.rs:136:9 [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x56445908f270 - std::backtrace_rs::backtrace::libunwind::trace::h706b838f5bbd876b [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/../../backtrace/src/backtrace/libunwind.rs:90:5 [INFO] [stdout] 1: 0x56445908f270 - std::backtrace_rs::backtrace::trace_unsynchronized::hc15f29ae7822b7b8 [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/../../backtrace/src/backtrace/mod.rs:66:5 [INFO] [stdout] 2: 0x56445908f270 - std::sys_common::backtrace::_print_fmt::h7c580c971f91926c [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/sys_common/backtrace.rs:67:5 [INFO] [stdout] 3: 0x56445908f270 - ::fmt::h2a772198c4032452 [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/sys_common/backtrace.rs:46:22 [INFO] [stdout] 4: 0x5644590b1a4c - core::fmt::write::h9a6d9c74526a6c1b [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/core/src/fmt/mod.rs:1115:17 [INFO] [stdout] 5: 0x56445908c2e5 - std::io::Write::write_fmt::h583dff5009d01a9f [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/io/mod.rs:1663:15 [INFO] [stdout] 6: 0x5644590913db - std::sys_common::backtrace::_print::h5b3c171e6f864ae4 [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/sys_common/backtrace.rs:49:5 [INFO] [stdout] 7: 0x5644590913db - std::sys_common::backtrace::print::h93b9e9ed2a98e611 [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/sys_common/backtrace.rs:36:9 [INFO] [stdout] 8: 0x5644590913db - std::panicking::default_hook::{{closure}}::hd8da92bb68d520c5 [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/panicking.rs:208:50 [INFO] [stdout] 9: 0x564459090eec - std::panicking::default_hook::hdbc8b2951c5afbab [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/panicking.rs:222:9 [INFO] [stdout] 10: 0x564459091aa4 - std::panicking::rust_panic_with_hook::h8a4c841655926f4e [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/panicking.rs:622:17 [INFO] [stdout] 11: 0x564459091557 - std::panicking::begin_panic_handler::{{closure}}::h471b6bc74904b7b0 [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/panicking.rs:517:13 [INFO] [stdout] 12: 0x56445908f76c - std::sys_common::backtrace::__rust_end_short_backtrace::h309f5c707f29932f [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/sys_common/backtrace.rs:141:18 [INFO] [stdout] 13: 0x5644590914e9 - rust_begin_unwind [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/panicking.rs:515:5 [INFO] [stdout] 14: 0x564459025641 - core::panicking::panic_fmt::hcf5f6d96e1dd7099 [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/core/src/panicking.rs:92:14 [INFO] [stdout] 15: 0x56445902558d - core::panicking::panic::hd695e3b1d0dd4ef4 [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/core/src/panicking.rs:50:5 [INFO] [stdout] 16: 0x564459035a0a - bondpricer::rates::tests::yc_new_curve::h09ca750f2edcc327 [INFO] [stdout] at /opt/rustwide/workdir/src/rates/mod.rs:136:9 [INFO] [stdout] 17: 0x56445903584a - bondpricer::rates::tests::yc_new_curve::{{closure}}::h25c0e74ac7222a7f [INFO] [stdout] at /opt/rustwide/workdir/src/rates/mod.rs:130:5 [INFO] [stdout] 18: 0x56445903152e - core::ops::function::FnOnce::call_once::h5ededf0ff6c9bfe4 [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/core/src/ops/function.rs:227:5 [INFO] [stdout] 19: 0x56445905e313 - core::ops::function::FnOnce::call_once::h99a97b0ff983bd25 [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/core/src/ops/function.rs:227:5 [INFO] [stdout] 20: 0x56445905e313 - test::__rust_begin_short_backtrace::h8fe0d26ed1584e50 [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/test/src/lib.rs:577:5 [INFO] [stdout] 21: 0x56445905cda0 - as core::ops::function::FnOnce>::call_once::he6b90e352f394d8f [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/alloc/src/boxed.rs:1572:9 [INFO] [stdout] 22: 0x56445905cda0 - as core::ops::function::FnOnce<()>>::call_once::h1c05475e029700b8 [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/panic.rs:347:9 [INFO] [stdout] 23: 0x56445905cda0 - std::panicking::try::do_call::he6de943476ae628a [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/panicking.rs:401:40 [INFO] [stdout] 24: 0x56445905cda0 - std::panicking::try::ha21937b8feb06f89 [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/panicking.rs:365:19 [INFO] [stdout] 25: 0x56445905cda0 - std::panic::catch_unwind::ha79830b3325c9fa6 [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/panic.rs:434:14 [INFO] [stdout] 26: 0x56445905cda0 - test::run_test_in_process::h1ab180b83ee2d5b5 [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/test/src/lib.rs:600:18 [INFO] [stdout] 27: 0x56445905cda0 - test::run_test::run_test_inner::{{closure}}::h8258ffe088f187a1 [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/test/src/lib.rs:492:39 [INFO] [stdout] 28: 0x564459036362 - test::run_test::run_test_inner::{{closure}}::hc697b214abd32bc6 [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/test/src/lib.rs:519:37 [INFO] [stdout] 29: 0x564459036362 - std::sys_common::backtrace::__rust_begin_short_backtrace::h64de0d3f894854a9 [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/sys_common/backtrace.rs:125:18 [INFO] [stdout] 30: 0x564459039fb8 - std::thread::Builder::spawn_unchecked::{{closure}}::{{closure}}::h1fd98fc86e533ece [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/thread/mod.rs:476:17 [INFO] [stdout] 31: 0x564459039fb8 - as core::ops::function::FnOnce<()>>::call_once::h4e2a7abf702e4cfd [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/panic.rs:347:9 [INFO] [stdout] 32: 0x564459039fb8 - std::panicking::try::do_call::h4496392321a3c8c0 [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/panicking.rs:401:40 [INFO] [stdout] 33: 0x564459039fb8 - std::panicking::try::hf1e14258e04e8e9a [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/panicking.rs:365:19 [INFO] [stdout] 34: 0x564459039fb8 - std::panic::catch_unwind::hb72c3777cd55642f [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/panic.rs:434:14 [INFO] [stdout] 35: 0x564459039fb8 - std::thread::Builder::spawn_unchecked::{{closure}}::h2d7915a5910e148e [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/thread/mod.rs:475:30 [INFO] [stdout] 36: 0x564459039fb8 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h83fd2f1ef5be797c [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/core/src/ops/function.rs:227:5 [INFO] [stdout] 37: 0x564459096637 - as core::ops::function::FnOnce>::call_once::ha8b1d5a0092467fc [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/alloc/src/boxed.rs:1572:9 [INFO] [stdout] 38: 0x564459096637 - as core::ops::function::FnOnce>::call_once::h4b9f24ec4e8a879e [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/alloc/src/boxed.rs:1572:9 [INFO] [stdout] 39: 0x564459096637 - std::sys::unix::thread::Thread::new::thread_start::h2a0e98fbc4ab4c32 [INFO] [stdout] at /rustc/ecabaf78506b7a4668d42dc20268c086b93f0fad/library/std/src/sys/unix/thread.rs:72:17 [INFO] [stdout] 40: 0x7fdb04719609 - start_thread [INFO] [stdout] 41: 0x7fdb044eb293 - clone [INFO] [stdout] 42: 0x0 - [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] rates::tests::yc_new_curve [INFO] [stdout] [INFO] [stdout] test result: FAILED. 15 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.07s [INFO] [stdout] [INFO] [stderr] error: test failed, to rerun pass '--lib' [INFO] running `Command { std: "docker" "inspect" "40f090c214f2c77c452e278f7abfa98bca9744b29df6b864fadbc7a9fe801fc7", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "40f090c214f2c77c452e278f7abfa98bca9744b29df6b864fadbc7a9fe801fc7", kill_on_drop: false }` [INFO] [stdout] 40f090c214f2c77c452e278f7abfa98bca9744b29df6b864fadbc7a9fe801fc7