PageRenderTime 50ms CodeModel.GetById 22ms RepoModel.GetById 0ms app.codeStats 0ms

/lib/Crypto/SelfTest/Util/test_Counter.py

https://gitlab.com/grayhamster/pycrypto
Python | 155 lines | 131 code | 1 blank | 23 comment | 0 complexity | 5d69400ad45a3bc840a1a8b04ded1baa MD5 | raw file
  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"""
  37. c = Counter.new(128)
  38. c = Counter.new(128, little_endian=False)
  39. def test_LE_shortcut(self):
  40. """Little endian"""
  41. c = Counter.new(128, little_endian=True)
  42. def test_BE_no_shortcut(self):
  43. """Big endian, with disable_shortcut"""
  44. # Just testing API backward-compatibility. disable_shortcut is now a no-op.
  45. c = Counter.new(128, disable_shortcut=True)
  46. c = Counter.new(128, little_endian=False, disable_shortcut=True)
  47. def test_LE_no_shortcut(self):
  48. """Little endian, shortcut disabled"""
  49. # Just testing API backward-compatibility. disable_shortcut is now a no-op.
  50. c = Counter.new(128, little_endian=True, disable_shortcut=True)
  51. def test_BE_defaults(self):
  52. """128-bit, Big endian, defaults"""
  53. c = Counter.new(128)
  54. self.assertEqual(1, c.next_value())
  55. self.assertEqual(b("\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x01"), c())
  56. self.assertEqual(2, c.next_value())
  57. self.assertEqual(b("\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x02"), c())
  58. for i in xrange(3, 256):
  59. self.assertEqual(i, c.next_value())
  60. self.assertEqual(b("\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00")+bchr(i), c())
  61. self.assertEqual(256, c.next_value())
  62. self.assertEqual(b("\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x01\x00"), c())
  63. def test_LE_defaults(self):
  64. """128-bit, Little endian, defaults"""
  65. c = Counter.new(128, little_endian=True)
  66. self.assertEqual(1, c.next_value())
  67. self.assertEqual(b("\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00"), c())
  68. self.assertEqual(2, c.next_value())
  69. self.assertEqual(b("\x02\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00"), c())
  70. for i in xrange(3, 256):
  71. self.assertEqual(i, c.next_value())
  72. self.assertEqual(bchr(i)+b("\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00"), c())
  73. self.assertEqual(256, c.next_value())
  74. self.assertEqual(b("\x00\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00"), c())
  75. def test_BE8_wraparound(self):
  76. """8-bit, Big endian, wraparound"""
  77. c = Counter.new(8)
  78. for i in xrange(1, 256):
  79. self.assertEqual(i, c.next_value())
  80. self.assertEqual(bchr(i), c())
  81. self.assertRaises(OverflowError, c.next_value)
  82. self.assertRaises(OverflowError, c)
  83. self.assertRaises(OverflowError, c.next_value)
  84. self.assertRaises(OverflowError, c)
  85. def test_LE8_wraparound(self):
  86. """8-bit, Little endian, wraparound"""
  87. c = Counter.new(8, little_endian=True)
  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_BE8_wraparound_allowed(self):
  96. """8-bit, Big endian, wraparound with allow_wraparound=True"""
  97. c = Counter.new(8, allow_wraparound=True)
  98. for i in xrange(1, 256):
  99. self.assertEqual(i, c.next_value())
  100. self.assertEqual(bchr(i), c())
  101. self.assertEqual(0, c.next_value())
  102. self.assertEqual(b("\x00"), c())
  103. self.assertEqual(1, c.next_value())
  104. def test_LE8_wraparound_allowed(self):
  105. """8-bit, Little endian, wraparound with allow_wraparound=True"""
  106. c = Counter.new(8, little_endian=True, allow_wraparound=True)
  107. for i in xrange(1, 256):
  108. self.assertEqual(i, c.next_value())
  109. self.assertEqual(bchr(i), c())
  110. self.assertEqual(0, c.next_value())
  111. self.assertEqual(b("\x00"), c())
  112. self.assertEqual(1, c.next_value())
  113. def test_BE8_carry(self):
  114. """8-bit, Big endian, carry attribute"""
  115. c = Counter.new(8)
  116. for i in xrange(1, 256):
  117. self.assertEqual(0, c.carry)
  118. self.assertEqual(i, c.next_value())
  119. self.assertEqual(bchr(i), c())
  120. self.assertEqual(1, c.carry)
  121. def test_LE8_carry(self):
  122. """8-bit, Little endian, carry attribute"""
  123. c = Counter.new(8, little_endian=True)
  124. for i in xrange(1, 256):
  125. self.assertEqual(0, c.carry)
  126. self.assertEqual(i, c.next_value())
  127. self.assertEqual(bchr(i), c())
  128. self.assertEqual(1, c.carry)
  129. def get_tests(config={}):
  130. from Crypto.SelfTest.st_common import list_test_cases
  131. return list_test_cases(CounterTests)
  132. if __name__ == '__main__':
  133. suite = lambda: unittest.TestSuite(get_tests())
  134. unittest.main(defaultTest='suite')
  135. # vim:set ts=4 sw=4 sts=4 expandtab: