X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=test.py;h=d7743b26ec11493b7cc62c51de698fae65842f2d;hb=17fd3f752d5e37df906abddf1f13fd7ad1de6c00;hp=21077a36051fd3ab05bdc9262e1f29416934c56c;hpb=183a53e3be74fabf501eaff19a39a47f1a6c9af5;p=perso%2FImmae%2FProjets%2FCryptomonnaies%2FCryptoportfolio%2FTrader.git diff --git a/test.py b/test.py index 21077a3..d7743b2 100644 --- a/test.py +++ b/test.py @@ -1,255 +1,17 @@ -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 * - 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()