// Copyright © 2024 Mikhail Hogrefe
//
// This file is part of Malachite.
//
// Malachite is free software: you can redistribute it and/or modify it under the terms of the GNU
// Lesser General Public License (LGPL) as published by the Free Software Foundation; either version
// 3 of the License, or (at your option) any later version. See .
use core::cmp::Ordering::*;
use malachite_base::num::comparison::traits::{EqAbs, OrdAbs};
use malachite_base::test_util::generators::signed_pair_gen;
use malachite_nz::platform::SignedLimb;
use malachite_nz::test_util::generators::integer_pair_gen;
use malachite_q::test_util::generators::{rational_gen, rational_pair_gen, rational_triple_gen};
use malachite_q::Rational;
use std::str::FromStr;
#[test]
fn test_eq_abs() {
let test = |s, t, eq| {
let u = Rational::from_str(s).unwrap();
let v = Rational::from_str(t).unwrap();
assert_eq!(u.eq_abs(&v), eq);
assert_eq!(v.eq_abs(&u), eq);
};
test("0", "0", true);
test("0", "5", false);
test("123", "123", true);
test("123", "124", false);
test("123", "122", false);
test("1000000000000", "123", false);
test("123", "1000000000000", false);
test("1000000000000", "1000000000000", true);
test("1000000000000", "0", false);
test("22/7", "0", false);
test("22/7", "22/7", true);
test("22/7", "23/7", false);
test("-123", "123", true);
test("-123", "124", false);
test("-123", "122", false);
test("-1000000000000", "123", false);
test("-123", "1000000000000", false);
test("-1000000000000", "1000000000000", true);
test("-1000000000000", "0", false);
test("-22/7", "0", false);
test("-22/7", "22/7", true);
test("-22/7", "23/7", false);
test("0", "-5", false);
test("123", "-123", true);
test("123", "-124", false);
test("123", "-122", false);
test("1000000000000", "-123", false);
test("123", "-1000000000000", false);
test("1000000000000", "-1000000000000", true);
test("22/7", "-22/7", true);
test("22/7", "-23/7", false);
test("-123", "-123", true);
test("-123", "-124", false);
test("-123", "-122", false);
test("-1000000000000", "-123", false);
test("-123", "-1000000000000", false);
test("-1000000000000", "-1000000000000", true);
test("-22/7", "-22/7", true);
test("-22/7", "-23/7", false);
}
#[allow(clippy::cmp_owned, clippy::eq_op)]
#[test]
fn eq_properties() {
rational_pair_gen().test_properties(|(x, y)| {
let eq = x.eq_abs(&y);
assert_eq!(y.eq_abs(&x), eq);
assert_eq!(x.cmp_abs(&y) == Equal, eq);
assert_eq!(x.eq_abs(&-&y), eq);
assert_eq!((-&x).eq_abs(&y), eq);
assert_eq!((-x).eq_abs(&-y), eq);
});
rational_gen().test_properties(|x| {
assert!(x.eq_abs(&x));
});
rational_triple_gen().test_properties(|(x, y, z)| {
if x.eq_abs(&y) && y.eq_abs(&z) {
assert!(x.eq_abs(&z));
}
});
integer_pair_gen().test_properties(|(x, y)| {
assert_eq!(Rational::from(&x) == Rational::from(&y), x == y);
assert_eq!(Rational::from(&x) == y, x == y);
assert_eq!(x == Rational::from(&y), x == y);
});
signed_pair_gen::().test_properties(|(x, y)| {
assert_eq!(Rational::from(x).eq_abs(&Rational::from(y)), x.eq_abs(&y));
});
}