Fix tests

This commit is contained in:
simon987 2021-10-21 19:52:42 -04:00
parent 5e00ddccdb
commit ed9d148411
6 changed files with 32 additions and 9 deletions

5
.gitignore vendored
View File

@ -1,4 +1,7 @@
*.iml
.idea/
*.db
*.png
*.png
hexlib.egg-info
build/
dist/

View File

@ -36,6 +36,9 @@ class VolatileState:
def __getitem__(self, table):
return RedisTable(self, table, self._sep)
def __delitem__(self, key):
self.rdb.delete(f"{self.prefix}{self._sep}{key}")
class VolatileQueue:
"""Quick and dirty volatile queue-like redis wrapper"""
@ -68,6 +71,9 @@ class VolatileBooleanState:
def __getitem__(self, table):
return RedisBooleanTable(self, table, self._sep)
def __delitem__(self, table):
self.rdb.delete(f"{self.prefix}{self._sep}{table}")
class RedisTable:
def __init__(self, state, table, sep=""):
@ -89,9 +95,9 @@ class RedisTable:
self._state.rdb.hdel(self._key, str(key))
def __iter__(self):
val = self._state.rdb.hgetall(self._key)
if val:
return ((k, umsgpack.loads(v)) for k, v in val.items())
for val in self._state.rdb.hscan(self._key):
if val:
return ((k, umsgpack.loads(v)) for k, v in val.items())
class RedisBooleanTable:
@ -114,7 +120,7 @@ class RedisBooleanTable:
self._state.rdb.srem(self._key, str(key))
def __iter__(self):
return iter(self._state.rdb.smembers(self._key))
yield from self._state.rdb.sscan_iter(self._key)
class Table:

View File

@ -14,6 +14,7 @@ setup(
install_requires=[
"ImageHash", "influxdb", "siphash", "python-dateutil", "redis", "orjson", "zstandard",
"u-msgpack-python", "psycopg2-binary", "bs4", "lxml", "nltk", "numpy",
"matplotlib", "scikit-learn", "fake-useragent @ git+git://github.com/Jordan9675/fake-useragent"
"matplotlib", "scikit-learn", "fake-useragent @ git+git://github.com/Jordan9675/fake-useragent",
"requests"
]
)

0
test/__init__.py Normal file
View File

View File

@ -1,10 +1,15 @@
from unittest import TestCase
from hexlib.db import VolatileState, VolatileBooleanState, VolatileQueue
from hexlib.env import get_redis
class TestVolatileState(TestCase):
def setUp(self) -> None:
rdb = get_redis()
rdb.delete("test1a", "test1b", "test1c", "test1:a", "test2b")
def test_get_set(self):
s = VolatileState(prefix="test1")
val = {
@ -53,6 +58,10 @@ class TestVolatileState(TestCase):
class TestVolatileBoolState(TestCase):
def setUp(self) -> None:
rdb = get_redis()
rdb.delete("test1a", "test1b", "test1c", "test1:a", "test2b")
def test_get_set(self):
s = VolatileBooleanState(prefix="test1")

View File

@ -2,12 +2,16 @@ import os
from unittest import TestCase
from hexlib.web import download_file
import warnings
class TestDownloadFile(TestCase):
def setUp(self) -> None:
warnings.filterwarnings(action="ignore", category=ResourceWarning)
def test_download_file(self):
download_file("http://ovh.net/files/10Mb.dat", "/tmp/10Mb.dat")
download_file("https://github.com/simon987/hexlib/raw/master/10MB.bin", "/tmp/10Mb.dat")
self.assertTrue(os.path.exists("/tmp/10Mb.dat"))
os.remove("/tmp/10Mb.dat")
@ -22,8 +26,8 @@ class TestDownloadFile(TestCase):
self.assertEqual(len(exceptions), 3)
def test_download_file_meta(self):
download_file("http://ovh.net/files/10Mb.dat", "/tmp/10Mb.dat", save_meta=True)
download_file("https://github.com/simon987/hexlib/raw/master/10MB.bin", "/tmp/10Mb.dat", save_meta=True)
self.assertTrue(os.path.exists("/tmp/10Mb.dat"))
self.assertTrue(os.path.exists("/tmp/10Mb.dat.meta"))
os.remove("/tmp/10Mb.dat")
# os.remove("/tmp/10Mb.dat.meta")
os.remove("/tmp/10Mb.dat.meta")