summaryrefslogtreecommitdiffstats
path: root/sigcore/test/TestFraction.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'sigcore/test/TestFraction.cpp')
-rw-r--r--sigcore/test/TestFraction.cpp187
1 files changed, 187 insertions, 0 deletions
diff --git a/sigcore/test/TestFraction.cpp b/sigcore/test/TestFraction.cpp
new file mode 100644
index 00000000..e8818ba0
--- /dev/null
+++ b/sigcore/test/TestFraction.cpp
@@ -0,0 +1,187 @@
+/*
+ * Copyright 2008 Ben Boeckel <MathStuf@gmail.com>
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+// Header include
+#include "TestFraction.h"
+
+// Qt includes
+#include <QtTest/QTest>
+
+void TestFraction::set()
+{
+ Sigcore::Fraction frac(1, 1);
+
+ QCOMPARE(frac.numerator(), 1);
+ QCOMPARE(frac.denominator(), 1);
+
+ frac.set(3, 4);
+
+ QCOMPARE(frac.numerator(), 3);
+ QCOMPARE(frac.denominator(), 4);
+}
+
+void TestFraction::setNumerator()
+{
+ Sigcore::Fraction frac(5, 8);
+
+ frac.setNumerator(4);
+
+ QCOMPARE(frac.numerator(), 4);
+}
+
+void TestFraction::setDenominator()
+{
+ Sigcore::Fraction frac(5, 8);
+
+ frac.setDenominator(4);
+
+ QCOMPARE(frac.denominator(), 4);
+}
+
+void TestFraction::reduce()
+{
+ Sigcore::Fraction frac(5, 8);
+
+ frac.reduce();
+
+ QCOMPARE(frac.numerator(), 5);
+ QCOMPARE(frac.denominator(), 8);
+
+ frac.set(2, 4);
+ frac.reduce();
+
+ QCOMPARE(frac.numerator(), 1);
+ QCOMPARE(frac.denominator(), 2);
+
+ frac.set(-2, 4);
+ frac.reduce();
+
+ QCOMPARE(frac.numerator(), -1);
+ QCOMPARE(frac.denominator(), 2);
+}
+
+void TestFraction::assignment()
+{
+ Sigcore::Fraction frac1(5, 8);
+ Sigcore::Fraction frac2(3, 4);
+
+ frac1 = frac2;
+
+ QCOMPARE(frac1.numerator(), 3);
+ QCOMPARE(frac1.denominator(), 4);
+}
+
+void TestFraction::conversion()
+{
+ Sigcore::Fraction frac(5, 8);
+
+ QVERIFY(frac == .625);
+}
+
+void TestFraction::addition()
+{
+ Sigcore::Fraction frac1(5, 8);
+ Sigcore::Fraction frac2(3, 4);
+
+ frac1 = frac1 + frac2;
+
+ QCOMPARE(frac1.numerator(), 11);
+ QCOMPARE(frac1.denominator(), 8);
+}
+
+void TestFraction::subtraction()
+{
+ Sigcore::Fraction frac1(5, 8);
+ Sigcore::Fraction frac2(3, 4);
+
+ frac1 = frac1 - frac2;
+
+ QCOMPARE(frac1.numerator(), -1);
+ QCOMPARE(frac1.denominator(), 8);
+}
+
+void TestFraction::multiplication()
+{
+ Sigcore::Fraction frac1(5, 8);
+ Sigcore::Fraction frac2(3, 4);
+
+ frac1 = frac1 * frac2;
+
+ QCOMPARE(frac1.numerator(), 15);
+ QCOMPARE(frac1.denominator(), 32);
+}
+
+void TestFraction::division()
+{
+ Sigcore::Fraction frac1(5, 8);
+ Sigcore::Fraction frac2(3, 4);
+
+ frac1 = frac1 / frac2;
+
+ QCOMPARE(frac1.numerator(), 5);
+ QCOMPARE(frac1.denominator(), 6);
+}
+
+void TestFraction::modulo()
+{
+ Sigcore::Fraction frac1(7, 8);
+ Sigcore::Fraction frac2(1, 2);
+
+ frac1 = frac1 % frac2;
+
+ QCOMPARE(frac1.numerator(), 3);
+ QCOMPARE(frac1.denominator(), 8);
+}
+
+void TestFraction::equal()
+{
+ Sigcore::Fraction frac1(6, 8);
+ Sigcore::Fraction frac2(3, 4);
+
+ QCOMPARE(frac1, frac2);
+}
+
+void TestFraction::less()
+{
+ Sigcore::Fraction frac1(5, 8);
+ Sigcore::Fraction frac2(3, 4);
+
+ QVERIFY(frac1 < frac2);
+}
+
+void TestFraction::greater()
+{
+ Sigcore::Fraction frac1(7, 8);
+ Sigcore::Fraction frac2(3, 4);
+
+ QVERIFY(frac1 > frac2);
+}
+
+void TestFraction::normalize()
+{
+ Sigcore::Fraction frac(-2, -1);
+
+ QCOMPARE(frac.numerator(), 2);
+ QCOMPARE(frac.denominator(), 1);
+
+ frac.set(2, -1);
+
+ QCOMPARE(frac.numerator(), -2);
+ QCOMPARE(frac.denominator(), 1);
+}
+
+QTEST_APPLESS_MAIN(TestFraction)