Upgrades the edition, with changes primarily performed by `cargo fix --edition`. In order to keep the changes to a minimum, this doesn't include automated idiom fixes (i.e. `cargo fix --edition-idioms`). This is needed to unblock the edition upgrade for the RSA crate: https://github.com/RustCrypto/RSA/pull/135
47 lines
1.1 KiB
Rust
47 lines
1.1 KiB
Rust
#![cfg(feature = "rand")]
|
|
|
|
extern crate num_bigint_dig as num_bigint;
|
|
extern crate num_traits;
|
|
extern crate rand;
|
|
|
|
use crate::num_bigint::RandBigInt;
|
|
use num_traits::Zero;
|
|
use rand::prelude::*;
|
|
|
|
fn test_mul_divide_torture_count(count: usize) {
|
|
let bits_max = 1 << 12;
|
|
let seed = [
|
|
1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25,
|
|
26, 27, 28, 29, 30, 31, 32,
|
|
];
|
|
let mut rng = rand::rngs::SmallRng::from_seed(seed);
|
|
|
|
for _ in 0..count {
|
|
// Test with numbers of random sizes:
|
|
let xbits = rng.gen_range(0..bits_max);
|
|
let ybits = rng.gen_range(0..bits_max);
|
|
|
|
let x = rng.gen_biguint(xbits);
|
|
let y = rng.gen_biguint(ybits);
|
|
|
|
if x.is_zero() || y.is_zero() {
|
|
continue;
|
|
}
|
|
|
|
let prod = &x * &y;
|
|
assert_eq!(&prod / &x, y);
|
|
assert_eq!(&prod / &y, x);
|
|
}
|
|
}
|
|
|
|
#[test]
|
|
fn test_mul_divide_torture() {
|
|
test_mul_divide_torture_count(1000);
|
|
}
|
|
|
|
#[test]
|
|
#[ignore]
|
|
fn test_mul_divide_torture_long() {
|
|
test_mul_divide_torture_count(1000000);
|
|
}
|