mirror of https://mirror.osredm.com/root/redis.git
Tests: regressios for MEMORY USAGE / DEBUG DIGEST.
This commit is contained in:
parent
1f92040fcf
commit
1d09d67909
|
@ -0,0 +1,39 @@
|
||||||
|
from test import TestCase, generate_random_vector
|
||||||
|
import struct
|
||||||
|
|
||||||
|
class DebugDigestTest(TestCase):
|
||||||
|
def getname(self):
|
||||||
|
return "[regression] DEBUG DIGEST-VALUE with attributes"
|
||||||
|
|
||||||
|
def test(self):
|
||||||
|
# Generate random vectors
|
||||||
|
vec1 = generate_random_vector(4)
|
||||||
|
vec2 = generate_random_vector(4)
|
||||||
|
vec_bytes1 = struct.pack('4f', *vec1)
|
||||||
|
vec_bytes2 = struct.pack('4f', *vec2)
|
||||||
|
|
||||||
|
# Add vectors to the key, one with attribute, one without
|
||||||
|
self.redis.execute_command('VADD', self.test_key, 'FP32', vec_bytes1, f'{self.test_key}:item:1')
|
||||||
|
self.redis.execute_command('VADD', self.test_key, 'FP32', vec_bytes2, f'{self.test_key}:item:2', 'SETATTR', '{"color":"red"}')
|
||||||
|
|
||||||
|
# Call DEBUG DIGEST-VALUE on the key
|
||||||
|
try:
|
||||||
|
digest1 = self.redis.execute_command('DEBUG', 'DIGEST-VALUE', self.test_key)
|
||||||
|
assert digest1 is not None, "DEBUG DIGEST-VALUE should return a value"
|
||||||
|
|
||||||
|
# Change attribute and verify digest changes
|
||||||
|
self.redis.execute_command('VSETATTR', self.test_key, f'{self.test_key}:item:2', '{"color":"blue"}')
|
||||||
|
|
||||||
|
digest2 = self.redis.execute_command('DEBUG', 'DIGEST-VALUE', self.test_key)
|
||||||
|
assert digest2 is not None, "DEBUG DIGEST-VALUE should return a value after attribute change"
|
||||||
|
assert digest1 != digest2, "Digest should change when an attribute is modified"
|
||||||
|
|
||||||
|
# Remove attribute and verify digest changes again
|
||||||
|
self.redis.execute_command('VSETATTR', self.test_key, f'{self.test_key}:item:2', '')
|
||||||
|
|
||||||
|
digest3 = self.redis.execute_command('DEBUG', 'DIGEST-VALUE', self.test_key)
|
||||||
|
assert digest3 is not None, "DEBUG DIGEST-VALUE should return a value after attribute removal"
|
||||||
|
assert digest2 != digest3, "Digest should change when an attribute is removed"
|
||||||
|
|
||||||
|
except Exception as e:
|
||||||
|
raise AssertionError(f"DEBUG DIGEST-VALUE command failed: {str(e)}")
|
|
@ -0,0 +1,36 @@
|
||||||
|
from test import TestCase, generate_random_vector
|
||||||
|
import struct
|
||||||
|
|
||||||
|
class MemoryUsageTest(TestCase):
|
||||||
|
def getname(self):
|
||||||
|
return "[regression] MEMORY USAGE with attributes"
|
||||||
|
|
||||||
|
def test(self):
|
||||||
|
# Generate random vectors
|
||||||
|
vec1 = generate_random_vector(4)
|
||||||
|
vec2 = generate_random_vector(4)
|
||||||
|
vec_bytes1 = struct.pack('4f', *vec1)
|
||||||
|
vec_bytes2 = struct.pack('4f', *vec2)
|
||||||
|
|
||||||
|
# Add vectors to the key, one with attribute, one without
|
||||||
|
self.redis.execute_command('VADD', self.test_key, 'FP32', vec_bytes1, f'{self.test_key}:item:1')
|
||||||
|
self.redis.execute_command('VADD', self.test_key, 'FP32', vec_bytes2, f'{self.test_key}:item:2', 'SETATTR', '{"color":"red"}')
|
||||||
|
|
||||||
|
# Get memory usage for the key
|
||||||
|
try:
|
||||||
|
memory_usage = self.redis.execute_command('MEMORY', 'USAGE', self.test_key)
|
||||||
|
# If we got here without exception, the command worked
|
||||||
|
assert memory_usage > 0, "MEMORY USAGE should return a positive value"
|
||||||
|
|
||||||
|
# Add more attributes to increase complexity
|
||||||
|
self.redis.execute_command('VSETATTR', self.test_key, f'{self.test_key}:item:1', '{"color":"blue","size":10}')
|
||||||
|
|
||||||
|
# Check memory usage again
|
||||||
|
new_memory_usage = self.redis.execute_command('MEMORY', 'USAGE', self.test_key)
|
||||||
|
assert new_memory_usage > 0, "MEMORY USAGE should still return a positive value after setting attributes"
|
||||||
|
|
||||||
|
# Memory usage should be higher after adding attributes
|
||||||
|
assert new_memory_usage > memory_usage, "Memory usage increase after adding attributes"
|
||||||
|
|
||||||
|
except Exception as e:
|
||||||
|
raise AssertionError(f"MEMORY USAGE command failed: {str(e)}")
|
Loading…
Reference in New Issue