[INFO] updating cached repository https://github.com/gambl0rdan/bondpricer [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "-c" "remote.origin.fetch=refs/heads/*:refs/heads/*" "fetch" "origin" "--force" "--prune", kill_on_drop: false }` [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] cf47a446460696bd9db20a7175b4074e273f0cfe [INFO] testing gambl0rdan/bondpricer against master#8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e for pr-74409 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fgambl0rdan%2Fbondpricer" "/workspace/builds/worker-6/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-6/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/gambl0rdan/bondpricer on toolchain 8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e" "read-manifest" "--manifest-path" "Cargo.toml", 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-6/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" "+8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e" "fetch" "--locked" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/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" "MAP_USER_ID=0" "-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" "--network" "none" "rustops/crates-build-env@sha256:38e1b949b06cde1964af550a6e548bd9b2b2ea170003ae122f8fc0886596cc07" "/opt/rustwide/cargo-home/bin/cargo" "+8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 26f5c02960a4cb74e1370ebdc86eaa9f9094f861dce15471908e0058a58d8ee5 [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" "26f5c02960a4cb74e1370ebdc86eaa9f9094f861dce15471908e0058a58d8ee5", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "26f5c02960a4cb74e1370ebdc86eaa9f9094f861dce15471908e0058a58d8ee5", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "26f5c02960a4cb74e1370ebdc86eaa9f9094f861dce15471908e0058a58d8ee5", kill_on_drop: false }` [INFO] [stdout] 26f5c02960a4cb74e1370ebdc86eaa9f9094f861dce15471908e0058a58d8ee5 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/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" "MAP_USER_ID=0" "-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" "--network" "none" "rustops/crates-build-env@sha256:38e1b949b06cde1964af550a6e548bd9b2b2ea170003ae122f8fc0886596cc07" "/opt/rustwide/cargo-home/bin/cargo" "+8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] ffd200c7b78415e866f61720760eb49ea451e56e77ab95a2c04ff6da8da666f8 [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" "ffd200c7b78415e866f61720760eb49ea451e56e77ab95a2c04ff6da8da666f8", kill_on_drop: false }` [INFO] [stderr] Compiling autocfg v1.0.0 [INFO] [stderr] Compiling libc v0.2.66 [INFO] [stderr] Compiling num-traits v0.2.11 [INFO] [stderr] Compiling num-integer v0.1.42 [INFO] [stderr] Compiling time 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 8.86s [INFO] running `Command { std: "docker" "inspect" "ffd200c7b78415e866f61720760eb49ea451e56e77ab95a2c04ff6da8da666f8", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "ffd200c7b78415e866f61720760eb49ea451e56e77ab95a2c04ff6da8da666f8", kill_on_drop: false }` [INFO] [stdout] ffd200c7b78415e866f61720760eb49ea451e56e77ab95a2c04ff6da8da666f8 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/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" "MAP_USER_ID=0" "-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" "--network" "none" "rustops/crates-build-env@sha256:38e1b949b06cde1964af550a6e548bd9b2b2ea170003ae122f8fc0886596cc07" "/opt/rustwide/cargo-home/bin/cargo" "+8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] bd961e8f6ad2b20e4002c76b2586e9c49df3020cdd95a1ce6ac06e68c2813aa5 [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" "bd961e8f6ad2b20e4002c76b2586e9c49df3020cdd95a1ce6ac06e68c2813aa5", kill_on_drop: false }` [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] [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 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: 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 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: 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 1.71s [INFO] running `Command { std: "docker" "inspect" "bd961e8f6ad2b20e4002c76b2586e9c49df3020cdd95a1ce6ac06e68c2813aa5", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "bd961e8f6ad2b20e4002c76b2586e9c49df3020cdd95a1ce6ac06e68c2813aa5", kill_on_drop: false }` [INFO] [stdout] bd961e8f6ad2b20e4002c76b2586e9c49df3020cdd95a1ce6ac06e68c2813aa5 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/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" "MAP_USER_ID=0" "-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" "--network" "none" "rustops/crates-build-env@sha256:38e1b949b06cde1964af550a6e548bd9b2b2ea170003ae122f8fc0886596cc07" "/opt/rustwide/cargo-home/bin/cargo" "+8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] dfee0a805bc007fb25b56c976d65640f03bd9eb80b7d60f7220d23eeef34990b [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" "dfee0a805bc007fb25b56c976d65640f03bd9eb80b7d60f7220d23eeef34990b", 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: `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: `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: `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.05s [INFO] [stderr] Running /opt/rustwide/target/debug/deps/bondpricer-c04ffec8b09580d1 [INFO] [stdout] [INFO] [stdout] running 16 tests [INFO] [stdout] test bonds::analytics::tests::bonds_analytics_comparisons ... ok [INFO] [stdout] test rates::tests::yc_linear_interpolate ... ok [INFO] [stdout] test bonds::tests::bonds_price_simple ... ok [INFO] [stdout] test dates::tests::date_to_year_fract_correct ... ok [INFO] [stdout] test equations::tests::pv_from_fv ... ok [INFO] [stdout] test dates::tests::date_accrued_days_broken_dates ... ok [INFO] [stdout] test equations::tests::simple_discount_factors ... ok [INFO] [stdout] test dates::tests::date_from_1st_jan_2020 ... ok [INFO] [stdout] test bonds::analytics::tests::bonds_analytics_ytm_zspread ... ok [INFO] [stdout] test bonds::tests::bonds_yield_simple ... ok [INFO] [stdout] test bonds::tests::bonds_pv_simple ... ok [INFO] [stdout] test dates::tests::date_vec_flows ... ok [INFO] [stdout] test equations::tests::fv_from_pv ... ok [INFO] [stdout] test bonds::analytics::tests::bonds_analytics_ytm ... ok [INFO] [stdout] test bonds::tests::bonds_ai ... ok [INFO] [stderr] error: test failed, to rerun pass '--lib' [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: 0x5568d4caaca5 - backtrace::backtrace::libunwind::trace::hea89dfbbfe67f40d [INFO] [stdout] at /cargo/registry/src/github.com-1ecc6299db9ec823/backtrace-0.3.46/src/backtrace/libunwind.rs:86 [INFO] [stdout] 1: 0x5568d4caaca5 - backtrace::backtrace::trace_unsynchronized::h0513dd713d7644d4 [INFO] [stdout] at /cargo/registry/src/github.com-1ecc6299db9ec823/backtrace-0.3.46/src/backtrace/mod.rs:66 [INFO] [stdout] 2: 0x5568d4caaca5 - std::sys_common::backtrace::_print_fmt::h040abae64e4a24a9 [INFO] [stdout] at src/libstd/sys_common/backtrace.rs:78 [INFO] [stdout] 3: 0x5568d4caaca5 - ::fmt::hb4bdb37c3c335733 [INFO] [stdout] at src/libstd/sys_common/backtrace.rs:59 [INFO] [stdout] 4: 0x5568d4cd291c - core::fmt::write::h540ac4a6a1232abc [INFO] [stdout] at src/libcore/fmt/mod.rs:1076 [INFO] [stdout] 5: 0x5568d4c57095 - std::io::Write::write_fmt::h4be0daababb55bba [INFO] [stdout] at /rustc/8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e/src/libstd/io/mod.rs:1539 [INFO] [stdout] 6: 0x5568d4ca5371 - std::io::impls::>::write_fmt::h83c1e1aa73f374f5 [INFO] [stdout] at src/libstd/io/impls.rs:176 [INFO] [stdout] 7: 0x5568d4cad400 - std::sys_common::backtrace::_print::hb55cc635eaf1882e [INFO] [stdout] at src/libstd/sys_common/backtrace.rs:62 [INFO] [stdout] 8: 0x5568d4cad400 - std::sys_common::backtrace::print::h2b2218fa55714084 [INFO] [stdout] at src/libstd/sys_common/backtrace.rs:49 [INFO] [stdout] 9: 0x5568d4cad400 - std::panicking::default_hook::{{closure}}::h578517c025765cf3 [INFO] [stdout] at src/libstd/panicking.rs:198 [INFO] [stdout] 10: 0x5568d4cad0fa - std::panicking::default_hook::h4cafc94c2fc640fb [INFO] [stdout] at src/libstd/panicking.rs:214 [INFO] [stdout] 11: 0x5568d4cada43 - std::panicking::rust_panic_with_hook::h3eeb5001beeca5c3 [INFO] [stdout] at src/libstd/panicking.rs:526 [INFO] [stdout] 12: 0x5568d4c9b4a9 - std::panicking::begin_panic::h10f3df1530afa4e6 [INFO] [stdout] at /rustc/8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e/src/libstd/panicking.rs:456 [INFO] [stdout] 13: 0x5568d4c4ae6c - bondpricer::rates::tests::yc_new_curve::h4e1419f8f5d32700 [INFO] [stdout] at src/rates/mod.rs:136 [INFO] [stdout] 14: 0x5568d4c4acca - bondpricer::rates::tests::yc_new_curve::{{closure}}::ha2f2826060ddb66b [INFO] [stdout] at src/rates/mod.rs:130 [INFO] [stdout] 15: 0x5568d4c4d05e - core::ops::function::FnOnce::call_once::h14279ad25e4e3d22 [INFO] [stdout] at /rustc/8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e/src/libcore/ops/function.rs:233 [INFO] [stdout] 16: 0x5568d4c7e60c - as core::ops::function::FnOnce>::call_once::h8340ba6798e0c4ff [INFO] [stdout] at /rustc/8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e/src/liballoc/boxed.rs:1081 [INFO] [stdout] 17: 0x5568d4c7e60c - as core::ops::function::FnOnce<()>>::call_once::h5590e98676605094 [INFO] [stdout] at /rustc/8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e/src/libstd/panic.rs:318 [INFO] [stdout] 18: 0x5568d4c7e60c - std::panicking::try::do_call::hd8680a2dbb0ed3c4 [INFO] [stdout] at /rustc/8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e/src/libstd/panicking.rs:348 [INFO] [stdout] 19: 0x5568d4c7e60c - std::panicking::try::h46b4de2d705e7a8d [INFO] [stdout] at /rustc/8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e/src/libstd/panicking.rs:325 [INFO] [stdout] 20: 0x5568d4c7e60c - std::panic::catch_unwind::h059b3f06991e0a9c [INFO] [stdout] at /rustc/8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e/src/libstd/panic.rs:394 [INFO] [stdout] 21: 0x5568d4c7e60c - test::run_test_in_process::h5ae08a65430494a4 [INFO] [stdout] at src/libtest/lib.rs:541 [INFO] [stdout] 22: 0x5568d4c7e60c - test::run_test::run_test_inner::{{closure}}::h4b36073838376ae8 [INFO] [stdout] at src/libtest/lib.rs:450 [INFO] [stdout] 23: 0x5568d4c56586 - std::sys_common::backtrace::__rust_begin_short_backtrace::h0169d0be588b8bf0 [INFO] [stdout] at /rustc/8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e/src/libstd/sys_common/backtrace.rs:130 [INFO] [stdout] 24: 0x5568d4c5b575 - std::thread::Builder::spawn_unchecked::{{closure}}::{{closure}}::h71bfc37e887d3973 [INFO] [stdout] at /rustc/8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e/src/libstd/thread/mod.rs:475 [INFO] [stdout] 25: 0x5568d4c5b575 - as core::ops::function::FnOnce<()>>::call_once::h36c65072907dc180 [INFO] [stdout] at /rustc/8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e/src/libstd/panic.rs:318 [INFO] [stdout] 26: 0x5568d4c5b575 - std::panicking::try::do_call::h4e0f426e17cd216c [INFO] [stdout] at /rustc/8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e/src/libstd/panicking.rs:348 [INFO] [stdout] 27: 0x5568d4c5b575 - std::panicking::try::hd05e4ef6b4303d29 [INFO] [stdout] at /rustc/8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e/src/libstd/panicking.rs:325 [INFO] [stdout] 28: 0x5568d4c5b575 - std::panic::catch_unwind::h19a1127ec729c5dd [INFO] [stdout] at /rustc/8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e/src/libstd/panic.rs:394 [INFO] [stdout] 29: 0x5568d4c5b575 - std::thread::Builder::spawn_unchecked::{{closure}}::h011300735f06b1e2 [INFO] [stdout] at /rustc/8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e/src/libstd/thread/mod.rs:474 [INFO] [stdout] 30: 0x5568d4c5b575 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h1e3c55f31f1d122e [INFO] [stdout] at /rustc/8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e/src/libcore/ops/function.rs:233 [INFO] [stdout] 31: 0x5568d4cb3c1a - as core::ops::function::FnOnce>::call_once::hc0e15d78a519721e [INFO] [stdout] at /rustc/8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e/src/liballoc/boxed.rs:1081 [INFO] [stdout] 32: 0x5568d4cb3c1a - as core::ops::function::FnOnce>::call_once::h211da8fffb09f192 [INFO] [stdout] at /rustc/8534be72fc3b9c5f2f2dc4e4ee7b651a008e9a3e/src/liballoc/boxed.rs:1081 [INFO] [stdout] 33: 0x5568d4cb3c1a - std::sys::unix::thread::Thread::new::thread_start::h29594ddebf23e421 [INFO] [stdout] at src/libstd/sys/unix/thread.rs:87 [INFO] [stdout] 34: 0x7f437f0eb609 - start_thread [INFO] [stdout] 35: 0x7f437eff7103 - __clone [INFO] [stdout] 36: 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 [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "dfee0a805bc007fb25b56c976d65640f03bd9eb80b7d60f7220d23eeef34990b", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "dfee0a805bc007fb25b56c976d65640f03bd9eb80b7d60f7220d23eeef34990b", kill_on_drop: false }` [INFO] [stdout] dfee0a805bc007fb25b56c976d65640f03bd9eb80b7d60f7220d23eeef34990b