[util] add "defaultdict" filters-environment
allows accessing undefined values without raising an exception, but preserves other errors like TypeError, AttributeError, etc
This commit is contained in:
@@ -300,6 +300,87 @@ class TestCookiesTxt(unittest.TestCase):
|
||||
)
|
||||
|
||||
|
||||
class TestCompileExpression(unittest.TestCase):
|
||||
|
||||
def test_compile_expression(self):
|
||||
expr = util.compile_expression("1 + 2 * 3")
|
||||
self.assertEqual(expr(), 7)
|
||||
self.assertEqual(expr({"a": 1, "b": 2, "c": 3}), 7)
|
||||
self.assertEqual(expr({"a": 9, "b": 9, "c": 9}), 7)
|
||||
|
||||
expr = util.compile_expression("a + b * c")
|
||||
self.assertEqual(expr({"a": 1, "b": 2, "c": 3}), 7)
|
||||
self.assertEqual(expr({"a": 9, "b": 9, "c": 9}), 90)
|
||||
|
||||
with self.assertRaises(SyntaxError):
|
||||
util.compile_expression("")
|
||||
with self.assertRaises(SyntaxError):
|
||||
util.compile_expression("x++")
|
||||
|
||||
expr = util.compile_expression("1 and abort()")
|
||||
with self.assertRaises(exception.StopExtraction):
|
||||
expr()
|
||||
|
||||
def test_compile_expression_raw(self):
|
||||
expr = util.compile_expression_raw("a + b * c")
|
||||
with self.assertRaises(NameError):
|
||||
expr()
|
||||
with self.assertRaises(NameError):
|
||||
expr({"a": 2})
|
||||
|
||||
expr = util.compile_expression_defaultdict("int.param")
|
||||
with self.assertRaises(AttributeError):
|
||||
expr({"a": 2})
|
||||
|
||||
def test_compile_expression_tryexcept(self):
|
||||
expr = util.compile_expression_tryexcept("a + b * c")
|
||||
self.assertIs(expr(), util.NONE)
|
||||
self.assertIs(expr({"a": 2}), util.NONE)
|
||||
|
||||
expr = util.compile_expression_tryexcept("int.param")
|
||||
self.assertIs(expr({"a": 2}), util.NONE)
|
||||
|
||||
def test_compile_expression_defaultdict(self):
|
||||
expr = util.compile_expression_defaultdict("a + b * c")
|
||||
self.assertIs(expr(), util.NONE)
|
||||
self.assertIs(expr({"a": 2}), util.NONE)
|
||||
|
||||
expr = util.compile_expression_defaultdict("int.param")
|
||||
with self.assertRaises(AttributeError):
|
||||
expr({"a": 2})
|
||||
|
||||
def test_custom_globals(self):
|
||||
value = {"v": "foobar"}
|
||||
result = "8843d7f92416211de9ebb963ff4ce28125932878"
|
||||
|
||||
expr = util.compile_expression("hash_sha1(v)")
|
||||
self.assertEqual(expr(value), result)
|
||||
|
||||
expr = util.compile_expression("hs(v)", globals={"hs": util.sha1})
|
||||
self.assertEqual(expr(value), result)
|
||||
|
||||
with tempfile.TemporaryDirectory() as path:
|
||||
file = path + "/module_sha1.py"
|
||||
with open(file, "w") as fp:
|
||||
fp.write("""
|
||||
import hashlib
|
||||
def hash(value):
|
||||
return hashlib.sha1(value.encode()).hexdigest()
|
||||
""")
|
||||
module = util.import_file(file)
|
||||
|
||||
expr = util.compile_expression("hash(v)", globals=module.__dict__)
|
||||
self.assertEqual(expr(value), result)
|
||||
|
||||
GLOBALS_ORIG = util.GLOBALS
|
||||
try:
|
||||
util.GLOBALS = module.__dict__
|
||||
expr = util.compile_expression("hash(v)")
|
||||
finally:
|
||||
util.GLOBALS = GLOBALS_ORIG
|
||||
self.assertEqual(expr(value), result)
|
||||
|
||||
|
||||
class TestOther(unittest.TestCase):
|
||||
|
||||
def test_bencode(self):
|
||||
@@ -434,31 +515,6 @@ class TestOther(unittest.TestCase):
|
||||
self.assertEqual(util.sha1(None),
|
||||
"da39a3ee5e6b4b0d3255bfef95601890afd80709")
|
||||
|
||||
def test_compile_expression(self):
|
||||
expr = util.compile_expression("1 + 2 * 3")
|
||||
self.assertEqual(expr(), 7)
|
||||
self.assertEqual(expr({"a": 1, "b": 2, "c": 3}), 7)
|
||||
self.assertEqual(expr({"a": 9, "b": 9, "c": 9}), 7)
|
||||
|
||||
expr = util.compile_expression("a + b * c")
|
||||
self.assertEqual(expr({"a": 1, "b": 2, "c": 3}), 7)
|
||||
self.assertEqual(expr({"a": 9, "b": 9, "c": 9}), 90)
|
||||
|
||||
expr = util.compile_expression_raw("a + b * c")
|
||||
with self.assertRaises(NameError):
|
||||
expr()
|
||||
with self.assertRaises(NameError):
|
||||
expr({"a": 2})
|
||||
|
||||
with self.assertRaises(SyntaxError):
|
||||
util.compile_expression("")
|
||||
with self.assertRaises(SyntaxError):
|
||||
util.compile_expression("x++")
|
||||
|
||||
expr = util.compile_expression("1 and abort()")
|
||||
with self.assertRaises(exception.StopExtraction):
|
||||
expr()
|
||||
|
||||
def test_import_file(self):
|
||||
module = util.import_file("datetime")
|
||||
self.assertIs(module, datetime)
|
||||
@@ -478,37 +534,6 @@ value = 123
|
||||
self.assertEqual(module.value, 123)
|
||||
self.assertIs(module.datetime, datetime)
|
||||
|
||||
def test_custom_globals(self):
|
||||
value = {"v": "foobar"}
|
||||
result = "8843d7f92416211de9ebb963ff4ce28125932878"
|
||||
|
||||
expr = util.compile_expression("hash_sha1(v)")
|
||||
self.assertEqual(expr(value), result)
|
||||
|
||||
expr = util.compile_expression("hs(v)", globals={"hs": util.sha1})
|
||||
self.assertEqual(expr(value), result)
|
||||
|
||||
with tempfile.TemporaryDirectory() as path:
|
||||
file = path + "/module_sha1.py"
|
||||
with open(file, "w") as fp:
|
||||
fp.write("""
|
||||
import hashlib
|
||||
def hash(value):
|
||||
return hashlib.sha1(value.encode()).hexdigest()
|
||||
""")
|
||||
module = util.import_file(file)
|
||||
|
||||
expr = util.compile_expression("hash(v)", globals=module.__dict__)
|
||||
self.assertEqual(expr(value), result)
|
||||
|
||||
GLOBALS_ORIG = util.GLOBALS
|
||||
try:
|
||||
util.GLOBALS = module.__dict__
|
||||
expr = util.compile_expression("hash(v)")
|
||||
finally:
|
||||
util.GLOBALS = GLOBALS_ORIG
|
||||
self.assertEqual(expr(value), result)
|
||||
|
||||
def test_build_duration_func(self, f=util.build_duration_func):
|
||||
|
||||
def test_single(df, v):
|
||||
|
||||
Reference in New Issue
Block a user