summaryrefslogtreecommitdiff
path: root/tests/numerics/Commodity.cc
diff options
context:
space:
mode:
Diffstat (limited to 'tests/numerics/Commodity.cc')
-rw-r--r--tests/numerics/Commodity.cc55
1 files changed, 55 insertions, 0 deletions
diff --git a/tests/numerics/Commodity.cc b/tests/numerics/Commodity.cc
new file mode 100644
index 00000000..e7e2a18c
--- /dev/null
+++ b/tests/numerics/Commodity.cc
@@ -0,0 +1,55 @@
+#include "Commodity.h"
+
+CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(CommodityTestCase, "numerics");
+
+void CommodityTestCase::setUp() {
+ ledger::initialize();
+}
+void CommodityTestCase::tearDown() {
+ ledger::shutdown();
+}
+
+void CommodityTestCase::testPriceHistory()
+{
+ ptime jan17_07 = parse_datetime("2007/01/17 00:00:00");
+ ptime feb27_07 = parse_datetime("2007/02/27 18:00:00");
+ ptime feb28_07 = parse_datetime("2007/02/28 06:00:00");
+ ptime feb28_07sbm = parse_datetime("2007/02/28 11:59:59");
+ ptime mar01_07 = parse_datetime("2007/03/01 00:00:00");
+ ptime apr15_07 = parse_datetime("2007/04/15 13:00:00");
+
+ // jww (2007-04-17): tbd
+ amount_t x1("100.10 AAPL");
+
+ // Commodities cannot be constructed by themselves, since a great
+ // deal of their state depends on how they were seen to be used.
+ commodity_t& aapl(x1.commodity());
+
+ aapl.add_price(jan17_07, amount_t("$10.20"));
+ aapl.add_price(feb27_07, amount_t("$13.40"));
+ aapl.add_price(feb28_07, amount_t("$18.33"));
+ aapl.add_price(feb28_07sbm, amount_t("$18.30"));
+ aapl.add_price(mar01_07, amount_t("$19.50"));
+ aapl.add_price(apr15_07, amount_t("$21.22"));
+
+ assertEqual(amount_t("$1831.83"), x1.value(feb28_07sbm));
+ assertEqual(amount_t("$2124.12"), x1.value(now));
+
+ assertValid(x1);
+}
+
+void CommodityTestCase::testLots()
+{
+ // jww (2007-04-17): tbd
+}
+
+void CommodityTestCase::testScalingBase()
+{
+ // jww (2007-04-17): tbd
+}
+
+void CommodityTestCase::testReduction()
+{
+ // jww (2007-04-17): tbd
+}
+