|
1 | 1 | """Pluggable storage test module.""" |
2 | 2 | import json |
3 | 3 | import threading |
| 4 | +import copy |
4 | 5 | import pytest |
5 | 6 |
|
6 | 7 | from splitio.optional.loaders import asyncio |
7 | 8 | from splitio.models.splits import Split |
8 | | -from splitio.models import splits, segments |
| 9 | +from splitio.models import splits, segments, rule_based_segments |
9 | 10 | from splitio.models.segments import Segment |
10 | 11 | from splitio.models.impressions import Impression |
11 | 12 | from splitio.models.events import Event, EventWrapper |
12 | 13 | from splitio.storage.pluggable import PluggableSplitStorage, PluggableSegmentStorage, PluggableImpressionsStorage, PluggableEventsStorage, \ |
13 | 14 | PluggableTelemetryStorage, PluggableEventsStorageAsync, PluggableSegmentStorageAsync, PluggableImpressionsStorageAsync,\ |
14 | | - PluggableSplitStorageAsync, PluggableTelemetryStorageAsync |
| 15 | + PluggableSplitStorageAsync, PluggableTelemetryStorageAsync, PluggableRuleBasedSegmentsStorage, PluggableRuleBasedSegmentsStorageAsync |
15 | 16 | from splitio.client.util import get_metadata, SdkMetadata |
16 | 17 | from splitio.models.telemetry import MAX_TAGS, MethodExceptionsAndLatencies, OperationMode |
17 | | -from tests.integration import splits_json |
| 18 | +from tests.integration import splits_json, rbsegments_json |
18 | 19 |
|
19 | 20 | class StorageMockAdapter(object): |
20 | 21 | def __init__(self): |
@@ -1372,3 +1373,124 @@ async def test_push_config_stats(self): |
1372 | 1373 | await pluggable_telemetry_storage.record_active_and_redundant_factories(2, 1) |
1373 | 1374 | await pluggable_telemetry_storage.push_config_stats() |
1374 | 1375 | assert(self.mock_adapter._keys[pluggable_telemetry_storage._telemetry_config_key + "::" + pluggable_telemetry_storage._sdk_metadata] == '{"aF": 2, "rF": 1, "sT": "memory", "oM": 0, "t": []}') |
| 1376 | + |
| 1377 | +class PluggableRuleBasedSegmentStorageTests(object): |
| 1378 | + """In memory rule based segment storage test cases.""" |
| 1379 | + |
| 1380 | + def setup_method(self): |
| 1381 | + """Prepare storages with test data.""" |
| 1382 | + self.mock_adapter = StorageMockAdapter() |
| 1383 | + |
| 1384 | + def test_get(self): |
| 1385 | + self.mock_adapter._keys = {} |
| 1386 | + for sprefix in [None, 'myprefix']: |
| 1387 | + pluggable_rbs_storage = PluggableRuleBasedSegmentsStorage(self.mock_adapter, prefix=sprefix) |
| 1388 | + |
| 1389 | + rbs1 = rule_based_segments.from_raw(rbsegments_json['segment1']) |
| 1390 | + rbs_name = rbsegments_json['segment1']['name'] |
| 1391 | + |
| 1392 | + self.mock_adapter.set(pluggable_rbs_storage._prefix.format(segment_name=rbs_name), rbs1.to_json()) |
| 1393 | + assert(pluggable_rbs_storage.get(rbs_name).to_json() == rule_based_segments.from_raw(rbsegments_json['segment1']).to_json()) |
| 1394 | + assert(pluggable_rbs_storage.get('not_existing') == None) |
| 1395 | + |
| 1396 | + def test_get_change_number(self): |
| 1397 | + self.mock_adapter._keys = {} |
| 1398 | + for sprefix in [None, 'myprefix']: |
| 1399 | + pluggable_rbs_storage = PluggableRuleBasedSegmentsStorage(self.mock_adapter, prefix=sprefix) |
| 1400 | + if sprefix == 'myprefix': |
| 1401 | + prefix = 'myprefix.' |
| 1402 | + else: |
| 1403 | + prefix = '' |
| 1404 | + self.mock_adapter.set(prefix + "SPLITIO.rbsegments.till", 1234) |
| 1405 | + assert(pluggable_rbs_storage.get_change_number() == 1234) |
| 1406 | + |
| 1407 | + def test_get_segment_names(self): |
| 1408 | + self.mock_adapter._keys = {} |
| 1409 | + for sprefix in [None, 'myprefix']: |
| 1410 | + pluggable_rbs_storage = PluggableRuleBasedSegmentsStorage(self.mock_adapter, prefix=sprefix) |
| 1411 | + rbs1 = rule_based_segments.from_raw(rbsegments_json['segment1']) |
| 1412 | + rbs2_temp = copy.deepcopy(rbsegments_json['segment1']) |
| 1413 | + rbs2_temp['name'] = 'another_segment' |
| 1414 | + rbs2 = rule_based_segments.from_raw(rbs2_temp) |
| 1415 | + self.mock_adapter.set(pluggable_rbs_storage._prefix.format(segment_name=rbs1.name), rbs1.to_json()) |
| 1416 | + self.mock_adapter.set(pluggable_rbs_storage._prefix.format(segment_name=rbs2.name), rbs2.to_json()) |
| 1417 | + assert(pluggable_rbs_storage.get_segment_names() == [rbs1.name, rbs2.name]) |
| 1418 | + |
| 1419 | + def test_contains(self): |
| 1420 | + self.mock_adapter._keys = {} |
| 1421 | + for sprefix in [None, 'myprefix']: |
| 1422 | + pluggable_rbs_storage = PluggableRuleBasedSegmentsStorage(self.mock_adapter, prefix=sprefix) |
| 1423 | + rbs1 = rule_based_segments.from_raw(rbsegments_json['segment1']) |
| 1424 | + rbs2_temp = copy.deepcopy(rbsegments_json['segment1']) |
| 1425 | + rbs2_temp['name'] = 'another_segment' |
| 1426 | + rbs2 = rule_based_segments.from_raw(rbs2_temp) |
| 1427 | + self.mock_adapter.set(pluggable_rbs_storage._prefix.format(segment_name=rbs1.name), rbs1.to_json()) |
| 1428 | + self.mock_adapter.set(pluggable_rbs_storage._prefix.format(segment_name=rbs2.name), rbs2.to_json()) |
| 1429 | + |
| 1430 | + assert(pluggable_rbs_storage.contains([rbs1.name, rbs2.name])) |
| 1431 | + assert(pluggable_rbs_storage.contains([rbs2.name])) |
| 1432 | + assert(not pluggable_rbs_storage.contains(['none-exists', rbs2.name])) |
| 1433 | + assert(not pluggable_rbs_storage.contains(['none-exists', 'none-exists2'])) |
| 1434 | + |
| 1435 | +class PluggableRuleBasedSegmentStorageAsyncTests(object): |
| 1436 | + """In memory rule based segment storage test cases.""" |
| 1437 | + |
| 1438 | + def setup_method(self): |
| 1439 | + """Prepare storages with test data.""" |
| 1440 | + self.mock_adapter = StorageMockAdapterAsync() |
| 1441 | + |
| 1442 | + @pytest.mark.asyncio |
| 1443 | + async def test_get(self): |
| 1444 | + self.mock_adapter._keys = {} |
| 1445 | + for sprefix in [None, 'myprefix']: |
| 1446 | + pluggable_rbs_storage = PluggableRuleBasedSegmentsStorageAsync(self.mock_adapter, prefix=sprefix) |
| 1447 | + |
| 1448 | + rbs1 = rule_based_segments.from_raw(rbsegments_json['segment1']) |
| 1449 | + rbs_name = rbsegments_json['segment1']['name'] |
| 1450 | + |
| 1451 | + await self.mock_adapter.set(pluggable_rbs_storage._prefix.format(segment_name=rbs_name), rbs1.to_json()) |
| 1452 | + rbs = await pluggable_rbs_storage.get(rbs_name) |
| 1453 | + assert(rbs.to_json() == rule_based_segments.from_raw(rbsegments_json['segment1']).to_json()) |
| 1454 | + assert(await pluggable_rbs_storage.get('not_existing') == None) |
| 1455 | + |
| 1456 | + @pytest.mark.asyncio |
| 1457 | + async def test_get_change_number(self): |
| 1458 | + self.mock_adapter._keys = {} |
| 1459 | + for sprefix in [None, 'myprefix']: |
| 1460 | + pluggable_rbs_storage = PluggableRuleBasedSegmentsStorageAsync(self.mock_adapter, prefix=sprefix) |
| 1461 | + if sprefix == 'myprefix': |
| 1462 | + prefix = 'myprefix.' |
| 1463 | + else: |
| 1464 | + prefix = '' |
| 1465 | + await self.mock_adapter.set(prefix + "SPLITIO.rbsegments.till", 1234) |
| 1466 | + assert(await pluggable_rbs_storage.get_change_number() == 1234) |
| 1467 | + |
| 1468 | + @pytest.mark.asyncio |
| 1469 | + async def test_get_segment_names(self): |
| 1470 | + self.mock_adapter._keys = {} |
| 1471 | + for sprefix in [None, 'myprefix']: |
| 1472 | + pluggable_rbs_storage = PluggableRuleBasedSegmentsStorageAsync(self.mock_adapter, prefix=sprefix) |
| 1473 | + rbs1 = rule_based_segments.from_raw(rbsegments_json['segment1']) |
| 1474 | + rbs2_temp = copy.deepcopy(rbsegments_json['segment1']) |
| 1475 | + rbs2_temp['name'] = 'another_segment' |
| 1476 | + rbs2 = rule_based_segments.from_raw(rbs2_temp) |
| 1477 | + await self.mock_adapter.set(pluggable_rbs_storage._prefix.format(segment_name=rbs1.name), rbs1.to_json()) |
| 1478 | + await self.mock_adapter.set(pluggable_rbs_storage._prefix.format(segment_name=rbs2.name), rbs2.to_json()) |
| 1479 | + assert(await pluggable_rbs_storage.get_segment_names() == [rbs1.name, rbs2.name]) |
| 1480 | + |
| 1481 | + @pytest.mark.asyncio |
| 1482 | + async def test_contains(self): |
| 1483 | + self.mock_adapter._keys = {} |
| 1484 | + for sprefix in [None, 'myprefix']: |
| 1485 | + pluggable_rbs_storage = PluggableRuleBasedSegmentsStorageAsync(self.mock_adapter, prefix=sprefix) |
| 1486 | + rbs1 = rule_based_segments.from_raw(rbsegments_json['segment1']) |
| 1487 | + rbs2_temp = copy.deepcopy(rbsegments_json['segment1']) |
| 1488 | + rbs2_temp['name'] = 'another_segment' |
| 1489 | + rbs2 = rule_based_segments.from_raw(rbs2_temp) |
| 1490 | + await self.mock_adapter.set(pluggable_rbs_storage._prefix.format(segment_name=rbs1.name), rbs1.to_json()) |
| 1491 | + await self.mock_adapter.set(pluggable_rbs_storage._prefix.format(segment_name=rbs2.name), rbs2.to_json()) |
| 1492 | + |
| 1493 | + assert(await pluggable_rbs_storage.contains([rbs1.name, rbs2.name])) |
| 1494 | + assert(await pluggable_rbs_storage.contains([rbs2.name])) |
| 1495 | + assert(not await pluggable_rbs_storage.contains(['none-exists', rbs2.name])) |
| 1496 | + assert(not await pluggable_rbs_storage.contains(['none-exists', 'none-exists2'])) |
0 commit comments