Amend asset filter matching to be more explicit
This commit is contained in:
@@ -22,13 +22,12 @@ class AssetfilterTestCase(TestCase):
|
||||
Test that the asset filter works on negative aggregations.
|
||||
"""
|
||||
# We have negative news about EUR
|
||||
self.asset_rule = AssetRule.objects.create(
|
||||
AssetRule.objects.create(
|
||||
user=self.user,
|
||||
group=self.group,
|
||||
asset="EUR",
|
||||
status=3,
|
||||
)
|
||||
self.asset_rule.save()
|
||||
|
||||
# This means that:
|
||||
# * base == EUR: long is not allowed, short is allowed
|
||||
@@ -47,18 +46,156 @@ class AssetfilterTestCase(TestCase):
|
||||
# Test that short on quote of EUR is not allowed
|
||||
self.assertFalse(assetfilter.get_allowed(self.group, "USD", "EUR", "short"))
|
||||
|
||||
def test_get_allowed_base_not_listed(self):
|
||||
self.group.when_no_data = 7 # Always deny
|
||||
self.group.save()
|
||||
AssetRule.objects.create(
|
||||
user=self.user,
|
||||
group=self.group,
|
||||
asset="JPY",
|
||||
status=6, # Always allow
|
||||
)
|
||||
|
||||
self.assertFalse(assetfilter.get_allowed(self.group, "XAG", "JPY", "long"))
|
||||
|
||||
def test_get_allowed_quote_not_listed(self):
|
||||
self.group.when_no_data = 7
|
||||
self.group.save()
|
||||
|
||||
AssetRule.objects.create(
|
||||
user=self.user,
|
||||
group=self.group,
|
||||
asset="JPY",
|
||||
status=6,
|
||||
)
|
||||
|
||||
self.assertFalse(assetfilter.get_allowed(self.group, "JPY", "XAG", "long"))
|
||||
|
||||
def test_get_allowed_paranoid_success(self):
|
||||
"""
|
||||
Test that when we request explicit checking of both base and quote,
|
||||
it works.
|
||||
"""
|
||||
self.group.when_no_data = 7
|
||||
self.group.save()
|
||||
|
||||
AssetRule.objects.create(
|
||||
user=self.user,
|
||||
group=self.group,
|
||||
asset="JPY",
|
||||
status=6,
|
||||
)
|
||||
AssetRule.objects.create(
|
||||
user=self.user,
|
||||
group=self.group,
|
||||
asset="XAG",
|
||||
status=6,
|
||||
)
|
||||
|
||||
self.assertTrue(assetfilter.get_allowed(self.group, "JPY", "XAG", "long"))
|
||||
|
||||
def test_get_allowed_paranoid_success_direction(self):
|
||||
"""
|
||||
Test that when we request explicit checking of both base and quote,
|
||||
and specify a direction, it works.
|
||||
"""
|
||||
self.group.when_no_data = 7
|
||||
self.group.save()
|
||||
|
||||
AssetRule.objects.create(
|
||||
user=self.user,
|
||||
group=self.group,
|
||||
asset="JPY",
|
||||
status=2, # Positive
|
||||
)
|
||||
AssetRule.objects.create(
|
||||
user=self.user,
|
||||
group=self.group,
|
||||
asset="XAG",
|
||||
status=3, # Negative
|
||||
)
|
||||
|
||||
self.assertTrue(assetfilter.get_allowed(self.group, "JPY", "XAG", "long"))
|
||||
|
||||
def test_get_allowed_paranoid_fail_direction(self):
|
||||
"""
|
||||
Test that when we request explicit checking of both base and quote,
|
||||
and specify a direction, it works.
|
||||
"""
|
||||
self.group.when_no_data = 7
|
||||
self.group.save()
|
||||
|
||||
AssetRule.objects.create(
|
||||
user=self.user,
|
||||
group=self.group,
|
||||
asset="JPY",
|
||||
status=3, # Negative
|
||||
)
|
||||
AssetRule.objects.create(
|
||||
user=self.user,
|
||||
group=self.group,
|
||||
asset="XAG",
|
||||
status=2, # Positive
|
||||
)
|
||||
|
||||
self.assertFalse(assetfilter.get_allowed(self.group, "JPY", "XAG", "long"))
|
||||
|
||||
def test_get_allowed_paranoid_fail_direction_short(self):
|
||||
"""
|
||||
Test that when we request explicit checking of both base and quote,
|
||||
and specify a direction, it works.
|
||||
"""
|
||||
self.group.when_no_data = 7
|
||||
self.group.save()
|
||||
|
||||
AssetRule.objects.create(
|
||||
user=self.user,
|
||||
group=self.group,
|
||||
asset="JPY",
|
||||
status=2, # Positive
|
||||
)
|
||||
AssetRule.objects.create(
|
||||
user=self.user,
|
||||
group=self.group,
|
||||
asset="XAG",
|
||||
status=3, # Negative
|
||||
)
|
||||
|
||||
self.assertFalse(assetfilter.get_allowed(self.group, "JPY", "XAG", "short"))
|
||||
|
||||
def test_get_allowed_mixed_sentiment(self):
|
||||
"""
|
||||
Test that deny is hit before allow.
|
||||
"""
|
||||
AssetRule.objects.create(
|
||||
user=self.user,
|
||||
group=self.group,
|
||||
asset="JPY",
|
||||
status=6, # Always allow
|
||||
)
|
||||
AssetRule.objects.create(
|
||||
user=self.user,
|
||||
group=self.group,
|
||||
asset="XAG",
|
||||
status=7, # Always deny
|
||||
)
|
||||
|
||||
self.assertFalse(assetfilter.get_allowed(self.group, "JPY", "XAG", "short"))
|
||||
self.assertFalse(assetfilter.get_allowed(self.group, "XAG", "JPY", "short"))
|
||||
self.assertFalse(assetfilter.get_allowed(self.group, "JPY", "XAG", "long"))
|
||||
self.assertFalse(assetfilter.get_allowed(self.group, "XAG", "JPY", "long"))
|
||||
|
||||
def test_get_allowed_permitted(self):
|
||||
"""
|
||||
Test that the asset filter works on positive aggregations.
|
||||
"""
|
||||
# We have positive news about EUR
|
||||
self.asset_rule = AssetRule.objects.create(
|
||||
AssetRule.objects.create(
|
||||
user=self.user,
|
||||
group=self.group,
|
||||
asset="EUR",
|
||||
status=2,
|
||||
)
|
||||
self.asset_rule.save()
|
||||
|
||||
# This means that:
|
||||
# * base == EUR: long is allowed, short is not allowed
|
||||
@@ -78,80 +215,74 @@ class AssetfilterTestCase(TestCase):
|
||||
self.assertFalse(assetfilter.get_allowed(self.group, "USD", "EUR", "long"))
|
||||
|
||||
def test_get_allowed_no_data(self):
|
||||
self.asset_rule = AssetRule.objects.create(
|
||||
AssetRule.objects.create(
|
||||
user=self.user,
|
||||
group=self.group,
|
||||
asset="EUR",
|
||||
status=0,
|
||||
)
|
||||
self.asset_rule.save()
|
||||
|
||||
self.assertTrue(assetfilter.get_allowed(self.group, "EUR", "USD", "long"))
|
||||
|
||||
def test_get_allowed_no_data_prohibited(self):
|
||||
self.group.when_no_data = 7
|
||||
self.group.save()
|
||||
self.asset_rule = AssetRule.objects.create(
|
||||
AssetRule.objects.create(
|
||||
user=self.user,
|
||||
group=self.group,
|
||||
asset="EUR",
|
||||
status=0,
|
||||
)
|
||||
self.asset_rule.save()
|
||||
|
||||
self.assertFalse(assetfilter.get_allowed(self.group, "EUR", "USD", "long"))
|
||||
|
||||
def test_get_allowed_no_match(self):
|
||||
self.asset_rule = AssetRule.objects.create(
|
||||
AssetRule.objects.create(
|
||||
user=self.user,
|
||||
group=self.group,
|
||||
asset="EUR",
|
||||
status=1,
|
||||
)
|
||||
self.asset_rule.save()
|
||||
|
||||
self.assertTrue(assetfilter.get_allowed(self.group, "EUR", "USD", "long"))
|
||||
|
||||
def test_get_allowed_no_aggregation(self):
|
||||
self.asset_rule = AssetRule.objects.create(
|
||||
AssetRule.objects.create(
|
||||
user=self.user,
|
||||
group=self.group,
|
||||
asset="EUR",
|
||||
status=4,
|
||||
)
|
||||
self.asset_rule.save()
|
||||
|
||||
self.assertTrue(assetfilter.get_allowed(self.group, "EUR", "USD", "long"))
|
||||
|
||||
def test_get_allowed_not_in_bounds(self):
|
||||
self.asset_rule = AssetRule.objects.create(
|
||||
AssetRule.objects.create(
|
||||
user=self.user,
|
||||
group=self.group,
|
||||
asset="EUR",
|
||||
status=5,
|
||||
)
|
||||
self.asset_rule.save()
|
||||
|
||||
self.assertTrue(assetfilter.get_allowed(self.group, "EUR", "USD", "long"))
|
||||
|
||||
def test_get_allowed_always_allow(self):
|
||||
self.asset_rule = AssetRule.objects.create(
|
||||
AssetRule.objects.create(
|
||||
user=self.user,
|
||||
group=self.group,
|
||||
asset="EUR",
|
||||
status=6,
|
||||
)
|
||||
self.asset_rule.save()
|
||||
|
||||
self.assertTrue(assetfilter.get_allowed(self.group, "EUR", "USD", "long"))
|
||||
|
||||
def test_get_allowed_always_deny(self):
|
||||
self.asset_rule = AssetRule.objects.create(
|
||||
AssetRule.objects.create(
|
||||
user=self.user,
|
||||
group=self.group,
|
||||
asset="EUR",
|
||||
status=7,
|
||||
)
|
||||
self.asset_rule.save()
|
||||
|
||||
self.assertFalse(assetfilter.get_allowed(self.group, "EUR", "USD", "long"))
|
||||
|
||||
|
||||
Reference in New Issue
Block a user