2016-01-22 01:07:27 +08:00
|
|
|
import test_helper
|
2015-11-11 19:28:24 +08:00
|
|
|
from mockredis import MockRedis
|
2016-01-29 18:54:50 +08:00
|
|
|
from cartodb_services.metrics import QuotaService
|
2016-07-21 19:46:57 +08:00
|
|
|
from cartodb_services.metrics import GeocoderConfig, RoutingConfig, ObservatorySnapshotConfig, IsolinesRoutingConfig
|
2015-11-11 19:28:24 +08:00
|
|
|
from unittest import TestCase
|
|
|
|
from nose.tools import assert_raises
|
2016-01-22 01:07:27 +08:00
|
|
|
from datetime import datetime, date
|
2015-11-11 19:28:24 +08:00
|
|
|
|
|
|
|
|
|
|
|
class TestQuotaService(TestCase):
|
|
|
|
|
2016-01-22 01:07:27 +08:00
|
|
|
# single user
|
|
|
|
# user:<username>:<service>:<metric>:YYYYMM:DD
|
|
|
|
# organization user
|
|
|
|
# org:<orgname>:<service>:<metric>:YYYYMM:DD
|
|
|
|
|
|
|
|
def setUp(self):
|
|
|
|
self.redis_conn = MockRedis()
|
|
|
|
|
|
|
|
def test_should_return_true_if_user_quota_with_no_use(self):
|
2016-04-14 23:50:46 +08:00
|
|
|
qs = self.__build_geocoder_quota_service('test_user')
|
2016-01-22 01:07:27 +08:00
|
|
|
assert qs.check_user_quota() is True
|
|
|
|
|
|
|
|
def test_should_return_true_if_org_quota_with_no_use(self):
|
2016-04-14 23:50:46 +08:00
|
|
|
qs = self.__build_geocoder_quota_service('test_user',
|
|
|
|
orgname='test_org')
|
2016-01-22 01:07:27 +08:00
|
|
|
assert qs.check_user_quota() is True
|
|
|
|
|
|
|
|
def test_should_return_true_if_user_quota_is_not_completely_used(self):
|
2016-04-14 23:50:46 +08:00
|
|
|
qs = self.__build_geocoder_quota_service('test_user')
|
2016-04-22 22:43:28 +08:00
|
|
|
test_helper.increment_service_uses(self.redis_conn, 'test_user')
|
2016-01-22 01:07:27 +08:00
|
|
|
assert qs.check_user_quota() is True
|
|
|
|
|
|
|
|
def test_should_return_true_if_org_quota_is_not_completely_used(self):
|
2016-04-14 23:50:46 +08:00
|
|
|
qs = self.__build_geocoder_quota_service('test_user',
|
|
|
|
orgname='test_org')
|
2016-04-22 22:43:28 +08:00
|
|
|
test_helper.increment_service_uses(self.redis_conn, 'test_user',
|
|
|
|
orgname='test_org')
|
2016-01-22 01:07:27 +08:00
|
|
|
assert qs.check_user_quota() is True
|
|
|
|
|
|
|
|
def test_should_return_false_if_user_quota_is_surpassed(self):
|
2016-04-14 23:50:46 +08:00
|
|
|
qs = self.__build_geocoder_quota_service('test_user')
|
2016-04-22 22:43:28 +08:00
|
|
|
test_helper.increment_service_uses(self.redis_conn, 'test_user',
|
|
|
|
amount=300)
|
2016-01-22 01:07:27 +08:00
|
|
|
assert qs.check_user_quota() is False
|
|
|
|
|
|
|
|
def test_should_return_false_if_org_quota_is_surpassed(self):
|
2016-04-14 23:50:46 +08:00
|
|
|
qs = self.__build_geocoder_quota_service('test_user',
|
|
|
|
orgname='test_org')
|
2016-04-22 22:43:28 +08:00
|
|
|
test_helper.increment_service_uses(self.redis_conn, 'test_user',
|
|
|
|
orgname='test_org', amount=400)
|
2016-01-22 01:07:27 +08:00
|
|
|
assert qs.check_user_quota() is False
|
|
|
|
|
|
|
|
def test_should_return_true_if_user_quota_is_surpassed_but_soft_limit_is_enabled(self):
|
2016-04-14 23:50:46 +08:00
|
|
|
qs = self.__build_geocoder_quota_service('test_user', soft_limit=True)
|
2016-04-22 22:43:28 +08:00
|
|
|
test_helper.increment_service_uses(self.redis_conn, 'test_user',
|
|
|
|
amount=300)
|
2016-01-22 01:07:27 +08:00
|
|
|
assert qs.check_user_quota() is True
|
|
|
|
|
|
|
|
def test_should_return_true_if_org_quota_is_surpassed_but_soft_limit_is_enabled(self):
|
2016-04-14 23:50:46 +08:00
|
|
|
qs = self.__build_geocoder_quota_service('test_user',
|
|
|
|
orgname='test_org',
|
|
|
|
soft_limit=True)
|
2016-04-22 22:43:28 +08:00
|
|
|
test_helper.increment_service_uses(self.redis_conn, 'test_user',
|
2016-01-22 01:07:27 +08:00
|
|
|
orgname='test_org', amount=400)
|
|
|
|
assert qs.check_user_quota() is True
|
|
|
|
|
|
|
|
def test_should_check_user_increment_and_quota_check_correctly(self):
|
2016-04-14 23:50:46 +08:00
|
|
|
qs = self.__build_geocoder_quota_service('test_user', quota=2)
|
2016-03-07 22:40:37 +08:00
|
|
|
qs.increment_success_service_use()
|
2016-01-29 18:54:50 +08:00
|
|
|
assert qs.check_user_quota() is True
|
2016-03-07 22:40:37 +08:00
|
|
|
qs.increment_success_service_use(amount=2)
|
2016-01-29 18:54:50 +08:00
|
|
|
assert qs.check_user_quota() is False
|
2016-01-22 01:07:27 +08:00
|
|
|
|
|
|
|
def test_should_check_org_increment_and_quota_check_correctly(self):
|
2016-04-14 23:50:46 +08:00
|
|
|
qs = self.__build_geocoder_quota_service('test_user', quota=2,
|
|
|
|
orgname='test_org')
|
2016-03-07 22:40:37 +08:00
|
|
|
qs.increment_success_service_use()
|
2016-01-29 18:54:50 +08:00
|
|
|
assert qs.check_user_quota() is True
|
2016-03-07 22:40:37 +08:00
|
|
|
qs.increment_success_service_use(amount=2)
|
2016-01-29 18:54:50 +08:00
|
|
|
assert qs.check_user_quota() is False
|
2016-01-22 01:07:27 +08:00
|
|
|
|
2016-04-14 23:50:46 +08:00
|
|
|
def test_should_check_user_mapzen_geocoder_quota_correctly(self):
|
|
|
|
qs = self.__build_geocoder_quota_service('test_user', service='mapzen')
|
|
|
|
qs.increment_success_service_use()
|
|
|
|
assert qs.check_user_quota() is True
|
|
|
|
qs.increment_success_service_use(amount=1500000)
|
|
|
|
assert qs.check_user_quota() is False
|
|
|
|
|
|
|
|
def test_should_check_org_mapzen_geocoder_quota_correctly(self):
|
|
|
|
qs = self.__build_geocoder_quota_service('test_user', orgname='testorg',
|
|
|
|
service='mapzen')
|
|
|
|
qs.increment_success_service_use()
|
|
|
|
assert qs.check_user_quota() is True
|
|
|
|
qs.increment_success_service_use(amount=1500000)
|
|
|
|
assert qs.check_user_quota() is False
|
|
|
|
|
|
|
|
def test_should_check_user_routing_quota_correctly(self):
|
|
|
|
qs = self.__build_routing_quota_service('test_user')
|
|
|
|
qs.increment_success_service_use()
|
|
|
|
assert qs.check_user_quota() is True
|
|
|
|
qs.increment_success_service_use(amount=1500000)
|
|
|
|
assert qs.check_user_quota() is False
|
|
|
|
|
|
|
|
def test_should_check_org_routing_quota_correctly(self):
|
|
|
|
qs = self.__build_routing_quota_service('test_user', orgname='testorg')
|
|
|
|
qs.increment_success_service_use()
|
|
|
|
assert qs.check_user_quota() is True
|
|
|
|
qs.increment_success_service_use(amount=1500000)
|
|
|
|
assert qs.check_user_quota() is False
|
|
|
|
|
2016-07-21 19:46:57 +08:00
|
|
|
def test_should_check_user_isolines_quota_correctly(self):
|
|
|
|
qs = self.__build_isolines_quota_service('test_user')
|
|
|
|
qs.increment_success_service_use()
|
|
|
|
assert qs.check_user_quota() is True
|
|
|
|
qs.increment_success_service_use(amount=1500000)
|
|
|
|
assert qs.check_user_quota() is False
|
|
|
|
|
|
|
|
def test_should_check_org_isolines_quota_correctly(self):
|
|
|
|
qs = self.__build_isolines_quota_service('test_user', orgname='testorg')
|
|
|
|
qs.increment_success_service_use()
|
|
|
|
assert qs.check_user_quota() is True
|
|
|
|
qs.increment_success_service_use(amount=1500000)
|
|
|
|
assert qs.check_user_quota() is False
|
|
|
|
|
2016-04-22 22:43:28 +08:00
|
|
|
def test_should_check_user_obs_snapshot_quota_correctly(self):
|
|
|
|
qs = self.__build_obs_snapshot_quota_service('test_user')
|
2016-04-20 00:45:45 +08:00
|
|
|
qs.increment_success_service_use()
|
|
|
|
assert qs.check_user_quota() is True
|
|
|
|
qs.increment_success_service_use(amount=100000)
|
|
|
|
assert qs.check_user_quota() is False
|
|
|
|
|
2016-04-22 22:43:28 +08:00
|
|
|
def test_should_check_org_obs_snapshot_quota_correctly(self):
|
|
|
|
qs = self.__build_obs_snapshot_quota_service('test_user',
|
|
|
|
orgname='testorg')
|
2016-04-20 00:45:45 +08:00
|
|
|
qs.increment_success_service_use()
|
|
|
|
assert qs.check_user_quota() is True
|
|
|
|
qs.increment_success_service_use(amount=100000)
|
|
|
|
assert qs.check_user_quota() is False
|
|
|
|
|
2016-04-14 23:50:46 +08:00
|
|
|
def __prepare_quota_service(self, username, quota, service, orgname,
|
2016-04-22 22:43:28 +08:00
|
|
|
soft_limit, do_quota, soft_do_limit, end_date):
|
2016-01-22 01:07:27 +08:00
|
|
|
test_helper.build_redis_user_config(self.redis_conn, username,
|
2016-04-14 23:50:46 +08:00
|
|
|
quota=quota, service=service,
|
|
|
|
soft_limit=soft_limit,
|
2016-04-22 22:43:28 +08:00
|
|
|
soft_do_limit=soft_do_limit,
|
|
|
|
do_quota=do_quota,
|
2016-04-14 23:50:46 +08:00
|
|
|
end_date=end_date)
|
2016-01-22 01:07:27 +08:00
|
|
|
if orgname:
|
|
|
|
test_helper.build_redis_org_config(self.redis_conn, orgname,
|
2016-04-22 22:43:28 +08:00
|
|
|
quota=quota, service=service,
|
|
|
|
do_quota=do_quota,
|
|
|
|
end_date=end_date)
|
2016-04-14 23:50:46 +08:00
|
|
|
self._plpy_mock = test_helper.build_plpy_mock()
|
|
|
|
|
|
|
|
def __build_geocoder_quota_service(self, username, quota=100,
|
|
|
|
service='heremaps', orgname=None,
|
|
|
|
soft_limit=False,
|
|
|
|
end_date=datetime.today()):
|
|
|
|
self.__prepare_quota_service(username, quota, service, orgname,
|
2016-04-22 22:43:28 +08:00
|
|
|
soft_limit, 0, False, end_date)
|
2016-04-14 23:50:46 +08:00
|
|
|
geocoder_config = GeocoderConfig(self.redis_conn, self._plpy_mock,
|
2016-03-08 19:24:27 +08:00
|
|
|
username, orgname)
|
2016-04-14 23:50:46 +08:00
|
|
|
return QuotaService(geocoder_config, redis_connection=self.redis_conn)
|
|
|
|
|
2016-07-21 19:46:57 +08:00
|
|
|
def __build_routing_quota_service(self, username, service='mapzen',
|
2016-04-22 22:43:28 +08:00
|
|
|
orgname=None, soft_limit=False,
|
|
|
|
quota=100, end_date=datetime.today()):
|
2016-04-14 23:50:46 +08:00
|
|
|
self.__prepare_quota_service(username, quota, service, orgname,
|
2016-04-22 22:43:28 +08:00
|
|
|
soft_limit, 0, False, end_date)
|
2016-04-14 23:50:46 +08:00
|
|
|
routing_config = RoutingConfig(self.redis_conn, self._plpy_mock,
|
|
|
|
username, orgname)
|
|
|
|
return QuotaService(routing_config, redis_connection=self.redis_conn)
|
2016-04-20 00:45:45 +08:00
|
|
|
|
2016-07-21 19:46:57 +08:00
|
|
|
def __build_isolines_quota_service(self, username, service='mapzen',
|
|
|
|
orgname=None, soft_limit=False,
|
|
|
|
quota=100, end_date=datetime.today()):
|
|
|
|
self.__prepare_quota_service(username, quota, service, orgname,
|
|
|
|
soft_limit, 0, False, end_date)
|
|
|
|
isolines_config = IsolinesRoutingConfig(self.redis_conn, self._plpy_mock,
|
|
|
|
username, orgname)
|
|
|
|
return QuotaService(isolines_config, redis_connection=self.redis_conn)
|
|
|
|
|
2016-04-22 22:43:28 +08:00
|
|
|
def __build_obs_snapshot_quota_service(self, username, quota=100,
|
|
|
|
service='obs_snapshot',
|
|
|
|
orgname=None,
|
2016-04-20 00:45:45 +08:00
|
|
|
soft_limit=False,
|
|
|
|
end_date=datetime.today()):
|
2016-04-22 22:43:28 +08:00
|
|
|
self.__prepare_quota_service(username, 0, service, orgname, False,
|
|
|
|
quota, soft_limit, end_date)
|
|
|
|
do_config = ObservatorySnapshotConfig(self.redis_conn, self._plpy_mock,
|
2016-04-20 00:45:45 +08:00
|
|
|
username, orgname)
|
|
|
|
return QuotaService(do_config, redis_connection=self.redis_conn)
|