]> git.immae.eu Git - perso/Immae/Projets/Cryptomonnaies/Cryptoportfolio/Trader.git/blobdiff - test.py
Merge branch 'dev'
[perso/Immae/Projets/Cryptomonnaies/Cryptoportfolio/Trader.git] / test.py
diff --git a/test.py b/test.py
index 21077a36051fd3ab05bdc9262e1f29416934c56c..ed8943461fe07bae36a5c7fd87f0c13cf89ce01b 100644 (file)
--- a/test.py
+++ b/test.py
-import portfolio
 import unittest
-from unittest import mock
+from tests.acceptance import TimeMock
 
-class AmountTest(unittest.TestCase):
-    def test_values(self):
-        amount = portfolio.Amount("BTC", 0.65)
-        self.assertEqual(0.65, amount.value)
-        self.assertEqual("BTC", amount.currency)
+from tests.helper import limits
 
-        amount = portfolio.Amount("BTC", 10, int_val=2000000000000000)
-        self.assertEqual(0.002, amount.value)
+if "unit" in limits:
+    from tests.test_ccxt_wrapper import *
+    from tests.test_main import *
+    from tests.test_market import *
+    from tests.test_store import *
+    from tests.test_portfolio import *
+    from tests.test_dbs import *
 
-    def test_in_currency(self):
-        amount = portfolio.Amount("ETC", 10)
-
-        self.assertEqual(amount, amount.in_currency("ETC", None))
-
-        ticker_mock = unittest.mock.Mock()
-        with mock.patch.object(portfolio.Amount, 'get_ticker', new=ticker_mock):
-            ticker_mock.return_value = None
-            portfolio.Amount.get_ticker = ticker_mock
-
-            self.assertRaises(Exception, amount.in_currency, "ETH", None)
-
-        with mock.patch.object(portfolio.Amount, 'get_ticker', new=ticker_mock):
-            ticker_mock.return_value = {
-                    "average": 0.3,
-                    "foo": "bar",
-                    }
-            converted_amount = amount.in_currency("ETH", None)
-
-            self.assertEqual(3.0, converted_amount.value)
-            self.assertEqual("ETH", converted_amount.currency)
-            self.assertEqual(amount, converted_amount.linked_to)
-            self.assertEqual("bar", converted_amount.ticker["foo"])
-
-    @unittest.skip("TODO")
-    def test_get_ticker(self):
-        pass
-
-    def test__abs(self):
-        amount = portfolio.Amount("SC", -120)
-        self.assertEqual(120, abs(amount).value)
-        self.assertEqual("SC", abs(amount).currency)
-
-        amount = portfolio.Amount("SC", 10)
-        self.assertEqual(10, abs(amount).value)
-        self.assertEqual("SC", abs(amount).currency)
-
-    def test__add(self):
-        amount1 = portfolio.Amount("XVG", 12.9)
-        amount2 = portfolio.Amount("XVG", 13.1)
-
-        self.assertEqual(26, (amount1 + amount2).value)
-        self.assertEqual("XVG", (amount1 + amount2).currency)
-
-        amount3 = portfolio.Amount("ETH", 1.6)
-        with self.assertRaises(Exception):
-            amount1 + amount3
-
-        amount4 = portfolio.Amount("ETH", 0.0)
-        self.assertEqual(amount1, amount1 + amount4)
-
-    def test__radd(self):
-        amount = portfolio.Amount("XVG", 12.9)
-
-        self.assertEqual(amount, 0 + amount)
-        with self.assertRaises(Exception):
-            4 + amount
-
-    def test__sub(self):
-        amount1 = portfolio.Amount("XVG", 13.3)
-        amount2 = portfolio.Amount("XVG", 13.1)
-
-        self.assertEqual(0.2, (amount1 - amount2).value)
-        self.assertEqual("XVG", (amount1 - amount2).currency)
-
-        amount3 = portfolio.Amount("ETH", 1.6)
-        with self.assertRaises(Exception):
-            amount1 - amount3
-
-        amount4 = portfolio.Amount("ETH", 0.0)
-        self.assertEqual(amount1, amount1 - amount4)
-
-    def test__int(self):
-        amount = portfolio.Amount("XMR", 0.1)
-        self.assertEqual(100000000000000000, int(amount))
-
-    def test__mul(self):
-        amount = portfolio.Amount("XEM", 11)
-
-        self.assertEqual(38.5, (amount * 3.5).value)
-        self.assertEqual(33, (amount * 3).value)
-
-        with self.assertRaises(Exception):
-            amount * amount
-
-    def test__rmul(self):
-        amount = portfolio.Amount("XEM", 11)
-
-        self.assertEqual(38.5, (3.5 * amount).value)
-        self.assertEqual(33, (3 * amount).value)
-
-    def test__floordiv(self):
-        amount = portfolio.Amount("XEM", 11)
-
-        self.assertEqual(5.5, (amount // 2).value)
-        with self.assertRaises(TypeError):
-            amount // 2.5
-        self.assertEqual(1571428571428571428, (amount // 7)._value)
-
-    def test__div(self):
-        amount = portfolio.Amount("XEM", 11)
-
-        with self.assertRaises(TypeError):
-            amount / 2.5
-        self.assertEqual(5.5, (amount / 2).value)
-        self.assertEqual(1571428571428571428, (amount / 7)._value)
-
-    def test__lt(self):
-        amount1 = portfolio.Amount("BTD", 11.3)
-        amount2 = portfolio.Amount("BTD", 13.1)
-
-        self.assertTrue(amount1 < amount2)
-        self.assertFalse(amount2 < amount1)
-        self.assertFalse(amount1 < amount1)
-
-        amount3 = portfolio.Amount("BTC", 1.6)
-        with self.assertRaises(Exception):
-            amount1 < amount3
-
-    def test__eq(self):
-        amount1 = portfolio.Amount("BTD", 11.3)
-        amount2 = portfolio.Amount("BTD", 13.1)
-        amount3 = portfolio.Amount("BTD", 11.3)
-
-        self.assertFalse(amount1 == amount2)
-        self.assertFalse(amount2 == amount1)
-        self.assertTrue(amount1 == amount3)
-        self.assertFalse(amount2 == 0)
-
-        amount4 = portfolio.Amount("BTC", 1.6)
-        with self.assertRaises(Exception):
-            amount1 == amount4
-
-        amount5 = portfolio.Amount("BTD", 0)
-        self.assertTrue(amount5 == 0)
-
-    def test__str(self):
-        amount1 = portfolio.Amount("BTX", 32)
-        self.assertEqual("32.00000000 BTX", str(amount1))
-
-        amount2 = portfolio.Amount("USDT", 12000)
-        amount1.linked_to = amount2
-        self.assertEqual("32.00000000 BTX [12000.00000000 USDT]", str(amount1))
-
-    def test__repr(self):
-        amount1 = portfolio.Amount("BTX", 32)
-        self.assertEqual("Amount(32.00000000 BTX)", repr(amount1))
-
-        amount2 = portfolio.Amount("USDT", 12000)
-        amount1.linked_to = amount2
-        self.assertEqual("Amount(32.00000000 BTX -> Amount(12000.00000000 USDT))", repr(amount1))
-
-        amount3 = portfolio.Amount("BTC", 0.1)
-        amount2.linked_to = amount3
-        self.assertEqual("Amount(32.00000000 BTX -> Amount(12000.00000000 USDT -> Amount(0.10000000 BTC)))", repr(amount1))
-
-class PortfolioTest(unittest.TestCase):
-    import urllib3
-    def fill_data(self):
-        if self.json_response is not None:
-            portfolio.Portfolio.data = self.json_response
-
-    def setUp(self):
-        super(PortfolioTest, self).setUp()
-
-        with open("test_portfolio.json") as example:
-            import json
-            self.json_response = json.load(example)
-
-        self.patcher = mock.patch.multiple(portfolio.Portfolio, data=None, liquidities={})
-        self.patcher.start()
-
-    @mock.patch.object(urllib3, "disable_warnings")
-    @mock.patch.object(urllib3.poolmanager.PoolManager, "request")
-    @mock.patch.object(portfolio.Portfolio, "URL", new="foo://bar")
-    def test_get_cryptoportfolio(self, request, disable_warnings):
-        request.side_effect = [
-                type('', (), { "data": '{ "foo": "bar" }' }),
-                type('', (), { "data": 'System Error' }),
-                Exception("Connection error"),
-                ]
-
-        portfolio.Portfolio.get_cryptoportfolio()
-        self.assertIn("foo", portfolio.Portfolio.data)
-        self.assertEqual("bar", portfolio.Portfolio.data["foo"])
-        request.assert_called_with("GET", "foo://bar")
-
-        request.reset_mock()
-        portfolio.Portfolio.get_cryptoportfolio()
-        self.assertIsNone(portfolio.Portfolio.data)
-        request.assert_called_with("GET", "foo://bar")
-
-        request.reset_mock()
-        portfolio.Portfolio.data = "foo"
-        portfolio.Portfolio.get_cryptoportfolio()
-        request.assert_called_with("GET", "foo://bar")
-        self.assertEqual("foo", portfolio.Portfolio.data)
-        disable_warnings.assert_called_with()
-
-    @mock.patch.object(portfolio.Portfolio, "get_cryptoportfolio")
-    def test_parse_cryptoportfolio(self, mock_get):
-        mock_get.side_effect = self.fill_data
-
-        portfolio.Portfolio.parse_cryptoportfolio()
-
-        self.assertListEqual(
-                ["medium", "high"],
-                list(portfolio.Portfolio.liquidities.keys()))
-
-        liquidities = portfolio.Portfolio.liquidities
-        self.assertEqual(10, len(liquidities["medium"].keys()))
-        self.assertEqual(10, len(liquidities["high"].keys()))
-
-        expected = {'BTC': 2857, 'DGB': 1015, 'DOGE': 1805, 'SC': 623, 'ZEC': 3701}
-        self.assertDictEqual(expected, liquidities["high"]['2018-01-08'])
-
-        expected = {'ETC': 1000, 'FCT': 1000, 'GAS': 1000, 'NAV': 1000, 'OMG': 1000, 'OMNI': 1000, 'PPC': 1000, 'RIC': 1000, 'VIA': 1000, 'XCP': 1000}
-        self.assertDictEqual(expected, liquidities["medium"]['2018-01-08'])
-
-        # It doesn't refetch the data when available
-        portfolio.Portfolio.parse_cryptoportfolio()
-        mock_get.assert_called_once_with()
-
-        portfolio.Portfolio.data["portfolio_1"]["holding"]["direction"][3] = "short"
-        self.assertRaises(AssertionError, portfolio.Portfolio.parse_cryptoportfolio)
-
-    @mock.patch.object(portfolio.Portfolio, "get_cryptoportfolio")
-    def test_repartition_pertenthousand(self, mock_get):
-        mock_get.side_effect = self.fill_data
-
-        expected_medium = {'USDT': 1000, 'ETC': 1000, 'FCT': 1000, 'OMG': 1000, 'STEEM': 1000, 'STRAT': 1000, 'XEM': 1000, 'XMR': 1000, 'XVC': 1000, 'ZRX': 1000}
-        expected_high = {'USDT': 1226, 'BTC': 1429, 'ETC': 1127, 'ETH': 1569, 'FCT': 3341, 'GAS': 1308}
-
-        self.assertEqual(expected_medium, portfolio.Portfolio.repartition_pertenthousand())
-        self.assertEqual(expected_medium, portfolio.Portfolio.repartition_pertenthousand(liquidity="medium"))
-        self.assertEqual(expected_high, portfolio.Portfolio.repartition_pertenthousand(liquidity="high"))
-
-    def tearDown(self):
-        self.patcher.stop()
+if "acceptance" in limits:
+    from tests.test_acceptance import *
 
 if __name__ == '__main__':
     unittest.main()