diff options
author | Ezio Melotti <ezio.melotti@gmail.com> | 2013-04-19 02:46:08 (GMT) |
---|---|---|
committer | Ezio Melotti <ezio.melotti@gmail.com> | 2013-04-19 02:46:08 (GMT) |
commit | ba5da9437e766c2cbe12aef97ea6352fafaa75d5 (patch) | |
tree | 673097b9b267ec77b6d3bcd7c080aed98fbfaa5c /Lib/test/test_random.py | |
parent | a108112680db1576a71d9218cf052437b16868b6 (diff) | |
parent | 3e4a98bd1c93f66abf41561b558d81c0fbd02b2e (diff) | |
download | cpython-ba5da9437e766c2cbe12aef97ea6352fafaa75d5.zip cpython-ba5da9437e766c2cbe12aef97ea6352fafaa75d5.tar.gz cpython-ba5da9437e766c2cbe12aef97ea6352fafaa75d5.tar.bz2 |
#17789: merge with 3.3.
Diffstat (limited to 'Lib/test/test_random.py')
-rw-r--r-- | Lib/test/test_random.py | 39 |
1 files changed, 12 insertions, 27 deletions
diff --git a/Lib/test/test_random.py b/Lib/test/test_random.py index 437a20f..49a3f7b 100644 --- a/Lib/test/test_random.py +++ b/Lib/test/test_random.py @@ -10,7 +10,7 @@ from functools import partial from math import log, exp, pi, fsum, sin from test import support -class TestBasicOps(unittest.TestCase): +class TestBasicOps: # Superclass with tests common to all generators. # Subclasses must arrange for self.gen to retrieve the Random instance # to be tested. @@ -188,7 +188,15 @@ class TestBasicOps(unittest.TestCase): k = sum(randrange(6755399441055744) % 3 == 2 for i in range(n)) self.assertTrue(0.30 < k/n < .37, (k/n)) -class SystemRandom_TestBasicOps(TestBasicOps): +try: + random.SystemRandom().random() +except NotImplementedError: + SystemRandom_available = False +else: + SystemRandom_available = True + +@unittest.skipUnless(SystemRandom_available, "random.SystemRandom not available") +class SystemRandom_TestBasicOps(TestBasicOps, unittest.TestCase): gen = random.SystemRandom() def test_autoseed(self): @@ -304,7 +312,7 @@ class SystemRandom_TestBasicOps(TestBasicOps): self.assertTrue(2**k > n > 2**(k-1)) # note the stronger assertion -class MersenneTwister_TestBasicOps(TestBasicOps): +class MersenneTwister_TestBasicOps(TestBasicOps, unittest.TestCase): gen = random.Random() def test_guaranteed_stable(self): @@ -749,28 +757,5 @@ class TestModule(unittest.TestCase): Subclass(newarg=1) -def test_main(verbose=None): - testclasses = [MersenneTwister_TestBasicOps, - TestDistributions, - TestModule] - - try: - random.SystemRandom().random() - except NotImplementedError: - pass - else: - testclasses.append(SystemRandom_TestBasicOps) - - support.run_unittest(*testclasses) - - # verify reference counting - import sys - if verbose and hasattr(sys, "gettotalrefcount"): - counts = [None] * 5 - for i in range(len(counts)): - support.run_unittest(*testclasses) - counts[i] = sys.gettotalrefcount() - print(counts) - if __name__ == "__main__": - test_main(verbose=True) + unittest.main() |