Source code for dhcpkit.tests.ipv6.options.test_option

"""
Test the basic option implementation
"""
import unittest

from dhcpkit.ipv6.options import Option, UnknownOption


[docs]class OptionTestCase(unittest.TestCase):
[docs] def setUp(self): # The following attributes must be overruled by child classes # The basics are tested with a simple UnknownOption self.option_bytes = bytes.fromhex('ffff0010') + b'0123456789abcdef' self.option_object = UnknownOption(65535, b'0123456789abcdef') self.parse_option()
[docs] def parse_option(self): self.length, self.option = Option.parse(self.option_bytes) self.assertIsInstance(self.option, Option) self.option_class = type(self.option)
[docs] def test_length(self): self.assertEqual(self.length, len(self.option_bytes))
[docs] def test_parse(self): self.assertEqual(self.option, self.option_object)
[docs] def test_save_parsed(self): self.assertEqual(self.option_bytes, self.option.save())
[docs] def test_save_fixture(self): self.assertEqual(self.option_bytes, self.option_object.save())
[docs] def test_validate(self): # This should be ok self.option.validate()
[docs] def test_overflow(self): with self.assertRaisesRegex(ValueError, 'longer than .* buffer'): self.option_class.parse(self.option_bytes, length=len(self.option_bytes) - 1)
[docs] def test_load_from_wrong_buffer(self): if issubclass(self.option_class, UnknownOption): # UnknownOption accepts any parseable buffer, no point in testing that one return option = self.option_class() with self.assertRaisesRegex(ValueError, 'buffer does not contain'): option.load_from(bytes.fromhex('fffe0000'))
[docs] def check_unsigned_integer_property(self, property_name: str, size: int = None): """ Perform basic verification of validation of an unsigned integer :param property_name: The property under test :param size: The number of bits of this integer field """ # Do the basic integer checks setattr(self.option, property_name, 0.1) with self.assertRaisesRegex(ValueError, 'integer'): self.option.validate() setattr(self.option, property_name, 0) self.option.validate() setattr(self.option, property_name, -1) with self.assertRaisesRegex(ValueError, 'unsigned {} bit integer'.format(size)): self.option.validate() if not size: # We can't do any further tests without knowing the size return setattr(self.option, property_name, 2 ** size - 1) self.option.validate() setattr(self.option, property_name, 2 ** size) with self.assertRaisesRegex(ValueError, 'unsigned {} bit integer'.format(size)): self.option.validate()
[docs] def check_integer_property_range(self, property_name: str, min_value: int = None, max_value: int = None): """ Perform basic verification of validation of an integer range :param property_name: The property under test :param min_value: The minimum value allowed :param max_value: The maximum value allowed """ # Do the basic integer checks setattr(self.option, property_name, 0.1) with self.assertRaisesRegex(ValueError, 'integer'): self.option.validate() if min_value is not None: setattr(self.option, property_name, min_value) self.option.validate() setattr(self.option, property_name, min_value - 1) with self.assertRaisesRegex(ValueError, 'between {} and {}'.format(min_value, max_value)): self.option.validate() if max_value is not None: setattr(self.option, property_name, max_value) self.option.validate() setattr(self.option, property_name, max_value + 1) with self.assertRaisesRegex(ValueError, 'between {} and {}'.format(min_value, max_value)): self.option.validate()
if __name__ == '__main__': # pragma: no cover unittest.main()