test_Counter.py 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. # -*- coding: utf-8 -*-
  2. #
  3. # SelfTest/Util/test_Counter: Self-test for the Crypto.Util.Counter module
  4. #
  5. # Written in 2009 by Dwayne C. Litzenberger <dlitz@dlitz.net>
  6. #
  7. # ===================================================================
  8. # The contents of this file are dedicated to the public domain. To
  9. # the extent that dedication to the public domain is not available,
  10. # everyone is granted a worldwide, perpetual, royalty-free,
  11. # non-exclusive license to exercise all rights associated with the
  12. # contents of this file for any purpose whatsoever.
  13. # No rights are reserved.
  14. #
  15. # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  16. # EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  17. # MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  18. # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
  19. # BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
  20. # ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  21. # CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  22. # SOFTWARE.
  23. # ===================================================================
  24. """Self-tests for Crypto.Util.Counter"""
  25. __revision__ = "$Id$"
  26. import sys
  27. if sys.version_info[0] == 2 and sys.version_info[1] == 1:
  28. from Crypto.Util.py21compat import *
  29. from Crypto.Util.py3compat import *
  30. import unittest
  31. class CounterTests(unittest.TestCase):
  32. def setUp(self):
  33. global Counter
  34. from Crypto.Util import Counter
  35. def test_BE_shortcut(self):
  36. """Big endian, shortcut enabled"""
  37. c = Counter.new(128)
  38. self.assertEqual(c.__PCT_CTR_SHORTCUT__,True) # assert_
  39. c = Counter.new(128, little_endian=False)
  40. self.assertEqual(c.__PCT_CTR_SHORTCUT__,True) # assert_
  41. c = Counter.new(128, disable_shortcut=False)
  42. self.assertEqual(c.__PCT_CTR_SHORTCUT__,True) # assert_
  43. c = Counter.new(128, little_endian=False, disable_shortcut=False)
  44. self.assertEqual(c.__PCT_CTR_SHORTCUT__,True) # assert_
  45. def test_LE_shortcut(self):
  46. """Little endian, shortcut enabled"""
  47. c = Counter.new(128, little_endian=True)
  48. self.assertEqual(c.__PCT_CTR_SHORTCUT__,True) # assert_
  49. c = Counter.new(128, little_endian=True, disable_shortcut=False)
  50. self.assertEqual(c.__PCT_CTR_SHORTCUT__,True) # assert_
  51. def test_BE_no_shortcut(self):
  52. """Big endian, shortcut disabled"""
  53. c = Counter.new(128, disable_shortcut=True)
  54. self.assertRaises(AttributeError, getattr, c, '__PCT_CTR_SHORTCUT__')
  55. c = Counter.new(128, little_endian=False, disable_shortcut=True)
  56. self.assertRaises(AttributeError, getattr, c, '__PCT_CTR_SHORTCUT__')
  57. def test_LE_no_shortcut(self):
  58. """Little endian, shortcut disabled"""
  59. c = Counter.new(128, little_endian=True, disable_shortcut=True)
  60. self.assertRaises(AttributeError, getattr, c, '__PCT_CTR_SHORTCUT__')
  61. def test_BE_defaults(self):
  62. """128-bit, Big endian, defaults"""
  63. c = Counter.new(128)
  64. self.assertEqual(1, c.next_value())
  65. self.assertEqual(b("\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x01"), c())
  66. self.assertEqual(2, c.next_value())
  67. self.assertEqual(b("\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x02"), c())
  68. for i in xrange(3, 256):
  69. self.assertEqual(i, c.next_value())
  70. self.assertEqual(b("\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00")+bchr(i), c())
  71. self.assertEqual(256, c.next_value())
  72. self.assertEqual(b("\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x01\x00"), c())
  73. def test_LE_defaults(self):
  74. """128-bit, Little endian, defaults"""
  75. c = Counter.new(128, little_endian=True)
  76. self.assertEqual(1, c.next_value())
  77. self.assertEqual(b("\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00"), c())
  78. self.assertEqual(2, c.next_value())
  79. self.assertEqual(b("\x02\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00"), c())
  80. for i in xrange(3, 256):
  81. self.assertEqual(i, c.next_value())
  82. self.assertEqual(bchr(i)+b("\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00"), c())
  83. self.assertEqual(256, c.next_value())
  84. self.assertEqual(b("\x00\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00"), c())
  85. def test_BE8_wraparound(self):
  86. """8-bit, Big endian, wraparound"""
  87. c = Counter.new(8)
  88. for i in xrange(1, 256):
  89. self.assertEqual(i, c.next_value())
  90. self.assertEqual(bchr(i), c())
  91. self.assertRaises(OverflowError, c.next_value)
  92. self.assertRaises(OverflowError, c)
  93. self.assertRaises(OverflowError, c.next_value)
  94. self.assertRaises(OverflowError, c)
  95. def test_LE8_wraparound(self):
  96. """8-bit, Little endian, wraparound"""
  97. c = Counter.new(8, little_endian=True)
  98. for i in xrange(1, 256):
  99. self.assertEqual(i, c.next_value())
  100. self.assertEqual(bchr(i), c())
  101. self.assertRaises(OverflowError, c.next_value)
  102. self.assertRaises(OverflowError, c)
  103. self.assertRaises(OverflowError, c.next_value)
  104. self.assertRaises(OverflowError, c)
  105. def test_BE8_wraparound_allowed(self):
  106. """8-bit, Big endian, wraparound with allow_wraparound=True"""
  107. c = Counter.new(8, allow_wraparound=True)
  108. for i in xrange(1, 256):
  109. self.assertEqual(i, c.next_value())
  110. self.assertEqual(bchr(i), c())
  111. self.assertEqual(0, c.next_value())
  112. self.assertEqual(b("\x00"), c())
  113. self.assertEqual(1, c.next_value())
  114. def test_LE8_wraparound_allowed(self):
  115. """8-bit, Little endian, wraparound with allow_wraparound=True"""
  116. c = Counter.new(8, little_endian=True, allow_wraparound=True)
  117. for i in xrange(1, 256):
  118. self.assertEqual(i, c.next_value())
  119. self.assertEqual(bchr(i), c())
  120. self.assertEqual(0, c.next_value())
  121. self.assertEqual(b("\x00"), c())
  122. self.assertEqual(1, c.next_value())
  123. def test_BE8_carry(self):
  124. """8-bit, Big endian, carry attribute"""
  125. c = Counter.new(8)
  126. for i in xrange(1, 256):
  127. self.assertEqual(0, c.carry)
  128. self.assertEqual(i, c.next_value())
  129. self.assertEqual(bchr(i), c())
  130. self.assertEqual(1, c.carry)
  131. def test_LE8_carry(self):
  132. """8-bit, Little endian, carry attribute"""
  133. c = Counter.new(8, little_endian=True)
  134. for i in xrange(1, 256):
  135. self.assertEqual(0, c.carry)
  136. self.assertEqual(i, c.next_value())
  137. self.assertEqual(bchr(i), c())
  138. self.assertEqual(1, c.carry)
  139. def get_tests(config={}):
  140. from Crypto.SelfTest.st_common import list_test_cases
  141. return list_test_cases(CounterTests)
  142. if __name__ == '__main__':
  143. suite = lambda: unittest.TestSuite(get_tests())
  144. unittest.main(defaultTest='suite')
  145. # vim:set ts=4 sw=4 sts=4 expandtab: