Merge branch 'fix_arbitrary_code_execution' into develop
This commit is contained in:
@ -48,3 +48,11 @@ class PropertyFilterTest(TestCase):
|
||||
pf["testkey"] = "new value"
|
||||
self.assertEqual(pm["testkey"], "new value")
|
||||
self.assertEqual(pf["testkey"], "new value")
|
||||
|
||||
def testRejectsWrite(self):
|
||||
pm = PropertyLayer()
|
||||
pm["testkey"] = "old value"
|
||||
pf = PropertyFilter(pm, "otherkey")
|
||||
with self.assertRaises(KeyError):
|
||||
pf["testkey"] = "new value"
|
||||
self.assertEqual(pm["testkey"], "old value")
|
||||
|
37
test/property/test_property_validator.py
Normal file
37
test/property/test_property_validator.py
Normal file
@ -0,0 +1,37 @@
|
||||
from unittest import TestCase
|
||||
from owrx.property import PropertyLayer, PropertyValidator, PropertyValidationError
|
||||
from owrx.property.validators import NumberValidator, StringValidator
|
||||
|
||||
|
||||
class PropertyValidatorTest(TestCase):
|
||||
def testPassesUnvalidated(self):
|
||||
pm = PropertyLayer()
|
||||
pv = PropertyValidator(pm)
|
||||
pv["testkey"] = "testvalue"
|
||||
self.assertEqual(pv["testkey"], "testvalue")
|
||||
self.assertEqual(pm["testkey"], "testvalue")
|
||||
|
||||
def testPassesValidValue(self):
|
||||
pv = PropertyValidator(PropertyLayer(), {"testkey": NumberValidator()})
|
||||
pv["testkey"] = 42
|
||||
self.assertEqual(pv["testkey"], 42)
|
||||
|
||||
def testThrowsErrorOnInvalidValue(self):
|
||||
pv = PropertyValidator(PropertyLayer(), {"testkey": NumberValidator()})
|
||||
with self.assertRaises(PropertyValidationError):
|
||||
pv["testkey"] = "text"
|
||||
|
||||
def testSetValidator(self):
|
||||
pv = PropertyValidator(PropertyLayer())
|
||||
pv.setValidator("testkey", NumberValidator())
|
||||
with self.assertRaises(PropertyValidationError):
|
||||
pv["testkey"] = "text"
|
||||
|
||||
def testUpdateValidator(self):
|
||||
pv = PropertyValidator(PropertyLayer(), {"testkey": StringValidator()})
|
||||
# this should pass
|
||||
pv["testkey"] = "text"
|
||||
pv.setValidator("testkey", NumberValidator())
|
||||
# this should raise
|
||||
with self.assertRaises(PropertyValidationError):
|
||||
pv["testkey"] = "text"
|
0
test/property/validators/__init__.py
Normal file
0
test/property/validators/__init__.py
Normal file
17
test/property/validators/test_bool_validator.py
Normal file
17
test/property/validators/test_bool_validator.py
Normal file
@ -0,0 +1,17 @@
|
||||
from unittest import TestCase
|
||||
from owrx.property.validators import BoolValidator
|
||||
|
||||
|
||||
class NumberValidatorTest(TestCase):
|
||||
def testPassesNumbers(self):
|
||||
validator = BoolValidator()
|
||||
self.assertTrue(validator.isValid(True))
|
||||
self.assertTrue(validator.isValid(False))
|
||||
|
||||
def testDoesntPassOthers(self):
|
||||
validator = BoolValidator()
|
||||
self.assertFalse(validator.isValid(123))
|
||||
self.assertFalse(validator.isValid(-2))
|
||||
self.assertFalse(validator.isValid(.5))
|
||||
self.assertFalse(validator.isValid("text"))
|
||||
self.assertFalse(validator.isValid(object()))
|
15
test/property/validators/test_float_validator.py
Normal file
15
test/property/validators/test_float_validator.py
Normal file
@ -0,0 +1,15 @@
|
||||
from unittest import TestCase
|
||||
from owrx.property.validators import FloatValidator
|
||||
|
||||
|
||||
class FloatValidatorTest(TestCase):
|
||||
def testPassesNumbers(self):
|
||||
validator = FloatValidator()
|
||||
self.assertTrue(validator.isValid(.5))
|
||||
|
||||
def testDoesntPassOthers(self):
|
||||
validator = FloatValidator()
|
||||
self.assertFalse(validator.isValid(123))
|
||||
self.assertFalse(validator.isValid(-2))
|
||||
self.assertFalse(validator.isValid("text"))
|
||||
self.assertFalse(validator.isValid(object()))
|
15
test/property/validators/test_integer_validator.py
Normal file
15
test/property/validators/test_integer_validator.py
Normal file
@ -0,0 +1,15 @@
|
||||
from unittest import TestCase
|
||||
from owrx.property.validators import IntegerValidator
|
||||
|
||||
|
||||
class IntegerValidatorTest(TestCase):
|
||||
def testPassesIntegers(self):
|
||||
validator = IntegerValidator()
|
||||
self.assertTrue(validator.isValid(123))
|
||||
self.assertTrue(validator.isValid(-2))
|
||||
|
||||
def testDoesntPassOthers(self):
|
||||
validator = IntegerValidator()
|
||||
self.assertFalse(validator.isValid(.5))
|
||||
self.assertFalse(validator.isValid("text"))
|
||||
self.assertFalse(validator.isValid(object()))
|
21
test/property/validators/test_lambda_validator.py
Normal file
21
test/property/validators/test_lambda_validator.py
Normal file
@ -0,0 +1,21 @@
|
||||
from unittest import TestCase
|
||||
from unittest.mock import Mock
|
||||
from owrx.property.validators import LambdaValidator
|
||||
|
||||
|
||||
class LambdaValidatorTest(TestCase):
|
||||
def testPassesValue(self):
|
||||
mock = Mock()
|
||||
validator = LambdaValidator(mock.method)
|
||||
validator.isValid("test")
|
||||
mock.method.assert_called_once_with("test")
|
||||
|
||||
def testReturnsTrue(self):
|
||||
validator = LambdaValidator(lambda x: True)
|
||||
self.assertTrue(validator.isValid("any value"))
|
||||
self.assertTrue(validator.isValid(3.1415926))
|
||||
|
||||
def testReturnsFalse(self):
|
||||
validator = LambdaValidator(lambda x: False)
|
||||
self.assertFalse(validator.isValid("any value"))
|
||||
self.assertFalse(validator.isValid(42))
|
18
test/property/validators/test_number_validator.py
Normal file
18
test/property/validators/test_number_validator.py
Normal file
@ -0,0 +1,18 @@
|
||||
from unittest import TestCase
|
||||
from owrx.property.validators import NumberValidator
|
||||
|
||||
|
||||
class NumberValidatorTest(TestCase):
|
||||
def testPassesNumbers(self):
|
||||
validator = NumberValidator()
|
||||
self.assertTrue(validator.isValid(123))
|
||||
self.assertTrue(validator.isValid(-2))
|
||||
self.assertTrue(validator.isValid(.5))
|
||||
|
||||
def testDoesntPassOthers(self):
|
||||
validator = NumberValidator()
|
||||
# bool is a subclass of int, so it passes this test.
|
||||
# not sure if we need to be more specific or if this is alright.
|
||||
# self.assertFalse(validator.isValid(True))
|
||||
self.assertFalse(validator.isValid("text"))
|
||||
self.assertFalse(validator.isValid(object()))
|
17
test/property/validators/test_or_validator.py
Normal file
17
test/property/validators/test_or_validator.py
Normal file
@ -0,0 +1,17 @@
|
||||
from unittest import TestCase
|
||||
from owrx.property.validators import OrValidator, IntegerValidator, StringValidator
|
||||
|
||||
|
||||
class OrValidatorTest(TestCase):
|
||||
def testPassesAnyValidators(self):
|
||||
validator = OrValidator(IntegerValidator(), StringValidator())
|
||||
self.assertTrue(validator.isValid(42))
|
||||
self.assertTrue(validator.isValid("text"))
|
||||
|
||||
def testRejectsOtherTypes(self):
|
||||
validator = OrValidator(IntegerValidator(), StringValidator())
|
||||
self.assertFalse(validator.isValid(.5))
|
||||
|
||||
def testRejectsIfNoValidator(self):
|
||||
validator = OrValidator()
|
||||
self.assertFalse(validator.isValid("any value"))
|
17
test/property/validators/test_regex_validator.py
Normal file
17
test/property/validators/test_regex_validator.py
Normal file
@ -0,0 +1,17 @@
|
||||
from unittest import TestCase
|
||||
from owrx.property.validators import RegexValidator
|
||||
import re
|
||||
|
||||
|
||||
class RegexValidatorTest(TestCase):
|
||||
def testMatchesRegex(self):
|
||||
validator = RegexValidator(re.compile("abc"))
|
||||
self.assertTrue(validator.isValid("abc"))
|
||||
|
||||
def testDoesntMatchRegex(self):
|
||||
validator = RegexValidator(re.compile("abc"))
|
||||
self.assertFalse(validator.isValid("xyz"))
|
||||
|
||||
def testFailsIfValueIsNoString(self):
|
||||
validator = RegexValidator(re.compile("abc"))
|
||||
self.assertFalse(validator.isValid(42))
|
14
test/property/validators/test_string_validator.py
Normal file
14
test/property/validators/test_string_validator.py
Normal file
@ -0,0 +1,14 @@
|
||||
from unittest import TestCase
|
||||
from owrx.property.validators import StringValidator
|
||||
|
||||
class StringValidatorTest(TestCase):
|
||||
def testPassesStrings(self):
|
||||
validator = StringValidator()
|
||||
self.assertTrue(validator.isValid("text"))
|
||||
|
||||
def testDoesntPassOthers(self):
|
||||
validator = StringValidator()
|
||||
self.assertFalse(validator.isValid(123))
|
||||
self.assertFalse(validator.isValid(-2))
|
||||
self.assertFalse(validator.isValid(.5))
|
||||
self.assertFalse(validator.isValid(object()))
|
20
test/property/validators/test_validator.py
Normal file
20
test/property/validators/test_validator.py
Normal file
@ -0,0 +1,20 @@
|
||||
from unittest import TestCase
|
||||
from owrx.property.validators import Validator, NumberValidator, LambdaValidator, StringValidator
|
||||
|
||||
|
||||
class ValidatorTest(TestCase):
|
||||
|
||||
def testReturnsValidator(self):
|
||||
validator = NumberValidator()
|
||||
self.assertIs(validator, Validator.of(validator))
|
||||
|
||||
def testTransformsLambda(self):
|
||||
def my_callable(v):
|
||||
return True
|
||||
validator = Validator.of(my_callable)
|
||||
self.assertIsInstance(validator, LambdaValidator)
|
||||
self.assertTrue(validator.isValid("test"))
|
||||
|
||||
def testGetsValidatorByKey(self):
|
||||
validator = Validator.of("str")
|
||||
self.assertIsInstance(validator, StringValidator)
|
Reference in New Issue
Block a user