Added tests for gcd

compare gcd with euclidean gcd
test panics on gcd(min_val, min_val) and gcd(min_val, 0) for signed integers
This commit is contained in:
Emerentius 2015-09-11 20:33:39 +02:00
parent 59089d9d5c
commit 499def9207
1 changed files with 66 additions and 0 deletions

View File

@ -360,6 +360,47 @@ macro_rules! impl_integer_for_isize {
assert_eq!((-6 as $T).gcd(&3), 3 as $T); assert_eq!((-6 as $T).gcd(&3), 3 as $T);
assert_eq!((-4 as $T).gcd(&-2), 2 as $T); assert_eq!((-4 as $T).gcd(&-2), 2 as $T);
} }
#[test]
fn test_gcd_cmp_with_euclidean() {
fn euclidean_gcd(mut m: $T, mut n: $T) -> $T {
while m != 0 {
::std::mem::swap(&mut m, &mut n);
m %= n;
}
n.abs()
}
// gcd(-128, b) = 128 is not representable as positive value
// for i8
for i in -127..127 {
for j in -127..127 {
assert_eq!(euclidean_gcd(i,j), i.gcd(&j));
}
}
// last value
// FIXME: Use inclusive ranges for above loop when implemented
let i = 127;
for j in -127..127 {
assert_eq!(euclidean_gcd(i,j), i.gcd(&j));
}
assert_eq!(127.gcd(&127), 127);
}
#[test]
#[should_panic]
fn test_gcd_min_val_min_val() {
let min = <$T>::min_value();
min.gcd(&min);
}
#[test]
#[should_panic]
fn test_gcd_min_val_0() {
let min = <$T>::min_value();
min.gcd(&0);
}
#[test] #[test]
fn test_lcm() { fn test_lcm() {
@ -498,6 +539,31 @@ macro_rules! impl_integer_for_usize {
assert_eq!((56 as $T).gcd(&42), 14 as $T); assert_eq!((56 as $T).gcd(&42), 14 as $T);
} }
#[test]
fn test_gcd_cmp_with_euclidean() {
fn euclidean_gcd(mut m: $T, mut n: $T) -> $T {
while m != 0 {
::std::mem::swap(&mut m, &mut n);
m %= n;
}
n
}
for i in 0..255 {
for j in 0..255 {
assert_eq!(euclidean_gcd(i,j), i.gcd(&j));
}
}
// last value
// FIXME: Use inclusive ranges for above loop when implemented
let i = 255;
for j in 0..255 {
assert_eq!(euclidean_gcd(i,j), i.gcd(&j));
}
assert_eq!(255.gcd(&255), 255);
}
#[test] #[test]
fn test_lcm() { fn test_lcm() {
assert_eq!((1 as $T).lcm(&0), 0 as $T); assert_eq!((1 as $T).lcm(&0), 0 as $T);