mirror of
https://github.com/Legrandin/pycryptodome.git
synced 2025-12-08 05:19:46 +00:00
SelfTest: Add SelfTest.Random and SelfTest.Random.OSRNG
This commit is contained in:
parent
a514238020
commit
2467f60dca
11 changed files with 470 additions and 0 deletions
53
SelfTest/Random/OSRNG/__init__.py
Normal file
53
SelfTest/Random/OSRNG/__init__.py
Normal file
|
|
@ -0,0 +1,53 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
#
|
||||||
|
# SelfTest/Random/OSRNG/__init__.py: Self-test for OSRNG modules
|
||||||
|
#
|
||||||
|
# =======================================================================
|
||||||
|
# Copyright (C) 2008 Dwayne C. Litzenberger <dlitz@dlitz.net>
|
||||||
|
#
|
||||||
|
# Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
# a copy of this software and associated documentation files (the
|
||||||
|
# "Software"), to deal in the Software without restriction, including
|
||||||
|
# without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
# distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
# permit persons to whom the Software is furnished to do so.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
# =======================================================================
|
||||||
|
#
|
||||||
|
|
||||||
|
"""Self-test for Crypto.Random.OSRNG package"""
|
||||||
|
|
||||||
|
__revision__ = "$Id$"
|
||||||
|
|
||||||
|
import os
|
||||||
|
|
||||||
|
def get_tests():
|
||||||
|
tests = []
|
||||||
|
if os.name == 'nt':
|
||||||
|
import test_nt; tests += test_nt.get_tests()
|
||||||
|
import test_winrandom; tests += test_winrandom.get_tests()
|
||||||
|
elif os.name == 'posix':
|
||||||
|
import test_posix; tests += test_posix.get_tests()
|
||||||
|
if hasattr(os, 'urandom'):
|
||||||
|
import test_fallback; tests += test_fallback.get_tests()
|
||||||
|
import test_generic; tests += test_generic.get_tests()
|
||||||
|
return tests
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
import unittest
|
||||||
|
suite = lambda: unittest.TestSuite(get_tests())
|
||||||
|
unittest.main(defaultTest='suite')
|
||||||
|
|
||||||
|
|
||||||
|
# vim:set ts=4 sw=4 sts=4 expandtab:
|
||||||
52
SelfTest/Random/OSRNG/test_fallback.py
Normal file
52
SelfTest/Random/OSRNG/test_fallback.py
Normal file
|
|
@ -0,0 +1,52 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
#
|
||||||
|
# SelfTest/Util/test_fallback.py: Self-test for the OSRNG.fallback.new() function
|
||||||
|
#
|
||||||
|
# =======================================================================
|
||||||
|
# Copyright (C) 2008 Dwayne C. Litzenberger <dlitz@dlitz.net>
|
||||||
|
#
|
||||||
|
# Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
# a copy of this software and associated documentation files (the
|
||||||
|
# "Software"), to deal in the Software without restriction, including
|
||||||
|
# without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
# distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
# permit persons to whom the Software is furnished to do so.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
# =======================================================================
|
||||||
|
#
|
||||||
|
|
||||||
|
"""Self-test suite for Crypto.Random.OSRNG.fallback"""
|
||||||
|
|
||||||
|
__revision__ = "$Id$"
|
||||||
|
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
class SimpleTest(unittest.TestCase):
|
||||||
|
def runTest(self):
|
||||||
|
"""Crypto.Random.OSRNG.fallback.new()"""
|
||||||
|
# Import the OSRNG.nt module and try to use it
|
||||||
|
import Crypto.Random.OSRNG.fallback
|
||||||
|
randobj = Crypto.Random.OSRNG.fallback.new()
|
||||||
|
x = randobj.read(16)
|
||||||
|
y = randobj.read(16)
|
||||||
|
self.assertNotEqual(x, y)
|
||||||
|
|
||||||
|
def get_tests():
|
||||||
|
return [SimpleTest()]
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
suite = lambda: unittest.TestSuite(get_tests())
|
||||||
|
unittest.main(defaultTest='suite')
|
||||||
|
|
||||||
|
# vim:set ts=4 sw=4 sts=4 expandtab:
|
||||||
52
SelfTest/Random/OSRNG/test_generic.py
Normal file
52
SelfTest/Random/OSRNG/test_generic.py
Normal file
|
|
@ -0,0 +1,52 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
#
|
||||||
|
# SelfTest/Util/test_generic.py: Self-test for the OSRNG.new() function
|
||||||
|
#
|
||||||
|
# =======================================================================
|
||||||
|
# Copyright (C) 2008 Dwayne C. Litzenberger <dlitz@dlitz.net>
|
||||||
|
#
|
||||||
|
# Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
# a copy of this software and associated documentation files (the
|
||||||
|
# "Software"), to deal in the Software without restriction, including
|
||||||
|
# without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
# distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
# permit persons to whom the Software is furnished to do so.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
# =======================================================================
|
||||||
|
#
|
||||||
|
|
||||||
|
"""Self-test suite for Crypto.Random.OSRNG"""
|
||||||
|
|
||||||
|
__revision__ = "$Id$"
|
||||||
|
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
class SimpleTest(unittest.TestCase):
|
||||||
|
def runTest(self):
|
||||||
|
"""Crypto.Random.OSRNG.new()"""
|
||||||
|
# Import the OSRNG module and try to use it
|
||||||
|
import Crypto.Random.OSRNG
|
||||||
|
randobj = Crypto.Random.OSRNG.new()
|
||||||
|
x = randobj.read(16)
|
||||||
|
y = randobj.read(16)
|
||||||
|
self.assertNotEqual(x, y)
|
||||||
|
|
||||||
|
def get_tests():
|
||||||
|
return [SimpleTest()]
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
suite = lambda: unittest.TestSuite(get_tests())
|
||||||
|
unittest.main(defaultTest='suite')
|
||||||
|
|
||||||
|
# vim:set ts=4 sw=4 sts=4 expandtab:
|
||||||
52
SelfTest/Random/OSRNG/test_nt.py
Normal file
52
SelfTest/Random/OSRNG/test_nt.py
Normal file
|
|
@ -0,0 +1,52 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
#
|
||||||
|
# SelfTest/Util/test_generic.py: Self-test for the OSRNG.nt.new() function
|
||||||
|
#
|
||||||
|
# =======================================================================
|
||||||
|
# Copyright (C) 2008 Dwayne C. Litzenberger <dlitz@dlitz.net>
|
||||||
|
#
|
||||||
|
# Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
# a copy of this software and associated documentation files (the
|
||||||
|
# "Software"), to deal in the Software without restriction, including
|
||||||
|
# without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
# distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
# permit persons to whom the Software is furnished to do so.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
# =======================================================================
|
||||||
|
#
|
||||||
|
|
||||||
|
"""Self-test suite for Crypto.Random.OSRNG.nt"""
|
||||||
|
|
||||||
|
__revision__ = "$Id$"
|
||||||
|
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
class SimpleTest(unittest.TestCase):
|
||||||
|
def runTest(self):
|
||||||
|
"""Crypto.Random.OSRNG.nt.new()"""
|
||||||
|
# Import the OSRNG.nt module and try to use it
|
||||||
|
import Crypto.Random.OSRNG.nt
|
||||||
|
randobj = Crypto.Random.OSRNG.nt.new()
|
||||||
|
x = randobj.read(16)
|
||||||
|
y = randobj.read(16)
|
||||||
|
self.assertNotEqual(x, y)
|
||||||
|
|
||||||
|
def get_tests():
|
||||||
|
return [SimpleTest()]
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
suite = lambda: unittest.TestSuite(get_tests())
|
||||||
|
unittest.main(defaultTest='suite')
|
||||||
|
|
||||||
|
# vim:set ts=4 sw=4 sts=4 expandtab:
|
||||||
52
SelfTest/Random/OSRNG/test_posix.py
Normal file
52
SelfTest/Random/OSRNG/test_posix.py
Normal file
|
|
@ -0,0 +1,52 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
#
|
||||||
|
# SelfTest/Util/test_posix.py: Self-test for the OSRNG.posix.new() function
|
||||||
|
#
|
||||||
|
# =======================================================================
|
||||||
|
# Copyright (C) 2008 Dwayne C. Litzenberger <dlitz@dlitz.net>
|
||||||
|
#
|
||||||
|
# Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
# a copy of this software and associated documentation files (the
|
||||||
|
# "Software"), to deal in the Software without restriction, including
|
||||||
|
# without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
# distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
# permit persons to whom the Software is furnished to do so.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
# =======================================================================
|
||||||
|
#
|
||||||
|
|
||||||
|
"""Self-test suite for Crypto.Random.OSRNG.posix"""
|
||||||
|
|
||||||
|
__revision__ = "$Id$"
|
||||||
|
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
class SimpleTest(unittest.TestCase):
|
||||||
|
def runTest(self):
|
||||||
|
"""Crypto.Random.OSRNG.posix.new()"""
|
||||||
|
# Import the OSRNG.nt module and try to use it
|
||||||
|
import Crypto.Random.OSRNG.posix
|
||||||
|
randobj = Crypto.Random.OSRNG.posix.new()
|
||||||
|
x = randobj.read(16)
|
||||||
|
y = randobj.read(16)
|
||||||
|
self.assertNotEqual(x, y)
|
||||||
|
|
||||||
|
def get_tests():
|
||||||
|
return [SimpleTest()]
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
suite = lambda: unittest.TestSuite(get_tests())
|
||||||
|
unittest.main(defaultTest='suite')
|
||||||
|
|
||||||
|
# vim:set ts=4 sw=4 sts=4 expandtab:
|
||||||
52
SelfTest/Random/OSRNG/test_winrandom.py
Normal file
52
SelfTest/Random/OSRNG/test_winrandom.py
Normal file
|
|
@ -0,0 +1,52 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
#
|
||||||
|
# SelfTest/Util/test_winrandom.py: Self-test for the winrandom module
|
||||||
|
#
|
||||||
|
# =======================================================================
|
||||||
|
# Copyright (C) 2008 Dwayne C. Litzenberger <dlitz@dlitz.net>
|
||||||
|
#
|
||||||
|
# Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
# a copy of this software and associated documentation files (the
|
||||||
|
# "Software"), to deal in the Software without restriction, including
|
||||||
|
# without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
# distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
# permit persons to whom the Software is furnished to do so.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
# =======================================================================
|
||||||
|
#
|
||||||
|
|
||||||
|
"""Self-test suite for Crypto.Random.OSRNG.winrandom"""
|
||||||
|
|
||||||
|
__revision__ = "$Id$"
|
||||||
|
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
class SimpleTest(unittest.TestCase):
|
||||||
|
def runTest(self):
|
||||||
|
"""Crypto.Random.OSRNG.winrandom"""
|
||||||
|
# Import the winrandom module and try to use it
|
||||||
|
from Crypto.Random.OSRNG import winrandom
|
||||||
|
randobj = winrandom.new()
|
||||||
|
x = randobj.get_bytes(16)
|
||||||
|
y = randobj.get_bytes(16)
|
||||||
|
self.assertNotEqual(x, y)
|
||||||
|
|
||||||
|
def get_tests():
|
||||||
|
return [SimpleTest()]
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
suite = lambda: unittest.TestSuite(get_tests())
|
||||||
|
unittest.main(defaultTest='suite')
|
||||||
|
|
||||||
|
# vim:set ts=4 sw=4 sts=4 expandtab:
|
||||||
45
SelfTest/Random/__init__.py
Normal file
45
SelfTest/Random/__init__.py
Normal file
|
|
@ -0,0 +1,45 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
#
|
||||||
|
# SelfTest/Random/__init__.py: Self-test for random number generation modules
|
||||||
|
#
|
||||||
|
# =======================================================================
|
||||||
|
# Copyright (C) 2008 Dwayne C. Litzenberger <dlitz@dlitz.net>
|
||||||
|
#
|
||||||
|
# Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
# a copy of this software and associated documentation files (the
|
||||||
|
# "Software"), to deal in the Software without restriction, including
|
||||||
|
# without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
# distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
# permit persons to whom the Software is furnished to do so.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
# =======================================================================
|
||||||
|
#
|
||||||
|
|
||||||
|
"""Self-test for random number generators"""
|
||||||
|
|
||||||
|
__revision__ = "$Id$"
|
||||||
|
|
||||||
|
def get_tests():
|
||||||
|
tests = []
|
||||||
|
import OSRNG; tests += OSRNG.get_tests()
|
||||||
|
import test_random; tests += test_random.get_tests()
|
||||||
|
import test_rpoolcompat; tests += test_rpoolcompat.get_tests()
|
||||||
|
return tests
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
import unittest
|
||||||
|
suite = lambda: unittest.TestSuite(get_tests())
|
||||||
|
unittest.main(defaultTest='suite')
|
||||||
|
|
||||||
|
# vim:set ts=4 sw=4 sts=4 expandtab:
|
||||||
52
SelfTest/Random/test_random.py
Normal file
52
SelfTest/Random/test_random.py
Normal file
|
|
@ -0,0 +1,52 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
#
|
||||||
|
# SelfTest/Util/test_generic.py: Self-test for the Crypto.Random.new() function
|
||||||
|
#
|
||||||
|
# =======================================================================
|
||||||
|
# Copyright (C) 2008 Dwayne C. Litzenberger <dlitz@dlitz.net>
|
||||||
|
#
|
||||||
|
# Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
# a copy of this software and associated documentation files (the
|
||||||
|
# "Software"), to deal in the Software without restriction, including
|
||||||
|
# without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
# distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
# permit persons to whom the Software is furnished to do so.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
# =======================================================================
|
||||||
|
#
|
||||||
|
|
||||||
|
"""Self-test suite for Crypto.Random.new()"""
|
||||||
|
|
||||||
|
__revision__ = "$Id$"
|
||||||
|
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
class SimpleTest(unittest.TestCase):
|
||||||
|
def runTest(self):
|
||||||
|
"""Crypto.Random.new()"""
|
||||||
|
# Import the OSRNG module and try to use it
|
||||||
|
from Crypto import Random
|
||||||
|
randobj = Random.new()
|
||||||
|
x = randobj.read(16)
|
||||||
|
y = randobj.read(16)
|
||||||
|
self.assertNotEqual(x, y)
|
||||||
|
|
||||||
|
def get_tests():
|
||||||
|
return [SimpleTest()]
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
suite = lambda: unittest.TestSuite(get_tests())
|
||||||
|
unittest.main(defaultTest='suite')
|
||||||
|
|
||||||
|
# vim:set ts=4 sw=4 sts=4 expandtab:
|
||||||
57
SelfTest/Random/test_rpoolcompat.py
Normal file
57
SelfTest/Random/test_rpoolcompat.py
Normal file
|
|
@ -0,0 +1,57 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
#
|
||||||
|
# SelfTest/Util/test_winrandom.py: Self-test for the winrandom module
|
||||||
|
#
|
||||||
|
# =======================================================================
|
||||||
|
# Copyright (C) 2008 Dwayne C. Litzenberger <dlitz@dlitz.net>
|
||||||
|
#
|
||||||
|
# Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
# a copy of this software and associated documentation files (the
|
||||||
|
# "Software"), to deal in the Software without restriction, including
|
||||||
|
# without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
# distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
# permit persons to whom the Software is furnished to do so.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
# =======================================================================
|
||||||
|
#
|
||||||
|
|
||||||
|
"""Self-test for the Crypto.Random.RandomPoolCompat class"""
|
||||||
|
|
||||||
|
__revision__ = "$Id$"
|
||||||
|
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
class SimpleTest(unittest.TestCase):
|
||||||
|
def runTest(self):
|
||||||
|
"""Crypto.Random.RandomPoolCompat"""
|
||||||
|
# Import the winrandom module and try to use it
|
||||||
|
from Crypto.Random import RandomPoolCompat
|
||||||
|
rpool = RandomPoolCompat()
|
||||||
|
x = rpool.get_bytes(16)
|
||||||
|
y = rpool.get_bytes(16)
|
||||||
|
self.assertNotEqual(x, y)
|
||||||
|
self.assertNotEqual(rpool.entropy, 0)
|
||||||
|
|
||||||
|
rpool.randomize()
|
||||||
|
rpool.stir('foo')
|
||||||
|
rpool.add_event('foo')
|
||||||
|
|
||||||
|
def get_tests():
|
||||||
|
return [SimpleTest()]
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
suite = lambda: unittest.TestSuite(get_tests())
|
||||||
|
unittest.main(defaultTest='suite')
|
||||||
|
|
||||||
|
# vim:set ts=4 sw=4 sts=4 expandtab:
|
||||||
|
|
@ -75,6 +75,7 @@ def get_tests():
|
||||||
tests = []
|
tests = []
|
||||||
import Cipher; tests += Cipher.get_tests()
|
import Cipher; tests += Cipher.get_tests()
|
||||||
import Hash; tests += Hash.get_tests()
|
import Hash; tests += Hash.get_tests()
|
||||||
|
import Random; tests += Random.get_tests()
|
||||||
import Util; tests += Util.get_tests()
|
import Util; tests += Util.get_tests()
|
||||||
return tests
|
return tests
|
||||||
|
|
||||||
|
|
|
||||||
2
setup.py
2
setup.py
|
|
@ -178,6 +178,8 @@ kw = {'name':"pycrypto",
|
||||||
"Crypto.SelfTest",
|
"Crypto.SelfTest",
|
||||||
"Crypto.SelfTest.Cipher",
|
"Crypto.SelfTest.Cipher",
|
||||||
"Crypto.SelfTest.Hash",
|
"Crypto.SelfTest.Hash",
|
||||||
|
"Crypto.SelfTest.Random",
|
||||||
|
"Crypto.SelfTest.Random.OSRNG",
|
||||||
"Crypto.SelfTest.Util",
|
"Crypto.SelfTest.Util",
|
||||||
"Crypto.Protocol", "Crypto.PublicKey"],
|
"Crypto.Protocol", "Crypto.PublicKey"],
|
||||||
'package_dir' : { "Crypto":"." },
|
'package_dir' : { "Crypto":"." },
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue