| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  | import unittest | 
					
						
							| 
									
										
										
										
											2013-04-02 12:47:23 -04:00
										 |  |  | import unittest.mock | 
					
						
							| 
									
										
										
										
											2002-05-05 20:40:00 +00:00
										 |  |  | import random | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  | import time | 
					
						
							| 
									
										
										
										
											2003-06-24 20:29:04 +00:00
										 |  |  | import pickle | 
					
						
							| 
									
										
										
										
											2003-10-05 09:09:15 +00:00
										 |  |  | import warnings | 
					
						
							| 
									
										
										
										
											2013-04-02 12:47:23 -04:00
										 |  |  | from functools import partial | 
					
						
							| 
									
										
										
										
											2010-03-14 10:45:50 +00:00
										 |  |  | from math import log, exp, pi, fsum, sin | 
					
						
							| 
									
										
										
										
											2008-05-20 21:35:26 +00:00
										 |  |  | from test import support | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-19 05:45:27 +03:00
										 |  |  | class TestBasicOps: | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  |     # Superclass with tests common to all generators. | 
					
						
							|  |  |  |     # Subclasses must arrange for self.gen to retrieve the Random instance | 
					
						
							|  |  |  |     # to be tested. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def randomlist(self, n): | 
					
						
							|  |  |  |         """Helper function to make a list of random numbers""" | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |         return [self.gen.random() for i in range(n)] | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def test_autoseed(self): | 
					
						
							|  |  |  |         self.gen.seed() | 
					
						
							|  |  |  |         state1 = self.gen.getstate() | 
					
						
							| 
									
										
										
										
											2003-08-09 18:30:57 +00:00
										 |  |  |         time.sleep(0.1) | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  |         self.gen.seed()      # diffent seeds at different times | 
					
						
							|  |  |  |         state2 = self.gen.getstate() | 
					
						
							|  |  |  |         self.assertNotEqual(state1, state2) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_saverestore(self): | 
					
						
							|  |  |  |         N = 1000 | 
					
						
							|  |  |  |         self.gen.seed() | 
					
						
							|  |  |  |         state = self.gen.getstate() | 
					
						
							|  |  |  |         randseq = self.randomlist(N) | 
					
						
							|  |  |  |         self.gen.setstate(state)    # should regenerate the same sequence | 
					
						
							|  |  |  |         self.assertEqual(randseq, self.randomlist(N)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_seedargs(self): | 
					
						
							| 
									
										
										
										
											2012-06-24 11:05:30 +01:00
										 |  |  |         # Seed value with a negative hash. | 
					
						
							|  |  |  |         class MySeed(object): | 
					
						
							|  |  |  |             def __hash__(self): | 
					
						
							|  |  |  |                 return -1729 | 
					
						
							| 
									
										
										
										
											2007-01-15 16:59:06 +00:00
										 |  |  |         for arg in [None, 0, 0, 1, 1, -1, -1, 10**20, -(10**20), | 
					
						
							| 
									
										
										
										
											2012-06-24 11:05:30 +01:00
										 |  |  |                     3.14, 1+2j, 'a', tuple('abc'), MySeed()]: | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  |             self.gen.seed(arg) | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |         for arg in [list(range(3)), dict(one=1)]: | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  |             self.assertRaises(TypeError, self.gen.seed, arg) | 
					
						
							| 
									
										
										
										
											2010-09-07 00:38:15 +00:00
										 |  |  |         self.assertRaises(TypeError, self.gen.seed, 1, 2, 3, 4) | 
					
						
							| 
									
										
										
										
											2004-07-09 14:26:18 +00:00
										 |  |  |         self.assertRaises(TypeError, type(self.gen), []) | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-02 12:47:23 -04:00
										 |  |  |     @unittest.mock.patch('random._urandom') # os.urandom | 
					
						
							|  |  |  |     def test_seed_when_randomness_source_not_found(self, urandom_mock): | 
					
						
							|  |  |  |         # Random.seed() uses time.time() when an operating system specific | 
					
						
							|  |  |  |         # randomness source is not found. To test this on machines were it | 
					
						
							|  |  |  |         # exists, run the above test, test_seedargs(), again after mocking | 
					
						
							|  |  |  |         # os.urandom() so that it raises the exception expected when the | 
					
						
							|  |  |  |         # randomness source is not available. | 
					
						
							|  |  |  |         urandom_mock.side_effect = NotImplementedError | 
					
						
							|  |  |  |         self.test_seedargs() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-04 02:10:33 +01:00
										 |  |  |     def test_shuffle(self): | 
					
						
							|  |  |  |         shuffle = self.gen.shuffle | 
					
						
							|  |  |  |         lst = [] | 
					
						
							|  |  |  |         shuffle(lst) | 
					
						
							|  |  |  |         self.assertEqual(lst, []) | 
					
						
							|  |  |  |         lst = [37] | 
					
						
							|  |  |  |         shuffle(lst) | 
					
						
							|  |  |  |         self.assertEqual(lst, [37]) | 
					
						
							|  |  |  |         seqs = [list(range(n)) for n in range(10)] | 
					
						
							|  |  |  |         shuffled_seqs = [list(range(n)) for n in range(10)] | 
					
						
							|  |  |  |         for shuffled_seq in shuffled_seqs: | 
					
						
							|  |  |  |             shuffle(shuffled_seq) | 
					
						
							|  |  |  |         for (seq, shuffled_seq) in zip(seqs, shuffled_seqs): | 
					
						
							|  |  |  |             self.assertEqual(len(seq), len(shuffled_seq)) | 
					
						
							|  |  |  |             self.assertEqual(set(seq), set(shuffled_seq)) | 
					
						
							|  |  |  |         # The above tests all would pass if the shuffle was a | 
					
						
							|  |  |  |         # no-op. The following non-deterministic test covers that.  It | 
					
						
							|  |  |  |         # asserts that the shuffled sequence of 1000 distinct elements | 
					
						
							|  |  |  |         # must be different from the original one. Although there is | 
					
						
							|  |  |  |         # mathematically a non-zero probability that this could | 
					
						
							|  |  |  |         # actually happen in a genuinely random shuffle, it is | 
					
						
							|  |  |  |         # completely negligible, given that the number of possible | 
					
						
							|  |  |  |         # permutations of 1000 objects is 1000! (factorial of 1000), | 
					
						
							|  |  |  |         # which is considerably larger than the number of atoms in the | 
					
						
							|  |  |  |         # universe... | 
					
						
							|  |  |  |         lst = list(range(1000)) | 
					
						
							|  |  |  |         shuffled_lst = list(range(1000)) | 
					
						
							|  |  |  |         shuffle(shuffled_lst) | 
					
						
							|  |  |  |         self.assertTrue(lst != shuffled_lst) | 
					
						
							|  |  |  |         shuffle(lst) | 
					
						
							|  |  |  |         self.assertTrue(lst != shuffled_lst) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-07 10:06:56 +00:00
										 |  |  |     def test_choice(self): | 
					
						
							|  |  |  |         choice = self.gen.choice | 
					
						
							|  |  |  |         with self.assertRaises(IndexError): | 
					
						
							|  |  |  |             choice([]) | 
					
						
							|  |  |  |         self.assertEqual(choice([50]), 50) | 
					
						
							|  |  |  |         self.assertIn(choice([25, 75]), [25, 75]) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  |     def test_sample(self): | 
					
						
							|  |  |  |         # For the entire allowable range of 0 <= k <= N, validate that | 
					
						
							|  |  |  |         # the sample is of the correct length and contains only unique items | 
					
						
							|  |  |  |         N = 100 | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |         population = range(N) | 
					
						
							|  |  |  |         for k in range(N+1): | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  |             s = self.gen.sample(population, k) | 
					
						
							|  |  |  |             self.assertEqual(len(s), k) | 
					
						
							| 
									
										
										
										
											2003-11-16 16:17:49 +00:00
										 |  |  |             uniq = set(s) | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  |             self.assertEqual(len(uniq), k) | 
					
						
							| 
									
										
										
										
											2009-06-30 23:06:06 +00:00
										 |  |  |             self.assertTrue(uniq <= set(population)) | 
					
						
							| 
									
										
										
										
											2003-01-04 05:55:11 +00:00
										 |  |  |         self.assertEqual(self.gen.sample([], 0), [])  # test edge case N==k==0 | 
					
						
							| 
									
										
										
										
											2013-04-02 12:47:23 -04:00
										 |  |  |         # Exception raised if size of sample exceeds that of population | 
					
						
							|  |  |  |         self.assertRaises(ValueError, self.gen.sample, population, N+1) | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-01-17 17:23:23 +00:00
										 |  |  |     def test_sample_distribution(self): | 
					
						
							|  |  |  |         # For the entire allowable range of 0 <= k <= N, validate that | 
					
						
							|  |  |  |         # sample generates all possible permutations | 
					
						
							|  |  |  |         n = 5 | 
					
						
							|  |  |  |         pop = range(n) | 
					
						
							|  |  |  |         trials = 10000  # large num prevents false negatives without slowing normal case | 
					
						
							|  |  |  |         def factorial(n): | 
					
						
							| 
									
										
										
										
											2006-08-22 00:21:25 +00:00
										 |  |  |             if n == 0: | 
					
						
							|  |  |  |                 return 1 | 
					
						
							|  |  |  |             return n * factorial(n - 1) | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |         for k in range(n): | 
					
						
							| 
									
										
										
										
											2004-09-27 15:29:05 +00:00
										 |  |  |             expected = factorial(n) // factorial(n-k) | 
					
						
							| 
									
										
										
										
											2003-01-17 17:23:23 +00:00
										 |  |  |             perms = {} | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |             for i in range(trials): | 
					
						
							| 
									
										
										
										
											2003-01-17 17:23:23 +00:00
										 |  |  |                 perms[tuple(self.gen.sample(pop, k))] = None | 
					
						
							|  |  |  |                 if len(perms) == expected: | 
					
						
							|  |  |  |                     break | 
					
						
							|  |  |  |             else: | 
					
						
							|  |  |  |                 self.fail() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-09-06 04:25:54 +00:00
										 |  |  |     def test_sample_inputs(self): | 
					
						
							|  |  |  |         # SF bug #801342 -- population can be any iterable defining __len__() | 
					
						
							| 
									
										
										
										
											2003-11-16 16:17:49 +00:00
										 |  |  |         self.gen.sample(set(range(20)), 2) | 
					
						
							| 
									
										
										
										
											2003-09-06 04:25:54 +00:00
										 |  |  |         self.gen.sample(range(20), 2) | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |         self.gen.sample(range(20), 2) | 
					
						
							| 
									
										
										
										
											2003-09-06 04:25:54 +00:00
										 |  |  |         self.gen.sample(str('abcdefghijklmnopqrst'), 2) | 
					
						
							|  |  |  |         self.gen.sample(tuple('abcdefghijklmnopqrst'), 2) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-04-21 10:40:58 +00:00
										 |  |  |     def test_sample_on_dicts(self): | 
					
						
							| 
									
										
										
										
											2008-01-14 01:00:53 +00:00
										 |  |  |         self.assertRaises(TypeError, self.gen.sample, dict.fromkeys('abcdef'), 2) | 
					
						
							| 
									
										
										
										
											2006-04-21 10:40:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  |     def test_gauss(self): | 
					
						
							|  |  |  |         # Ensure that the seed() method initializes all the hidden state.  In | 
					
						
							|  |  |  |         # particular, through 2.2.1 it failed to reset a piece of state used | 
					
						
							|  |  |  |         # by (and only by) the .gauss() method. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         for seed in 1, 12, 123, 1234, 12345, 123456, 654321: | 
					
						
							|  |  |  |             self.gen.seed(seed) | 
					
						
							|  |  |  |             x1 = self.gen.random() | 
					
						
							|  |  |  |             y1 = self.gen.gauss(0, 1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             self.gen.seed(seed) | 
					
						
							|  |  |  |             x2 = self.gen.random() | 
					
						
							|  |  |  |             y2 = self.gen.gauss(0, 1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             self.assertEqual(x1, x2) | 
					
						
							|  |  |  |             self.assertEqual(y1, y2) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-06-24 20:29:04 +00:00
										 |  |  |     def test_pickling(self): | 
					
						
							|  |  |  |         state = pickle.dumps(self.gen) | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |         origseq = [self.gen.random() for i in range(10)] | 
					
						
							| 
									
										
										
										
											2003-06-24 20:29:04 +00:00
										 |  |  |         newgen = pickle.loads(state) | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |         restoredseq = [newgen.random() for i in range(10)] | 
					
						
							| 
									
										
										
										
											2003-06-24 20:29:04 +00:00
										 |  |  |         self.assertEqual(origseq, restoredseq) | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 59275-59303 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
NOTE: The merge does NOT contain the modified file Python/import.c from
      r59288. I can't get it running. Nick, please check in the PEP 366
      manually.
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
........
  r59279 | georg.brandl | 2007-12-02 19:17:50 +0100 (Sun, 02 Dec 2007) | 2 lines
  Fix a sentence I missed before. Do not merge to 3k.
........
  r59281 | georg.brandl | 2007-12-02 22:58:54 +0100 (Sun, 02 Dec 2007) | 3 lines
  Add documentation for PySys_* functions.
  Written by Charlie Shepherd for GHOP. Also fixes #1245.
........
  r59288 | nick.coghlan | 2007-12-03 13:55:17 +0100 (Mon, 03 Dec 2007) | 1 line
  Implement PEP 366
........
  r59290 | christian.heimes | 2007-12-03 14:47:29 +0100 (Mon, 03 Dec 2007) | 3 lines
  Applied my patch #1455 with some extra fixes for VS 2005
  The new msvc9compiler module supports VS 2005 and VS 2008. I've also fixed build_ext to support PCbuild8 and PCbuild9 and backported my fix for xxmodule.c from py3k. The old code msvccompiler is still in place in case somebody likes to build an extension with VS 2003 or earlier.
  I've also updated the cygwin compiler module for VS 2005 and VS 2008. It works with VS 2005 but I'm unable to test it with VS 2008. We have to wait for a new version of cygwin.
........
  r59291 | christian.heimes | 2007-12-03 14:55:16 +0100 (Mon, 03 Dec 2007) | 1 line
  Added comment to Misc/NEWS for r59290
........
  r59292 | christian.heimes | 2007-12-03 15:28:04 +0100 (Mon, 03 Dec 2007) | 1 line
  I followed MA Lemberg's suggestion and added comments to the late initialization of the type slots.
........
  r59293 | facundo.batista | 2007-12-03 17:29:52 +0100 (Mon, 03 Dec 2007) | 3 lines
  Speedup and cleaning of __str__.  Thanks Mark Dickinson.
........
  r59294 | facundo.batista | 2007-12-03 18:55:00 +0100 (Mon, 03 Dec 2007) | 4 lines
  Faster _fix function, and some reordering for a more elegant
  coding. Thanks Mark Dickinson.
........
  r59295 | martin.v.loewis | 2007-12-03 20:20:02 +0100 (Mon, 03 Dec 2007) | 5 lines
  Issue #1727780: Support loading pickles of random.Random objects created
  on 32-bit systems on 64-bit systems, and vice versa. As a consequence
  of the change, Random pickles created by Python 2.6 cannot be loaded
  in Python 2.5.
........
  r59297 | facundo.batista | 2007-12-03 20:49:54 +0100 (Mon, 03 Dec 2007) | 3 lines
  Two small fixes. Issue 1547.
........
  r59299 | georg.brandl | 2007-12-03 20:57:02 +0100 (Mon, 03 Dec 2007) | 2 lines
  #1548: fix apostroph placement.
........
  r59300 | christian.heimes | 2007-12-03 21:01:02 +0100 (Mon, 03 Dec 2007) | 3 lines
  Patch #1537 from Chad Austin
  Change GeneratorExit's base class from Exception to BaseException
  (This time I'm applying the patch to the correct sandbox.)
........
  r59302 | georg.brandl | 2007-12-03 21:03:46 +0100 (Mon, 03 Dec 2007) | 3 lines
  Add examples to the xmlrpclib docs.
  Written for GHOP by Josip Dzolonga.
........
											
										 
											2007-12-03 21:02:03 +00:00
										 |  |  |     def test_bug_1727780(self): | 
					
						
							|  |  |  |         # verify that version-2-pickles can be loaded | 
					
						
							|  |  |  |         # fine, whether they are created on 32-bit or 64-bit | 
					
						
							|  |  |  |         # platforms, and that version-3-pickles load fine. | 
					
						
							|  |  |  |         files = [("randv2_32.pck", 780), | 
					
						
							|  |  |  |                  ("randv2_64.pck", 866), | 
					
						
							|  |  |  |                  ("randv3.pck", 343)] | 
					
						
							|  |  |  |         for file, value in files: | 
					
						
							| 
									
										
										
										
											2008-05-20 21:35:26 +00:00
										 |  |  |             f = open(support.findfile(file),"rb") | 
					
						
							| 
									
										
											  
											
												Merged revisions 59275-59303 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
NOTE: The merge does NOT contain the modified file Python/import.c from
      r59288. I can't get it running. Nick, please check in the PEP 366
      manually.
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
........
  r59279 | georg.brandl | 2007-12-02 19:17:50 +0100 (Sun, 02 Dec 2007) | 2 lines
  Fix a sentence I missed before. Do not merge to 3k.
........
  r59281 | georg.brandl | 2007-12-02 22:58:54 +0100 (Sun, 02 Dec 2007) | 3 lines
  Add documentation for PySys_* functions.
  Written by Charlie Shepherd for GHOP. Also fixes #1245.
........
  r59288 | nick.coghlan | 2007-12-03 13:55:17 +0100 (Mon, 03 Dec 2007) | 1 line
  Implement PEP 366
........
  r59290 | christian.heimes | 2007-12-03 14:47:29 +0100 (Mon, 03 Dec 2007) | 3 lines
  Applied my patch #1455 with some extra fixes for VS 2005
  The new msvc9compiler module supports VS 2005 and VS 2008. I've also fixed build_ext to support PCbuild8 and PCbuild9 and backported my fix for xxmodule.c from py3k. The old code msvccompiler is still in place in case somebody likes to build an extension with VS 2003 or earlier.
  I've also updated the cygwin compiler module for VS 2005 and VS 2008. It works with VS 2005 but I'm unable to test it with VS 2008. We have to wait for a new version of cygwin.
........
  r59291 | christian.heimes | 2007-12-03 14:55:16 +0100 (Mon, 03 Dec 2007) | 1 line
  Added comment to Misc/NEWS for r59290
........
  r59292 | christian.heimes | 2007-12-03 15:28:04 +0100 (Mon, 03 Dec 2007) | 1 line
  I followed MA Lemberg's suggestion and added comments to the late initialization of the type slots.
........
  r59293 | facundo.batista | 2007-12-03 17:29:52 +0100 (Mon, 03 Dec 2007) | 3 lines
  Speedup and cleaning of __str__.  Thanks Mark Dickinson.
........
  r59294 | facundo.batista | 2007-12-03 18:55:00 +0100 (Mon, 03 Dec 2007) | 4 lines
  Faster _fix function, and some reordering for a more elegant
  coding. Thanks Mark Dickinson.
........
  r59295 | martin.v.loewis | 2007-12-03 20:20:02 +0100 (Mon, 03 Dec 2007) | 5 lines
  Issue #1727780: Support loading pickles of random.Random objects created
  on 32-bit systems on 64-bit systems, and vice versa. As a consequence
  of the change, Random pickles created by Python 2.6 cannot be loaded
  in Python 2.5.
........
  r59297 | facundo.batista | 2007-12-03 20:49:54 +0100 (Mon, 03 Dec 2007) | 3 lines
  Two small fixes. Issue 1547.
........
  r59299 | georg.brandl | 2007-12-03 20:57:02 +0100 (Mon, 03 Dec 2007) | 2 lines
  #1548: fix apostroph placement.
........
  r59300 | christian.heimes | 2007-12-03 21:01:02 +0100 (Mon, 03 Dec 2007) | 3 lines
  Patch #1537 from Chad Austin
  Change GeneratorExit's base class from Exception to BaseException
  (This time I'm applying the patch to the correct sandbox.)
........
  r59302 | georg.brandl | 2007-12-03 21:03:46 +0100 (Mon, 03 Dec 2007) | 3 lines
  Add examples to the xmlrpclib docs.
  Written for GHOP by Josip Dzolonga.
........
											
										 
											2007-12-03 21:02:03 +00:00
										 |  |  |             r = pickle.load(f) | 
					
						
							|  |  |  |             f.close() | 
					
						
							| 
									
										
										
										
											2010-09-07 04:44:52 +00:00
										 |  |  |             self.assertEqual(int(r.random()*1000), value) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_bug_9025(self): | 
					
						
							|  |  |  |         # Had problem with an uneven distribution in int(n*random()) | 
					
						
							|  |  |  |         # Verify the fix by checking that distributions fall within expectations. | 
					
						
							|  |  |  |         n = 100000 | 
					
						
							|  |  |  |         randrange = self.gen.randrange | 
					
						
							|  |  |  |         k = sum(randrange(6755399441055744) % 3 == 2 for i in range(n)) | 
					
						
							|  |  |  |         self.assertTrue(0.30 < k/n < .37, (k/n)) | 
					
						
							| 
									
										
											  
											
												Merged revisions 59275-59303 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
NOTE: The merge does NOT contain the modified file Python/import.c from
      r59288. I can't get it running. Nick, please check in the PEP 366
      manually.
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
........
  r59279 | georg.brandl | 2007-12-02 19:17:50 +0100 (Sun, 02 Dec 2007) | 2 lines
  Fix a sentence I missed before. Do not merge to 3k.
........
  r59281 | georg.brandl | 2007-12-02 22:58:54 +0100 (Sun, 02 Dec 2007) | 3 lines
  Add documentation for PySys_* functions.
  Written by Charlie Shepherd for GHOP. Also fixes #1245.
........
  r59288 | nick.coghlan | 2007-12-03 13:55:17 +0100 (Mon, 03 Dec 2007) | 1 line
  Implement PEP 366
........
  r59290 | christian.heimes | 2007-12-03 14:47:29 +0100 (Mon, 03 Dec 2007) | 3 lines
  Applied my patch #1455 with some extra fixes for VS 2005
  The new msvc9compiler module supports VS 2005 and VS 2008. I've also fixed build_ext to support PCbuild8 and PCbuild9 and backported my fix for xxmodule.c from py3k. The old code msvccompiler is still in place in case somebody likes to build an extension with VS 2003 or earlier.
  I've also updated the cygwin compiler module for VS 2005 and VS 2008. It works with VS 2005 but I'm unable to test it with VS 2008. We have to wait for a new version of cygwin.
........
  r59291 | christian.heimes | 2007-12-03 14:55:16 +0100 (Mon, 03 Dec 2007) | 1 line
  Added comment to Misc/NEWS for r59290
........
  r59292 | christian.heimes | 2007-12-03 15:28:04 +0100 (Mon, 03 Dec 2007) | 1 line
  I followed MA Lemberg's suggestion and added comments to the late initialization of the type slots.
........
  r59293 | facundo.batista | 2007-12-03 17:29:52 +0100 (Mon, 03 Dec 2007) | 3 lines
  Speedup and cleaning of __str__.  Thanks Mark Dickinson.
........
  r59294 | facundo.batista | 2007-12-03 18:55:00 +0100 (Mon, 03 Dec 2007) | 4 lines
  Faster _fix function, and some reordering for a more elegant
  coding. Thanks Mark Dickinson.
........
  r59295 | martin.v.loewis | 2007-12-03 20:20:02 +0100 (Mon, 03 Dec 2007) | 5 lines
  Issue #1727780: Support loading pickles of random.Random objects created
  on 32-bit systems on 64-bit systems, and vice versa. As a consequence
  of the change, Random pickles created by Python 2.6 cannot be loaded
  in Python 2.5.
........
  r59297 | facundo.batista | 2007-12-03 20:49:54 +0100 (Mon, 03 Dec 2007) | 3 lines
  Two small fixes. Issue 1547.
........
  r59299 | georg.brandl | 2007-12-03 20:57:02 +0100 (Mon, 03 Dec 2007) | 2 lines
  #1548: fix apostroph placement.
........
  r59300 | christian.heimes | 2007-12-03 21:01:02 +0100 (Mon, 03 Dec 2007) | 3 lines
  Patch #1537 from Chad Austin
  Change GeneratorExit's base class from Exception to BaseException
  (This time I'm applying the patch to the correct sandbox.)
........
  r59302 | georg.brandl | 2007-12-03 21:03:46 +0100 (Mon, 03 Dec 2007) | 3 lines
  Add examples to the xmlrpclib docs.
  Written for GHOP by Josip Dzolonga.
........
											
										 
											2007-12-03 21:02:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-19 05:45:27 +03:00
										 |  |  | 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): | 
					
						
							| 
									
										
										
										
											2004-09-13 22:23:21 +00:00
										 |  |  |     gen = random.SystemRandom() | 
					
						
							| 
									
										
										
										
											2004-08-30 06:14:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def test_autoseed(self): | 
					
						
							|  |  |  |         # Doesn't need to do anything except not fail | 
					
						
							|  |  |  |         self.gen.seed() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_saverestore(self): | 
					
						
							|  |  |  |         self.assertRaises(NotImplementedError, self.gen.getstate) | 
					
						
							|  |  |  |         self.assertRaises(NotImplementedError, self.gen.setstate, None) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_seedargs(self): | 
					
						
							|  |  |  |         # Doesn't need to do anything except not fail | 
					
						
							|  |  |  |         self.gen.seed(100) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_gauss(self): | 
					
						
							|  |  |  |         self.gen.gauss_next = None | 
					
						
							|  |  |  |         self.gen.seed(100) | 
					
						
							|  |  |  |         self.assertEqual(self.gen.gauss_next, None) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_pickling(self): | 
					
						
							|  |  |  |         self.assertRaises(NotImplementedError, pickle.dumps, self.gen) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_53_bits_per_float(self): | 
					
						
							|  |  |  |         # This should pass whenever a C double has 53 bit precision. | 
					
						
							|  |  |  |         span = 2 ** 53 | 
					
						
							|  |  |  |         cum = 0 | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |         for i in range(100): | 
					
						
							| 
									
										
										
										
											2004-08-30 06:14:31 +00:00
										 |  |  |             cum |= int(self.gen.random() * span) | 
					
						
							|  |  |  |         self.assertEqual(cum, span-1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_bigrand(self): | 
					
						
							|  |  |  |         # The randrange routine should build-up the required number of bits | 
					
						
							|  |  |  |         # in stages so that all bit positions are active. | 
					
						
							|  |  |  |         span = 2 ** 500 | 
					
						
							|  |  |  |         cum = 0 | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |         for i in range(100): | 
					
						
							| 
									
										
										
										
											2004-08-30 06:14:31 +00:00
										 |  |  |             r = self.gen.randrange(span) | 
					
						
							| 
									
										
										
										
											2009-06-30 23:06:06 +00:00
										 |  |  |             self.assertTrue(0 <= r < span) | 
					
						
							| 
									
										
										
										
											2004-08-30 06:14:31 +00:00
										 |  |  |             cum |= r | 
					
						
							|  |  |  |         self.assertEqual(cum, span-1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_bigrand_ranges(self): | 
					
						
							|  |  |  |         for i in [40,80, 160, 200, 211, 250, 375, 512, 550]: | 
					
						
							| 
									
										
										
										
											2013-11-26 14:50:10 -06:00
										 |  |  |             start = self.gen.randrange(2 ** (i-2)) | 
					
						
							|  |  |  |             stop = self.gen.randrange(2 ** i) | 
					
						
							| 
									
										
										
										
											2004-08-30 06:14:31 +00:00
										 |  |  |             if stop <= start: | 
					
						
							| 
									
										
										
										
											2013-11-26 14:50:10 -06:00
										 |  |  |                 continue | 
					
						
							| 
									
										
										
										
											2009-06-30 23:06:06 +00:00
										 |  |  |             self.assertTrue(start <= self.gen.randrange(start, stop) < stop) | 
					
						
							| 
									
										
										
										
											2004-08-30 06:14:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def test_rangelimits(self): | 
					
						
							|  |  |  |         for start, stop in [(-2,0), (-(2**60)-2,-(2**60)), (2**60,2**60+2)]: | 
					
						
							|  |  |  |             self.assertEqual(set(range(start,stop)), | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |                 set([self.gen.randrange(start,stop) for i in range(100)])) | 
					
						
							| 
									
										
										
										
											2004-08-30 06:14:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-02 12:47:23 -04:00
										 |  |  |     def test_randrange_nonunit_step(self): | 
					
						
							|  |  |  |         rint = self.gen.randrange(0, 10, 2) | 
					
						
							|  |  |  |         self.assertIn(rint, (0, 2, 4, 6, 8)) | 
					
						
							|  |  |  |         rint = self.gen.randrange(0, 2, 2) | 
					
						
							|  |  |  |         self.assertEqual(rint, 0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_randrange_errors(self): | 
					
						
							|  |  |  |         raises = partial(self.assertRaises, ValueError, self.gen.randrange) | 
					
						
							|  |  |  |         # Empty range | 
					
						
							|  |  |  |         raises(3, 3) | 
					
						
							|  |  |  |         raises(-721) | 
					
						
							|  |  |  |         raises(0, 100, -12) | 
					
						
							|  |  |  |         # Non-integer start/stop | 
					
						
							|  |  |  |         raises(3.14159) | 
					
						
							|  |  |  |         raises(0, 2.71828) | 
					
						
							|  |  |  |         # Zero and non-integer step | 
					
						
							|  |  |  |         raises(0, 42, 0) | 
					
						
							|  |  |  |         raises(0, 42, 3.14159) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-08-30 06:14:31 +00:00
										 |  |  |     def test_genrandbits(self): | 
					
						
							|  |  |  |         # Verify ranges | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |         for k in range(1, 1000): | 
					
						
							| 
									
										
										
										
											2009-06-30 23:06:06 +00:00
										 |  |  |             self.assertTrue(0 <= self.gen.getrandbits(k) < 2**k) | 
					
						
							| 
									
										
										
										
											2004-08-30 06:14:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         # Verify all bits active | 
					
						
							|  |  |  |         getbits = self.gen.getrandbits | 
					
						
							|  |  |  |         for span in [1, 2, 3, 4, 31, 32, 32, 52, 53, 54, 119, 127, 128, 129]: | 
					
						
							|  |  |  |             cum = 0 | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |             for i in range(100): | 
					
						
							| 
									
										
										
										
											2004-08-30 06:14:31 +00:00
										 |  |  |                 cum |= getbits(span) | 
					
						
							|  |  |  |             self.assertEqual(cum, 2**span-1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # Verify argument checking | 
					
						
							|  |  |  |         self.assertRaises(TypeError, self.gen.getrandbits) | 
					
						
							|  |  |  |         self.assertRaises(TypeError, self.gen.getrandbits, 1, 2) | 
					
						
							|  |  |  |         self.assertRaises(ValueError, self.gen.getrandbits, 0) | 
					
						
							|  |  |  |         self.assertRaises(ValueError, self.gen.getrandbits, -1) | 
					
						
							|  |  |  |         self.assertRaises(TypeError, self.gen.getrandbits, 10.1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_randbelow_logic(self, _log=log, int=int): | 
					
						
							|  |  |  |         # check bitcount transition points:  2**i and 2**(i+1)-1 | 
					
						
							|  |  |  |         # show that: k = int(1.001 + _log(n, 2)) | 
					
						
							|  |  |  |         # is equal to or one greater than the number of bits in n | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |         for i in range(1, 1000): | 
					
						
							| 
									
										
										
										
											2007-01-15 16:59:06 +00:00
										 |  |  |             n = 1 << i # check an exact power of two | 
					
						
							| 
									
										
										
										
											2004-08-30 06:14:31 +00:00
										 |  |  |             numbits = i+1 | 
					
						
							|  |  |  |             k = int(1.00001 + _log(n, 2)) | 
					
						
							|  |  |  |             self.assertEqual(k, numbits) | 
					
						
							| 
									
										
										
										
											2007-07-11 12:20:59 +00:00
										 |  |  |             self.assertEqual(n, 2**(k-1)) | 
					
						
							| 
									
										
										
										
											2004-08-30 06:14:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |             n += n - 1      # check 1 below the next power of two | 
					
						
							|  |  |  |             k = int(1.00001 + _log(n, 2)) | 
					
						
							| 
									
										
										
										
											2010-01-19 00:09:57 +00:00
										 |  |  |             self.assertIn(k, [numbits, numbits+1]) | 
					
						
							| 
									
										
										
										
											2009-06-30 23:06:06 +00:00
										 |  |  |             self.assertTrue(2**k > n > 2**(k-2)) | 
					
						
							| 
									
										
										
										
											2004-08-30 06:14:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |             n -= n >> 15     # check a little farther below the next power of two | 
					
						
							|  |  |  |             k = int(1.00001 + _log(n, 2)) | 
					
						
							|  |  |  |             self.assertEqual(k, numbits)        # note the stronger assertion | 
					
						
							| 
									
										
										
										
											2009-06-30 23:06:06 +00:00
										 |  |  |             self.assertTrue(2**k > n > 2**(k-1))   # note the stronger assertion | 
					
						
							| 
									
										
										
										
											2004-08-30 06:14:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-19 05:45:27 +03:00
										 |  |  | class MersenneTwister_TestBasicOps(TestBasicOps, unittest.TestCase): | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  |     gen = random.Random() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-07 00:38:15 +00:00
										 |  |  |     def test_guaranteed_stable(self): | 
					
						
							|  |  |  |         # These sequences are guaranteed to stay the same across versions of python | 
					
						
							|  |  |  |         self.gen.seed(3456147, version=1) | 
					
						
							|  |  |  |         self.assertEqual([self.gen.random().hex() for i in range(4)], | 
					
						
							|  |  |  |             ['0x1.ac362300d90d2p-1', '0x1.9d16f74365005p-1', | 
					
						
							|  |  |  |              '0x1.1ebb4352e4c4dp-1', '0x1.1a7422abf9c11p-1']) | 
					
						
							|  |  |  |         self.gen.seed("the quick brown fox", version=2) | 
					
						
							|  |  |  |         self.assertEqual([self.gen.random().hex() for i in range(4)], | 
					
						
							| 
									
										
										
										
											2010-12-08 01:13:53 +00:00
										 |  |  |             ['0x1.1239ddfb11b7cp-3', '0x1.b3cbb5c51b120p-4', | 
					
						
							|  |  |  |              '0x1.8c4f55116b60fp-1', '0x1.63eb525174a27p-1']) | 
					
						
							| 
									
										
										
										
											2010-09-07 00:38:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-07-09 14:26:18 +00:00
										 |  |  |     def test_setstate_first_arg(self): | 
					
						
							|  |  |  |         self.assertRaises(ValueError, self.gen.setstate, (1, None, None)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_setstate_middle_arg(self): | 
					
						
							|  |  |  |         # Wrong type, s/b tuple | 
					
						
							|  |  |  |         self.assertRaises(TypeError, self.gen.setstate, (2, None, None)) | 
					
						
							|  |  |  |         # Wrong length, s/b 625 | 
					
						
							|  |  |  |         self.assertRaises(ValueError, self.gen.setstate, (2, (1,2,3), None)) | 
					
						
							|  |  |  |         # Wrong type, s/b tuple of 625 ints | 
					
						
							|  |  |  |         self.assertRaises(TypeError, self.gen.setstate, (2, ('a',)*625, None)) | 
					
						
							|  |  |  |         # Last element s/b an int also | 
					
						
							|  |  |  |         self.assertRaises(TypeError, self.gen.setstate, (2, (0,)*624+('a',), None)) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-02 12:47:23 -04:00
										 |  |  |         # Little trick to make "tuple(x % (2**32) for x in internalstate)" | 
					
						
							|  |  |  |         # raise ValueError. I cannot think of a simple way to achieve this, so | 
					
						
							|  |  |  |         # I am opting for using a generator as the middle argument of setstate | 
					
						
							|  |  |  |         # which attempts to cast a NaN to integer. | 
					
						
							|  |  |  |         state_values = self.gen.getstate()[1] | 
					
						
							|  |  |  |         state_values = list(state_values) | 
					
						
							|  |  |  |         state_values[-1] = float('nan') | 
					
						
							|  |  |  |         state = (int(x) for x in state_values) | 
					
						
							|  |  |  |         self.assertRaises(TypeError, self.gen.setstate, (2, state, None)) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  |     def test_referenceImplementation(self): | 
					
						
							|  |  |  |         # Compare the python implementation with results from the original | 
					
						
							|  |  |  |         # code.  Create 2000 53-bit precision random floats.  Compare only | 
					
						
							|  |  |  |         # the last ten entries to show that the independent implementations | 
					
						
							|  |  |  |         # are tracking.  Here is the main() function needed to create the | 
					
						
							|  |  |  |         # list of expected random numbers: | 
					
						
							|  |  |  |         #    void main(void){ | 
					
						
							|  |  |  |         #         int i; | 
					
						
							|  |  |  |         #         unsigned long init[4]={61731, 24903, 614, 42143}, length=4; | 
					
						
							|  |  |  |         #         init_by_array(init, length); | 
					
						
							|  |  |  |         #         for (i=0; i<2000; i++) { | 
					
						
							|  |  |  |         #           printf("%.15f ", genrand_res53()); | 
					
						
							|  |  |  |         #           if (i%5==4) printf("\n"); | 
					
						
							|  |  |  |         #         } | 
					
						
							|  |  |  |         #     } | 
					
						
							|  |  |  |         expected = [0.45839803073713259, | 
					
						
							|  |  |  |                     0.86057815201978782, | 
					
						
							|  |  |  |                     0.92848331726782152, | 
					
						
							|  |  |  |                     0.35932681119782461, | 
					
						
							|  |  |  |                     0.081823493762449573, | 
					
						
							|  |  |  |                     0.14332226470169329, | 
					
						
							|  |  |  |                     0.084297823823520024, | 
					
						
							|  |  |  |                     0.53814864671831453, | 
					
						
							|  |  |  |                     0.089215024911993401, | 
					
						
							|  |  |  |                     0.78486196105372907] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-01-15 16:59:06 +00:00
										 |  |  |         self.gen.seed(61731 + (24903<<32) + (614<<64) + (42143<<96)) | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  |         actual = self.randomlist(2000)[-10:] | 
					
						
							|  |  |  |         for a, e in zip(actual, expected): | 
					
						
							|  |  |  |             self.assertAlmostEqual(a,e,places=14) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_strong_reference_implementation(self): | 
					
						
							|  |  |  |         # Like test_referenceImplementation, but checks for exact bit-level | 
					
						
							|  |  |  |         # equality.  This should pass on any box where C double contains | 
					
						
							|  |  |  |         # at least 53 bits of precision (the underlying algorithm suffers | 
					
						
							|  |  |  |         # no rounding errors -- all results are exact). | 
					
						
							|  |  |  |         from math import ldexp | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-01-15 16:59:06 +00:00
										 |  |  |         expected = [0x0eab3258d2231f, | 
					
						
							|  |  |  |                     0x1b89db315277a5, | 
					
						
							|  |  |  |                     0x1db622a5518016, | 
					
						
							|  |  |  |                     0x0b7f9af0d575bf, | 
					
						
							|  |  |  |                     0x029e4c4db82240, | 
					
						
							|  |  |  |                     0x04961892f5d673, | 
					
						
							|  |  |  |                     0x02b291598e4589, | 
					
						
							|  |  |  |                     0x11388382c15694, | 
					
						
							|  |  |  |                     0x02dad977c9e1fe, | 
					
						
							|  |  |  |                     0x191d96d4d334c6] | 
					
						
							|  |  |  |         self.gen.seed(61731 + (24903<<32) + (614<<64) + (42143<<96)) | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  |         actual = self.randomlist(2000)[-10:] | 
					
						
							|  |  |  |         for a, e in zip(actual, expected): | 
					
						
							| 
									
										
										
										
											2007-01-15 16:59:06 +00:00
										 |  |  |             self.assertEqual(int(ldexp(a, 53)), e) | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def test_long_seed(self): | 
					
						
							|  |  |  |         # This is most interesting to run in debug mode, just to make sure | 
					
						
							|  |  |  |         # nothing blows up.  Under the covers, a dynamically resized array | 
					
						
							|  |  |  |         # is allocated, consuming space proportional to the number of bits | 
					
						
							|  |  |  |         # in the seed.  Unfortunately, that's a quadratic-time algorithm, | 
					
						
							|  |  |  |         # so don't make this horribly big. | 
					
						
							| 
									
										
										
										
											2007-01-15 16:59:06 +00:00
										 |  |  |         seed = (1 << (10000 * 8)) - 1  # about 10K bytes | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  |         self.gen.seed(seed) | 
					
						
							| 
									
										
										
										
											2002-05-05 20:40:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-10-05 09:09:15 +00:00
										 |  |  |     def test_53_bits_per_float(self): | 
					
						
							|  |  |  |         # This should pass whenever a C double has 53 bit precision. | 
					
						
							|  |  |  |         span = 2 ** 53 | 
					
						
							|  |  |  |         cum = 0 | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |         for i in range(100): | 
					
						
							| 
									
										
										
										
											2003-10-05 09:09:15 +00:00
										 |  |  |             cum |= int(self.gen.random() * span) | 
					
						
							|  |  |  |         self.assertEqual(cum, span-1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_bigrand(self): | 
					
						
							|  |  |  |         # The randrange routine should build-up the required number of bits | 
					
						
							|  |  |  |         # in stages so that all bit positions are active. | 
					
						
							|  |  |  |         span = 2 ** 500 | 
					
						
							|  |  |  |         cum = 0 | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |         for i in range(100): | 
					
						
							| 
									
										
										
										
											2003-10-05 09:09:15 +00:00
										 |  |  |             r = self.gen.randrange(span) | 
					
						
							| 
									
										
										
										
											2009-06-30 23:06:06 +00:00
										 |  |  |             self.assertTrue(0 <= r < span) | 
					
						
							| 
									
										
										
										
											2003-10-05 09:09:15 +00:00
										 |  |  |             cum |= r | 
					
						
							|  |  |  |         self.assertEqual(cum, span-1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_bigrand_ranges(self): | 
					
						
							|  |  |  |         for i in [40,80, 160, 200, 211, 250, 375, 512, 550]: | 
					
						
							| 
									
										
										
										
											2013-11-26 14:50:10 -06:00
										 |  |  |             start = self.gen.randrange(2 ** (i-2)) | 
					
						
							|  |  |  |             stop = self.gen.randrange(2 ** i) | 
					
						
							| 
									
										
										
										
											2003-10-05 09:09:15 +00:00
										 |  |  |             if stop <= start: | 
					
						
							| 
									
										
										
										
											2013-11-26 14:50:10 -06:00
										 |  |  |                 continue | 
					
						
							| 
									
										
										
										
											2009-06-30 23:06:06 +00:00
										 |  |  |             self.assertTrue(start <= self.gen.randrange(start, stop) < stop) | 
					
						
							| 
									
										
										
										
											2003-10-05 09:09:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def test_rangelimits(self): | 
					
						
							|  |  |  |         for start, stop in [(-2,0), (-(2**60)-2,-(2**60)), (2**60,2**60+2)]: | 
					
						
							| 
									
										
										
										
											2003-11-16 16:17:49 +00:00
										 |  |  |             self.assertEqual(set(range(start,stop)), | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |                 set([self.gen.randrange(start,stop) for i in range(100)])) | 
					
						
							| 
									
										
										
										
											2003-10-05 09:09:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def test_genrandbits(self): | 
					
						
							|  |  |  |         # Verify cross-platform repeatability | 
					
						
							|  |  |  |         self.gen.seed(1234567) | 
					
						
							|  |  |  |         self.assertEqual(self.gen.getrandbits(100), | 
					
						
							| 
									
										
										
										
											2007-01-15 16:59:06 +00:00
										 |  |  |                          97904845777343510404718956115) | 
					
						
							| 
									
										
										
										
											2003-10-05 09:09:15 +00:00
										 |  |  |         # Verify ranges | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |         for k in range(1, 1000): | 
					
						
							| 
									
										
										
										
											2009-06-30 23:06:06 +00:00
										 |  |  |             self.assertTrue(0 <= self.gen.getrandbits(k) < 2**k) | 
					
						
							| 
									
										
										
										
											2003-10-05 09:09:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         # Verify all bits active | 
					
						
							|  |  |  |         getbits = self.gen.getrandbits | 
					
						
							|  |  |  |         for span in [1, 2, 3, 4, 31, 32, 32, 52, 53, 54, 119, 127, 128, 129]: | 
					
						
							|  |  |  |             cum = 0 | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |             for i in range(100): | 
					
						
							| 
									
										
										
										
											2003-10-05 09:09:15 +00:00
										 |  |  |                 cum |= getbits(span) | 
					
						
							|  |  |  |             self.assertEqual(cum, 2**span-1) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-07-09 14:26:18 +00:00
										 |  |  |         # Verify argument checking | 
					
						
							|  |  |  |         self.assertRaises(TypeError, self.gen.getrandbits) | 
					
						
							|  |  |  |         self.assertRaises(TypeError, self.gen.getrandbits, 'a') | 
					
						
							|  |  |  |         self.assertRaises(TypeError, self.gen.getrandbits, 1, 2) | 
					
						
							|  |  |  |         self.assertRaises(ValueError, self.gen.getrandbits, 0) | 
					
						
							|  |  |  |         self.assertRaises(ValueError, self.gen.getrandbits, -1) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-10-05 09:09:15 +00:00
										 |  |  |     def test_randbelow_logic(self, _log=log, int=int): | 
					
						
							|  |  |  |         # check bitcount transition points:  2**i and 2**(i+1)-1 | 
					
						
							|  |  |  |         # show that: k = int(1.001 + _log(n, 2)) | 
					
						
							|  |  |  |         # is equal to or one greater than the number of bits in n | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |         for i in range(1, 1000): | 
					
						
							| 
									
										
										
										
											2007-01-15 16:59:06 +00:00
										 |  |  |             n = 1 << i # check an exact power of two | 
					
						
							| 
									
										
										
										
											2003-10-05 09:09:15 +00:00
										 |  |  |             numbits = i+1 | 
					
						
							|  |  |  |             k = int(1.00001 + _log(n, 2)) | 
					
						
							|  |  |  |             self.assertEqual(k, numbits) | 
					
						
							| 
									
										
										
										
											2007-07-11 12:20:59 +00:00
										 |  |  |             self.assertEqual(n, 2**(k-1)) | 
					
						
							| 
									
										
										
										
											2003-10-05 09:09:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |             n += n - 1      # check 1 below the next power of two | 
					
						
							|  |  |  |             k = int(1.00001 + _log(n, 2)) | 
					
						
							| 
									
										
										
										
											2010-01-19 00:09:57 +00:00
										 |  |  |             self.assertIn(k, [numbits, numbits+1]) | 
					
						
							| 
									
										
										
										
											2009-06-30 23:06:06 +00:00
										 |  |  |             self.assertTrue(2**k > n > 2**(k-2)) | 
					
						
							| 
									
										
										
										
											2003-10-05 09:09:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |             n -= n >> 15     # check a little farther below the next power of two | 
					
						
							|  |  |  |             k = int(1.00001 + _log(n, 2)) | 
					
						
							|  |  |  |             self.assertEqual(k, numbits)        # note the stronger assertion | 
					
						
							| 
									
										
										
										
											2009-06-30 23:06:06 +00:00
										 |  |  |             self.assertTrue(2**k > n > 2**(k-1))   # note the stronger assertion | 
					
						
							| 
									
										
										
										
											2003-10-05 09:09:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-02 12:47:23 -04:00
										 |  |  |     @unittest.mock.patch('random.Random.random') | 
					
						
							|  |  |  |     def test_randbelow_overriden_random(self, random_mock): | 
					
						
							|  |  |  |         # Random._randbelow() can only use random() when the built-in one | 
					
						
							|  |  |  |         # has been overridden but no new getrandbits() method was supplied. | 
					
						
							|  |  |  |         random_mock.side_effect = random.SystemRandom().random | 
					
						
							|  |  |  |         maxsize = 1<<random.BPF | 
					
						
							|  |  |  |         with warnings.catch_warnings(): | 
					
						
							|  |  |  |             warnings.simplefilter("ignore", UserWarning) | 
					
						
							|  |  |  |             # Population range too large (n >= maxsize) | 
					
						
							|  |  |  |             self.gen._randbelow(maxsize+1, maxsize = maxsize) | 
					
						
							|  |  |  |         self.gen._randbelow(5640, maxsize = maxsize) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # This might be going too far to test a single line, but because of our | 
					
						
							|  |  |  |         # noble aim of achieving 100% test coverage we need to write a case in | 
					
						
							|  |  |  |         # which the following line in Random._randbelow() gets executed: | 
					
						
							|  |  |  |         # | 
					
						
							|  |  |  |         # rem = maxsize % n | 
					
						
							|  |  |  |         # limit = (maxsize - rem) / maxsize | 
					
						
							|  |  |  |         # r = random() | 
					
						
							|  |  |  |         # while r >= limit: | 
					
						
							|  |  |  |         #     r = random() # <== *This line* <==< | 
					
						
							|  |  |  |         # | 
					
						
							|  |  |  |         # Therefore, to guarantee that the while loop is executed at least | 
					
						
							|  |  |  |         # once, we need to mock random() so that it returns a number greater | 
					
						
							|  |  |  |         # than 'limit' the first time it gets called. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         n = 42 | 
					
						
							|  |  |  |         epsilon = 0.01 | 
					
						
							|  |  |  |         limit = (maxsize - (maxsize % n)) / maxsize | 
					
						
							|  |  |  |         random_mock.side_effect = [limit + epsilon, limit - epsilon] | 
					
						
							|  |  |  |         self.gen._randbelow(n, maxsize = maxsize) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 53005-53303 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r53012 | walter.doerwald | 2006-12-12 22:55:31 +0100 (Tue, 12 Dec 2006) | 2 lines
  Fix typo.
........
  r53023 | brett.cannon | 2006-12-13 23:31:37 +0100 (Wed, 13 Dec 2006) | 2 lines
  Remove an unneeded import of 'warnings'.
........
  r53025 | brett.cannon | 2006-12-14 00:02:38 +0100 (Thu, 14 Dec 2006) | 2 lines
  Remove unneeded imports of 'warnings'.
........
  r53026 | brett.cannon | 2006-12-14 00:09:53 +0100 (Thu, 14 Dec 2006) | 4 lines
  Add test.test_support.guard_warnings_filter .  This function returns a context
  manager that protects warnings.filter from being modified once the context is
  exited.
........
  r53029 | george.yoshida | 2006-12-14 03:22:44 +0100 (Thu, 14 Dec 2006) | 2 lines
  Note that guard_warnings_filter was added in 2.6
........
  r53031 | vinay.sajip | 2006-12-14 09:53:55 +0100 (Thu, 14 Dec 2006) | 1 line
  Added news on recent changes to logging
........
  r53032 | andrew.kuchling | 2006-12-14 19:57:53 +0100 (Thu, 14 Dec 2006) | 1 line
  [Patch #1599256 from David Watson] check that os.fsync is available before using it
........
  r53042 | kurt.kaiser | 2006-12-15 06:13:11 +0100 (Fri, 15 Dec 2006) | 6 lines
  1. Avoid hang when encountering a duplicate in a completion list. Bug 1571112.
  2. Duplicate some old entries from Python's NEWS to IDLE's NEWS.txt
  M    AutoCompleteWindow.py
  M    NEWS.txt
........
  r53048 | andrew.kuchling | 2006-12-18 18:12:31 +0100 (Mon, 18 Dec 2006) | 1 line
  [Bug #1618083] Add missing word; make a few grammar fixes
........
  r53050 | andrew.kuchling | 2006-12-18 18:16:05 +0100 (Mon, 18 Dec 2006) | 1 line
  Bump version
........
  r53051 | andrew.kuchling | 2006-12-18 18:22:07 +0100 (Mon, 18 Dec 2006) | 1 line
  [Bug #1616726] Fix description of generator.close(); if you raise some random exception, the exception is raised and doesn't trigger a RuntimeError
........
  r53052 | andrew.kuchling | 2006-12-18 18:38:14 +0100 (Mon, 18 Dec 2006) | 1 line
  Describe new methods in Queue module
........
  r53053 | andrew.kuchling | 2006-12-18 20:22:24 +0100 (Mon, 18 Dec 2006) | 1 line
  [Patch #1615868 by Lars Gustaebel] Use Py_off_t to fix BZ2File.seek() for offsets > 2Gb
........
  r53057 | andrew.kuchling | 2006-12-18 22:29:07 +0100 (Mon, 18 Dec 2006) | 1 line
  Fix markup
........
  r53063 | thomas.wouters | 2006-12-19 09:17:50 +0100 (Tue, 19 Dec 2006) | 5 lines
  Make sre's SubPattern objects accept slice objects like it already accepts
  simple slices.
........
  r53065 | andrew.kuchling | 2006-12-19 15:13:05 +0100 (Tue, 19 Dec 2006) | 6 lines
  [Patch #1618455 by Ben Maurer] Improve speed of HMAC by using str.translate()
     instead of a more general XOR that has to construct a list.
  Slightly modified from Maurer's patch: the _strxor() function is no longer
  necessary at all.
........
  r53066 | andrew.kuchling | 2006-12-19 15:28:23 +0100 (Tue, 19 Dec 2006) | 9 lines
  [Bug #1613651] Document socket.recv_into, socket.recvfrom_into
  Also, the text for recvfrom told you to read recv() for an explanation of the
  'flags' argument, but recv() just pointed you at the man page.  Copied the
  man-page text to recvfrom(), recvfrom_into, recv_into to avoid the pointless
  redirection.
  I don't have LaTeX on this machine; hope my markup is OK.
........
  r53067 | andrew.kuchling | 2006-12-19 15:29:04 +0100 (Tue, 19 Dec 2006) | 1 line
  Comment typo
........
  r53068 | andrew.kuchling | 2006-12-19 16:11:41 +0100 (Tue, 19 Dec 2006) | 1 line
  [Patch #1617413 from Dug Song] Fix HTTP Basic authentication via HTTPS
........
  r53071 | andrew.kuchling | 2006-12-19 16:18:12 +0100 (Tue, 19 Dec 2006) | 1 line
  [Patch #1600491 from Jim Jewett] Describe how to build help files on Windows
........
  r53073 | andrew.kuchling | 2006-12-19 16:43:10 +0100 (Tue, 19 Dec 2006) | 6 lines
  [Patch #1587139 by kxroberto] Protect lock acquisition/release with
  try...finally to ensure the lock is always released.  This could use
  the 'with' statement, but the patch uses 'finally'.
  2.5 backport candidate.
........
  r53074 | vinay.sajip | 2006-12-19 19:29:11 +0100 (Tue, 19 Dec 2006) | 1 line
  Updated documentation for findCaller() to indicate that a 3-tuple is now returned, rather than a 2-tuple.
........
  r53090 | georg.brandl | 2006-12-19 23:06:46 +0100 (Tue, 19 Dec 2006) | 3 lines
  Patch #1484695: The tarfile module now raises a HeaderError exception
  if a buffer given to frombuf() is invalid.
........
  r53099 | raymond.hettinger | 2006-12-20 07:42:06 +0100 (Wed, 20 Dec 2006) | 5 lines
  Bug #1590891:   random.randrange don't return correct value for big number
  Needs to be backported.
........
  r53106 | georg.brandl | 2006-12-20 12:55:16 +0100 (Wed, 20 Dec 2006) | 3 lines
  Testcase for patch #1484695.
........
  r53110 | andrew.kuchling | 2006-12-20 20:48:20 +0100 (Wed, 20 Dec 2006) | 17 lines
  [Apply length-checking.diff from bug #1599254]
  Add length checking to single-file mailbox formats: before doing a
  flush() on a mailbox, seek to the end and verify its length is
  unchanged, raising ExternalClashError if the file's length has
  changed.
  This fix avoids potential data loss if some other process appends to
  the mailbox file after the table of contents has been generated;
  instead of overwriting the modified file, you'll get the exception.
  I also noticed that the self._lookup() call in self.flush() wasn't
  necessary (everything that sets self._pending to True also calls
  self.lookup()), and replaced it by an assertion.
  2.5 backport candidate.
........
  r53112 | andrew.kuchling | 2006-12-20 20:57:10 +0100 (Wed, 20 Dec 2006) | 1 line
  [Bug #1619674] Make sum() use the term iterable, not sequence
........
  r53113 | andrew.kuchling | 2006-12-20 20:58:11 +0100 (Wed, 20 Dec 2006) | 1 line
  Two grammar fixes
........
  r53115 | andrew.kuchling | 2006-12-20 21:11:12 +0100 (Wed, 20 Dec 2006) | 5 lines
  Some other built-in functions are described with 'sequence' arguments
  that should really be 'iterable'; this commit changes them.
  Did I miss any?  Did I introduce any errors?
........
  r53117 | andrew.kuchling | 2006-12-20 21:20:42 +0100 (Wed, 20 Dec 2006) | 1 line
  [Bug #1619680] in_dll() arguments are documented in the wrong order
........
  r53120 | neal.norwitz | 2006-12-21 05:38:00 +0100 (Thu, 21 Dec 2006) | 1 line
  Lars asked for permission on on python-dev for work on tarfile.py
........
  r53125 | andrew.kuchling | 2006-12-21 14:40:29 +0100 (Thu, 21 Dec 2006) | 1 line
  Mention the os.SEEK_* constants
........
  r53129 | walter.doerwald | 2006-12-21 19:06:30 +0100 (Thu, 21 Dec 2006) | 2 lines
  Fix typo.
........
  r53131 | thomas.heller | 2006-12-21 19:30:56 +0100 (Thu, 21 Dec 2006) | 3 lines
  Fix wrong markup of an argument in a method signature.
  Will backport.
........
  r53137 | andrew.kuchling | 2006-12-22 01:50:56 +0100 (Fri, 22 Dec 2006) | 1 line
  Typo fix
........
  r53139 | andrew.kuchling | 2006-12-22 14:25:02 +0100 (Fri, 22 Dec 2006) | 1 line
  [Bug #737202; fix from Titus Brown] Make CGIHTTPServer work for scripts in sub-directories
........
  r53141 | andrew.kuchling | 2006-12-22 16:04:45 +0100 (Fri, 22 Dec 2006) | 6 lines
  [Bug #802128] Make the mode argument of dumbdbm actually work the way it's
  described, and add a test for it.
  2.5 bugfix candidate, maybe; arguably this patch changes the API of
  dumbdbm and shouldn't be added in a point-release.
........
  r53142 | andrew.kuchling | 2006-12-22 16:16:58 +0100 (Fri, 22 Dec 2006) | 6 lines
  [Bug #802128 continued] Modify mode depending on the process umask.
  Is there really no other way to read the umask than to set it?
  Hope this works on Windows...
........
  r53145 | andrew.kuchling | 2006-12-22 17:43:26 +0100 (Fri, 22 Dec 2006) | 1 line
  [Bug #776202] Apply Walter Doerwald's patch to use text mode for encoded files
........
  r53146 | andrew.kuchling | 2006-12-22 19:41:42 +0100 (Fri, 22 Dec 2006) | 9 lines
  [Patch #783050 from Patrick Lynch] The emulation of forkpty() is incorrect;
  the master should close the slave fd.
  Added a test to test_pty.py that reads from the master_fd after doing
  a pty.fork(); without the fix it hangs forever instead of raising an
  exception.  (<crossing fingers for the buildbots>)
  2.5 backport candidate.
........
  r53147 | andrew.kuchling | 2006-12-22 20:06:16 +0100 (Fri, 22 Dec 2006) | 1 line
  [Patch #827559 from Chris Gonnerman] Make SimpleHTTPServer redirect when a directory URL is missing the trailing slash; this lets relative links work.
........
  r53149 | andrew.kuchling | 2006-12-22 20:21:27 +0100 (Fri, 22 Dec 2006) | 1 line
  Darn; this test works when you run test_pty.py directly, but fails when regrtest runs it (the os.read() raises os.error).  I can't figure out the cause, so am commenting out the test.
........
  r53150 | andrew.kuchling | 2006-12-22 22:48:19 +0100 (Fri, 22 Dec 2006) | 1 line
  Frak; this test also fails
........
  r53153 | lars.gustaebel | 2006-12-23 17:40:13 +0100 (Sat, 23 Dec 2006) | 5 lines
  Patch #1230446: tarfile.py: fix ExFileObject so that read() and tell()
  work correctly together with readline().
  Will backport to 2.5.
........
  r53155 | lars.gustaebel | 2006-12-23 18:57:23 +0100 (Sat, 23 Dec 2006) | 5 lines
  Patch #1262036: Prevent TarFiles from being added to themselves under
  certain conditions.
  Will backport to 2.5.
........
  r53159 | andrew.kuchling | 2006-12-27 04:25:31 +0100 (Wed, 27 Dec 2006) | 4 lines
  [Part of patch #1182394] Move the HMAC blocksize to be a class-level
  constant; this allows changing it in a subclass.  To accommodate this,
  copy() now uses __class__.  Also add some text to a comment.
........
  r53160 | andrew.kuchling | 2006-12-27 04:31:24 +0100 (Wed, 27 Dec 2006) | 1 line
  [Rest of patch #1182394] Add ._current() method so that we can use the written-in-C .hexdigest() method
........
  r53161 | lars.gustaebel | 2006-12-27 11:30:46 +0100 (Wed, 27 Dec 2006) | 4 lines
  Patch #1504073: Fix tarfile.open() for mode "r" with a fileobj argument.
  Will backport to 2.5.
........
  r53165 | neal.norwitz | 2006-12-28 05:39:20 +0100 (Thu, 28 Dec 2006) | 1 line
  Remove a stray (old) macro name left around (I guess)
........
  r53188 | neal.norwitz | 2006-12-29 04:01:53 +0100 (Fri, 29 Dec 2006) | 1 line
  SF bug #1623890, fix argument name in docstring
........
  r53200 | raymond.hettinger | 2006-12-30 05:01:17 +0100 (Sat, 30 Dec 2006) | 1 line
  For sets with cyclical reprs, emit an ellipsis instead of infinitely recursing.
........
  r53232 | brett.cannon | 2007-01-04 01:23:49 +0100 (Thu, 04 Jan 2007) | 3 lines
  Add EnvironmentVarGuard to test.test_support.  Provides a context manager to
  temporarily set or unset environment variables.
........
  r53235 | neal.norwitz | 2007-01-04 07:25:31 +0100 (Thu, 04 Jan 2007) | 1 line
  SF #1627373, fix typo in CarbonEvt.
........
  r53244 | raymond.hettinger | 2007-01-04 18:53:34 +0100 (Thu, 04 Jan 2007) | 1 line
  Fix stability of heapq's nlargest() and nsmallest().
........
  r53249 | martin.v.loewis | 2007-01-04 22:06:12 +0100 (Thu, 04 Jan 2007) | 3 lines
  Bug #1566280: Explicitly invoke threading._shutdown from Py_Main,
  to avoid relying on atexit.
  Will backport to 2.5.
........
  r53252 | gregory.p.smith | 2007-01-05 02:59:42 +0100 (Fri, 05 Jan 2007) | 3 lines
  Support linking of the bsddb module against BerkeleyDB 4.5.x
  (will backport to 2.5)
........
  r53253 | gregory.p.smith | 2007-01-05 03:06:17 +0100 (Fri, 05 Jan 2007) | 2 lines
  bump module version to match supported berkeleydb version
........
  r53255 | neal.norwitz | 2007-01-05 06:25:22 +0100 (Fri, 05 Jan 2007) | 6 lines
  Prevent crash on shutdown which can occur if we are finalizing
  and the module dict has been cleared already and some object
  raises a warning (like in a __del__).
  Will backport.
........
  r53258 | gregory.p.smith | 2007-01-05 08:21:35 +0100 (Fri, 05 Jan 2007) | 2 lines
  typo fix
........
  r53260 | neal.norwitz | 2007-01-05 09:06:43 +0100 (Fri, 05 Jan 2007) | 1 line
  Add Collin Winter for access to update PEP 3107
........
  r53262 | andrew.kuchling | 2007-01-05 15:22:17 +0100 (Fri, 05 Jan 2007) | 1 line
  [Bug #1622533] Make docstrings raw strings because they contain control characters (\0, \1)
........
  r53264 | andrew.kuchling | 2007-01-05 16:51:24 +0100 (Fri, 05 Jan 2007) | 1 line
  [Patch #1520904] Fix bsddb tests to write to the temp directory instead of the Lib/bsddb/test directory
........
  r53279 | brett.cannon | 2007-01-05 22:45:09 +0100 (Fri, 05 Jan 2007) | 3 lines
  Silence a warning from gcc 4.0.1 by specifying a function's parameter list is
  'void' instead of just a set of empty parentheses.
........
  r53285 | raymond.hettinger | 2007-01-06 02:14:41 +0100 (Sat, 06 Jan 2007) | 2 lines
  SF# 1409443:  Expand comment to cover the interaction between f->f_lasti and the PREDICT macros.
........
  r53286 | anthony.baxter | 2007-01-06 05:45:54 +0100 (Sat, 06 Jan 2007) | 1 line
  update to (c) years to include 2007
........
  r53291 | neal.norwitz | 2007-01-06 22:24:35 +0100 (Sat, 06 Jan 2007) | 1 line
  Add Josiah to SF for maintaining asyncore/asynchat
........
  r53293 | peter.astrand | 2007-01-07 09:53:46 +0100 (Sun, 07 Jan 2007) | 1 line
  Re-implemented fix for #1531862 once again, in a way that works with Python 2.2. Fixes bug #1603424.
........
  r53295 | peter.astrand | 2007-01-07 15:34:16 +0100 (Sun, 07 Jan 2007) | 1 line
  Avoid O(N**2) bottleneck in _communicate_(). Fixes #1598181.
........
  r53300 | raymond.hettinger | 2007-01-08 19:09:20 +0100 (Mon, 08 Jan 2007) | 1 line
  Fix zero-length corner case for iterating over a mutating deque.
........
  r53301 | vinay.sajip | 2007-01-08 19:50:32 +0100 (Mon, 08 Jan 2007) | 4 lines
  Bare except clause removed from SMTPHandler.emit(). Now, only ImportError is trapped.
  Bare except clause removed from SocketHandler.createSocket(). Now, only socket.error is trapped.
  (SF #411881)
........
  r53302 | vinay.sajip | 2007-01-08 19:51:46 +0100 (Mon, 08 Jan 2007) | 2 lines
  Bare except clause removed from LogRecord.__init__. Now, only ValueError, TypeError and AttributeError are trapped.
  (SF #411881)
........
  r53303 | vinay.sajip | 2007-01-08 19:52:36 +0100 (Mon, 08 Jan 2007) | 1 line
  Added entries about removal of some bare except clauses from logging.
........
											
										 
											2007-01-09 23:18:33 +00:00
										 |  |  |     def test_randrange_bug_1590891(self): | 
					
						
							|  |  |  |         start = 1000000000000 | 
					
						
							|  |  |  |         stop = -100000000000000000000 | 
					
						
							|  |  |  |         step = -200 | 
					
						
							|  |  |  |         x = self.gen.randrange(start, stop, step) | 
					
						
							| 
									
										
										
										
											2009-06-30 23:06:06 +00:00
										 |  |  |         self.assertTrue(stop < x <= start) | 
					
						
							| 
									
										
											  
											
												Merged revisions 53005-53303 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r53012 | walter.doerwald | 2006-12-12 22:55:31 +0100 (Tue, 12 Dec 2006) | 2 lines
  Fix typo.
........
  r53023 | brett.cannon | 2006-12-13 23:31:37 +0100 (Wed, 13 Dec 2006) | 2 lines
  Remove an unneeded import of 'warnings'.
........
  r53025 | brett.cannon | 2006-12-14 00:02:38 +0100 (Thu, 14 Dec 2006) | 2 lines
  Remove unneeded imports of 'warnings'.
........
  r53026 | brett.cannon | 2006-12-14 00:09:53 +0100 (Thu, 14 Dec 2006) | 4 lines
  Add test.test_support.guard_warnings_filter .  This function returns a context
  manager that protects warnings.filter from being modified once the context is
  exited.
........
  r53029 | george.yoshida | 2006-12-14 03:22:44 +0100 (Thu, 14 Dec 2006) | 2 lines
  Note that guard_warnings_filter was added in 2.6
........
  r53031 | vinay.sajip | 2006-12-14 09:53:55 +0100 (Thu, 14 Dec 2006) | 1 line
  Added news on recent changes to logging
........
  r53032 | andrew.kuchling | 2006-12-14 19:57:53 +0100 (Thu, 14 Dec 2006) | 1 line
  [Patch #1599256 from David Watson] check that os.fsync is available before using it
........
  r53042 | kurt.kaiser | 2006-12-15 06:13:11 +0100 (Fri, 15 Dec 2006) | 6 lines
  1. Avoid hang when encountering a duplicate in a completion list. Bug 1571112.
  2. Duplicate some old entries from Python's NEWS to IDLE's NEWS.txt
  M    AutoCompleteWindow.py
  M    NEWS.txt
........
  r53048 | andrew.kuchling | 2006-12-18 18:12:31 +0100 (Mon, 18 Dec 2006) | 1 line
  [Bug #1618083] Add missing word; make a few grammar fixes
........
  r53050 | andrew.kuchling | 2006-12-18 18:16:05 +0100 (Mon, 18 Dec 2006) | 1 line
  Bump version
........
  r53051 | andrew.kuchling | 2006-12-18 18:22:07 +0100 (Mon, 18 Dec 2006) | 1 line
  [Bug #1616726] Fix description of generator.close(); if you raise some random exception, the exception is raised and doesn't trigger a RuntimeError
........
  r53052 | andrew.kuchling | 2006-12-18 18:38:14 +0100 (Mon, 18 Dec 2006) | 1 line
  Describe new methods in Queue module
........
  r53053 | andrew.kuchling | 2006-12-18 20:22:24 +0100 (Mon, 18 Dec 2006) | 1 line
  [Patch #1615868 by Lars Gustaebel] Use Py_off_t to fix BZ2File.seek() for offsets > 2Gb
........
  r53057 | andrew.kuchling | 2006-12-18 22:29:07 +0100 (Mon, 18 Dec 2006) | 1 line
  Fix markup
........
  r53063 | thomas.wouters | 2006-12-19 09:17:50 +0100 (Tue, 19 Dec 2006) | 5 lines
  Make sre's SubPattern objects accept slice objects like it already accepts
  simple slices.
........
  r53065 | andrew.kuchling | 2006-12-19 15:13:05 +0100 (Tue, 19 Dec 2006) | 6 lines
  [Patch #1618455 by Ben Maurer] Improve speed of HMAC by using str.translate()
     instead of a more general XOR that has to construct a list.
  Slightly modified from Maurer's patch: the _strxor() function is no longer
  necessary at all.
........
  r53066 | andrew.kuchling | 2006-12-19 15:28:23 +0100 (Tue, 19 Dec 2006) | 9 lines
  [Bug #1613651] Document socket.recv_into, socket.recvfrom_into
  Also, the text for recvfrom told you to read recv() for an explanation of the
  'flags' argument, but recv() just pointed you at the man page.  Copied the
  man-page text to recvfrom(), recvfrom_into, recv_into to avoid the pointless
  redirection.
  I don't have LaTeX on this machine; hope my markup is OK.
........
  r53067 | andrew.kuchling | 2006-12-19 15:29:04 +0100 (Tue, 19 Dec 2006) | 1 line
  Comment typo
........
  r53068 | andrew.kuchling | 2006-12-19 16:11:41 +0100 (Tue, 19 Dec 2006) | 1 line
  [Patch #1617413 from Dug Song] Fix HTTP Basic authentication via HTTPS
........
  r53071 | andrew.kuchling | 2006-12-19 16:18:12 +0100 (Tue, 19 Dec 2006) | 1 line
  [Patch #1600491 from Jim Jewett] Describe how to build help files on Windows
........
  r53073 | andrew.kuchling | 2006-12-19 16:43:10 +0100 (Tue, 19 Dec 2006) | 6 lines
  [Patch #1587139 by kxroberto] Protect lock acquisition/release with
  try...finally to ensure the lock is always released.  This could use
  the 'with' statement, but the patch uses 'finally'.
  2.5 backport candidate.
........
  r53074 | vinay.sajip | 2006-12-19 19:29:11 +0100 (Tue, 19 Dec 2006) | 1 line
  Updated documentation for findCaller() to indicate that a 3-tuple is now returned, rather than a 2-tuple.
........
  r53090 | georg.brandl | 2006-12-19 23:06:46 +0100 (Tue, 19 Dec 2006) | 3 lines
  Patch #1484695: The tarfile module now raises a HeaderError exception
  if a buffer given to frombuf() is invalid.
........
  r53099 | raymond.hettinger | 2006-12-20 07:42:06 +0100 (Wed, 20 Dec 2006) | 5 lines
  Bug #1590891:   random.randrange don't return correct value for big number
  Needs to be backported.
........
  r53106 | georg.brandl | 2006-12-20 12:55:16 +0100 (Wed, 20 Dec 2006) | 3 lines
  Testcase for patch #1484695.
........
  r53110 | andrew.kuchling | 2006-12-20 20:48:20 +0100 (Wed, 20 Dec 2006) | 17 lines
  [Apply length-checking.diff from bug #1599254]
  Add length checking to single-file mailbox formats: before doing a
  flush() on a mailbox, seek to the end and verify its length is
  unchanged, raising ExternalClashError if the file's length has
  changed.
  This fix avoids potential data loss if some other process appends to
  the mailbox file after the table of contents has been generated;
  instead of overwriting the modified file, you'll get the exception.
  I also noticed that the self._lookup() call in self.flush() wasn't
  necessary (everything that sets self._pending to True also calls
  self.lookup()), and replaced it by an assertion.
  2.5 backport candidate.
........
  r53112 | andrew.kuchling | 2006-12-20 20:57:10 +0100 (Wed, 20 Dec 2006) | 1 line
  [Bug #1619674] Make sum() use the term iterable, not sequence
........
  r53113 | andrew.kuchling | 2006-12-20 20:58:11 +0100 (Wed, 20 Dec 2006) | 1 line
  Two grammar fixes
........
  r53115 | andrew.kuchling | 2006-12-20 21:11:12 +0100 (Wed, 20 Dec 2006) | 5 lines
  Some other built-in functions are described with 'sequence' arguments
  that should really be 'iterable'; this commit changes them.
  Did I miss any?  Did I introduce any errors?
........
  r53117 | andrew.kuchling | 2006-12-20 21:20:42 +0100 (Wed, 20 Dec 2006) | 1 line
  [Bug #1619680] in_dll() arguments are documented in the wrong order
........
  r53120 | neal.norwitz | 2006-12-21 05:38:00 +0100 (Thu, 21 Dec 2006) | 1 line
  Lars asked for permission on on python-dev for work on tarfile.py
........
  r53125 | andrew.kuchling | 2006-12-21 14:40:29 +0100 (Thu, 21 Dec 2006) | 1 line
  Mention the os.SEEK_* constants
........
  r53129 | walter.doerwald | 2006-12-21 19:06:30 +0100 (Thu, 21 Dec 2006) | 2 lines
  Fix typo.
........
  r53131 | thomas.heller | 2006-12-21 19:30:56 +0100 (Thu, 21 Dec 2006) | 3 lines
  Fix wrong markup of an argument in a method signature.
  Will backport.
........
  r53137 | andrew.kuchling | 2006-12-22 01:50:56 +0100 (Fri, 22 Dec 2006) | 1 line
  Typo fix
........
  r53139 | andrew.kuchling | 2006-12-22 14:25:02 +0100 (Fri, 22 Dec 2006) | 1 line
  [Bug #737202; fix from Titus Brown] Make CGIHTTPServer work for scripts in sub-directories
........
  r53141 | andrew.kuchling | 2006-12-22 16:04:45 +0100 (Fri, 22 Dec 2006) | 6 lines
  [Bug #802128] Make the mode argument of dumbdbm actually work the way it's
  described, and add a test for it.
  2.5 bugfix candidate, maybe; arguably this patch changes the API of
  dumbdbm and shouldn't be added in a point-release.
........
  r53142 | andrew.kuchling | 2006-12-22 16:16:58 +0100 (Fri, 22 Dec 2006) | 6 lines
  [Bug #802128 continued] Modify mode depending on the process umask.
  Is there really no other way to read the umask than to set it?
  Hope this works on Windows...
........
  r53145 | andrew.kuchling | 2006-12-22 17:43:26 +0100 (Fri, 22 Dec 2006) | 1 line
  [Bug #776202] Apply Walter Doerwald's patch to use text mode for encoded files
........
  r53146 | andrew.kuchling | 2006-12-22 19:41:42 +0100 (Fri, 22 Dec 2006) | 9 lines
  [Patch #783050 from Patrick Lynch] The emulation of forkpty() is incorrect;
  the master should close the slave fd.
  Added a test to test_pty.py that reads from the master_fd after doing
  a pty.fork(); without the fix it hangs forever instead of raising an
  exception.  (<crossing fingers for the buildbots>)
  2.5 backport candidate.
........
  r53147 | andrew.kuchling | 2006-12-22 20:06:16 +0100 (Fri, 22 Dec 2006) | 1 line
  [Patch #827559 from Chris Gonnerman] Make SimpleHTTPServer redirect when a directory URL is missing the trailing slash; this lets relative links work.
........
  r53149 | andrew.kuchling | 2006-12-22 20:21:27 +0100 (Fri, 22 Dec 2006) | 1 line
  Darn; this test works when you run test_pty.py directly, but fails when regrtest runs it (the os.read() raises os.error).  I can't figure out the cause, so am commenting out the test.
........
  r53150 | andrew.kuchling | 2006-12-22 22:48:19 +0100 (Fri, 22 Dec 2006) | 1 line
  Frak; this test also fails
........
  r53153 | lars.gustaebel | 2006-12-23 17:40:13 +0100 (Sat, 23 Dec 2006) | 5 lines
  Patch #1230446: tarfile.py: fix ExFileObject so that read() and tell()
  work correctly together with readline().
  Will backport to 2.5.
........
  r53155 | lars.gustaebel | 2006-12-23 18:57:23 +0100 (Sat, 23 Dec 2006) | 5 lines
  Patch #1262036: Prevent TarFiles from being added to themselves under
  certain conditions.
  Will backport to 2.5.
........
  r53159 | andrew.kuchling | 2006-12-27 04:25:31 +0100 (Wed, 27 Dec 2006) | 4 lines
  [Part of patch #1182394] Move the HMAC blocksize to be a class-level
  constant; this allows changing it in a subclass.  To accommodate this,
  copy() now uses __class__.  Also add some text to a comment.
........
  r53160 | andrew.kuchling | 2006-12-27 04:31:24 +0100 (Wed, 27 Dec 2006) | 1 line
  [Rest of patch #1182394] Add ._current() method so that we can use the written-in-C .hexdigest() method
........
  r53161 | lars.gustaebel | 2006-12-27 11:30:46 +0100 (Wed, 27 Dec 2006) | 4 lines
  Patch #1504073: Fix tarfile.open() for mode "r" with a fileobj argument.
  Will backport to 2.5.
........
  r53165 | neal.norwitz | 2006-12-28 05:39:20 +0100 (Thu, 28 Dec 2006) | 1 line
  Remove a stray (old) macro name left around (I guess)
........
  r53188 | neal.norwitz | 2006-12-29 04:01:53 +0100 (Fri, 29 Dec 2006) | 1 line
  SF bug #1623890, fix argument name in docstring
........
  r53200 | raymond.hettinger | 2006-12-30 05:01:17 +0100 (Sat, 30 Dec 2006) | 1 line
  For sets with cyclical reprs, emit an ellipsis instead of infinitely recursing.
........
  r53232 | brett.cannon | 2007-01-04 01:23:49 +0100 (Thu, 04 Jan 2007) | 3 lines
  Add EnvironmentVarGuard to test.test_support.  Provides a context manager to
  temporarily set or unset environment variables.
........
  r53235 | neal.norwitz | 2007-01-04 07:25:31 +0100 (Thu, 04 Jan 2007) | 1 line
  SF #1627373, fix typo in CarbonEvt.
........
  r53244 | raymond.hettinger | 2007-01-04 18:53:34 +0100 (Thu, 04 Jan 2007) | 1 line
  Fix stability of heapq's nlargest() and nsmallest().
........
  r53249 | martin.v.loewis | 2007-01-04 22:06:12 +0100 (Thu, 04 Jan 2007) | 3 lines
  Bug #1566280: Explicitly invoke threading._shutdown from Py_Main,
  to avoid relying on atexit.
  Will backport to 2.5.
........
  r53252 | gregory.p.smith | 2007-01-05 02:59:42 +0100 (Fri, 05 Jan 2007) | 3 lines
  Support linking of the bsddb module against BerkeleyDB 4.5.x
  (will backport to 2.5)
........
  r53253 | gregory.p.smith | 2007-01-05 03:06:17 +0100 (Fri, 05 Jan 2007) | 2 lines
  bump module version to match supported berkeleydb version
........
  r53255 | neal.norwitz | 2007-01-05 06:25:22 +0100 (Fri, 05 Jan 2007) | 6 lines
  Prevent crash on shutdown which can occur if we are finalizing
  and the module dict has been cleared already and some object
  raises a warning (like in a __del__).
  Will backport.
........
  r53258 | gregory.p.smith | 2007-01-05 08:21:35 +0100 (Fri, 05 Jan 2007) | 2 lines
  typo fix
........
  r53260 | neal.norwitz | 2007-01-05 09:06:43 +0100 (Fri, 05 Jan 2007) | 1 line
  Add Collin Winter for access to update PEP 3107
........
  r53262 | andrew.kuchling | 2007-01-05 15:22:17 +0100 (Fri, 05 Jan 2007) | 1 line
  [Bug #1622533] Make docstrings raw strings because they contain control characters (\0, \1)
........
  r53264 | andrew.kuchling | 2007-01-05 16:51:24 +0100 (Fri, 05 Jan 2007) | 1 line
  [Patch #1520904] Fix bsddb tests to write to the temp directory instead of the Lib/bsddb/test directory
........
  r53279 | brett.cannon | 2007-01-05 22:45:09 +0100 (Fri, 05 Jan 2007) | 3 lines
  Silence a warning from gcc 4.0.1 by specifying a function's parameter list is
  'void' instead of just a set of empty parentheses.
........
  r53285 | raymond.hettinger | 2007-01-06 02:14:41 +0100 (Sat, 06 Jan 2007) | 2 lines
  SF# 1409443:  Expand comment to cover the interaction between f->f_lasti and the PREDICT macros.
........
  r53286 | anthony.baxter | 2007-01-06 05:45:54 +0100 (Sat, 06 Jan 2007) | 1 line
  update to (c) years to include 2007
........
  r53291 | neal.norwitz | 2007-01-06 22:24:35 +0100 (Sat, 06 Jan 2007) | 1 line
  Add Josiah to SF for maintaining asyncore/asynchat
........
  r53293 | peter.astrand | 2007-01-07 09:53:46 +0100 (Sun, 07 Jan 2007) | 1 line
  Re-implemented fix for #1531862 once again, in a way that works with Python 2.2. Fixes bug #1603424.
........
  r53295 | peter.astrand | 2007-01-07 15:34:16 +0100 (Sun, 07 Jan 2007) | 1 line
  Avoid O(N**2) bottleneck in _communicate_(). Fixes #1598181.
........
  r53300 | raymond.hettinger | 2007-01-08 19:09:20 +0100 (Mon, 08 Jan 2007) | 1 line
  Fix zero-length corner case for iterating over a mutating deque.
........
  r53301 | vinay.sajip | 2007-01-08 19:50:32 +0100 (Mon, 08 Jan 2007) | 4 lines
  Bare except clause removed from SMTPHandler.emit(). Now, only ImportError is trapped.
  Bare except clause removed from SocketHandler.createSocket(). Now, only socket.error is trapped.
  (SF #411881)
........
  r53302 | vinay.sajip | 2007-01-08 19:51:46 +0100 (Mon, 08 Jan 2007) | 2 lines
  Bare except clause removed from LogRecord.__init__. Now, only ValueError, TypeError and AttributeError are trapped.
  (SF #411881)
........
  r53303 | vinay.sajip | 2007-01-08 19:52:36 +0100 (Mon, 08 Jan 2007) | 1 line
  Added entries about removal of some bare except clauses from logging.
........
											
										 
											2007-01-09 23:18:33 +00:00
										 |  |  |         self.assertEqual((x+stop)%step, 0) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-19 09:53:18 +00:00
										 |  |  | def gamma(z, sqrt2pi=(2.0*pi)**0.5): | 
					
						
							|  |  |  |     # Reflection to right half of complex plane | 
					
						
							|  |  |  |     if z < 0.5: | 
					
						
							|  |  |  |         return pi / sin(pi*z) / gamma(1.0-z) | 
					
						
							|  |  |  |     # Lanczos approximation with g=7 | 
					
						
							|  |  |  |     az = z + (7.0 - 0.5) | 
					
						
							|  |  |  |     return az ** (z-0.5) / exp(az) * sqrt2pi * fsum([ | 
					
						
							|  |  |  |         0.9999999999995183, | 
					
						
							|  |  |  |         676.5203681218835 / z, | 
					
						
							|  |  |  |         -1259.139216722289 / (z+1.0), | 
					
						
							|  |  |  |         771.3234287757674 / (z+2.0), | 
					
						
							|  |  |  |         -176.6150291498386 / (z+3.0), | 
					
						
							|  |  |  |         12.50734324009056 / (z+4.0), | 
					
						
							|  |  |  |         -0.1385710331296526 / (z+5.0), | 
					
						
							|  |  |  |         0.9934937113930748e-05 / (z+6.0), | 
					
						
							|  |  |  |         0.1659470187408462e-06 / (z+7.0), | 
					
						
							|  |  |  |     ]) | 
					
						
							| 
									
										
										
										
											2003-01-05 09:20:06 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-01-05 01:08:34 +00:00
										 |  |  | class TestDistributions(unittest.TestCase): | 
					
						
							|  |  |  |     def test_zeroinputs(self): | 
					
						
							|  |  |  |         # Verify that distributions can handle a series of zero inputs' | 
					
						
							|  |  |  |         g = random.Random() | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |         x = [g.random() for i in range(50)] + [0.0]*5 | 
					
						
							| 
									
										
										
										
											2003-01-05 01:08:34 +00:00
										 |  |  |         g.random = x[:].pop; g.uniform(1,10) | 
					
						
							|  |  |  |         g.random = x[:].pop; g.paretovariate(1.0) | 
					
						
							|  |  |  |         g.random = x[:].pop; g.expovariate(1.0) | 
					
						
							|  |  |  |         g.random = x[:].pop; g.weibullvariate(1.0, 1.0) | 
					
						
							| 
									
										
										
										
											2013-02-10 19:28:56 +02:00
										 |  |  |         g.random = x[:].pop; g.vonmisesvariate(1.0, 1.0) | 
					
						
							| 
									
										
										
										
											2003-01-05 01:08:34 +00:00
										 |  |  |         g.random = x[:].pop; g.normalvariate(0.0, 1.0) | 
					
						
							|  |  |  |         g.random = x[:].pop; g.gauss(0.0, 1.0) | 
					
						
							|  |  |  |         g.random = x[:].pop; g.lognormvariate(0.0, 1.0) | 
					
						
							|  |  |  |         g.random = x[:].pop; g.vonmisesvariate(0.0, 1.0) | 
					
						
							|  |  |  |         g.random = x[:].pop; g.gammavariate(0.01, 1.0) | 
					
						
							|  |  |  |         g.random = x[:].pop; g.gammavariate(1.0, 1.0) | 
					
						
							|  |  |  |         g.random = x[:].pop; g.gammavariate(200.0, 1.0) | 
					
						
							|  |  |  |         g.random = x[:].pop; g.betavariate(3.0, 3.0) | 
					
						
							| 
									
										
											  
											
												Merged revisions 61724-61725,61731-61735,61737,61739,61741,61743-61744,61753,61761,61765-61767,61769,61773,61776-61778,61780-61783,61788,61793,61796,61807,61813 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
................
  r61724 | martin.v.loewis | 2008-03-22 01:01:12 +0100 (Sat, 22 Mar 2008) | 49 lines
  Merged revisions 61602-61723 via svnmerge from
  svn+ssh://pythondev@svn.python.org/sandbox/trunk/2to3/lib2to3
  ........
    r61626 | david.wolever | 2008-03-19 17:19:16 +0100 (Mi, 19 M?\195?\164r 2008) | 1 line
    Added fixer for implicit local imports.  See #2414.
  ........
    r61628 | david.wolever | 2008-03-19 17:57:43 +0100 (Mi, 19 M?\195?\164r 2008) | 1 line
    Added a class for tests which should not run if a particular import is found.
  ........
    r61629 | collin.winter | 2008-03-19 17:58:19 +0100 (Mi, 19 M?\195?\164r 2008) | 1 line
    Two more relative import fixes in pgen2.
  ........
    r61635 | david.wolever | 2008-03-19 20:16:03 +0100 (Mi, 19 M?\195?\164r 2008) | 1 line
    Fixed print fixer so it will do the Right Thing when it encounters __future__.print_function.  2to3 gets upset, though, so the tests have been commented out.
  ........
    r61637 | david.wolever | 2008-03-19 21:37:17 +0100 (Mi, 19 M?\195?\164r 2008) | 3 lines
    Added a fixer for itertools imports (from itertools import imap, ifilterfalse --> from itertools import filterfalse)
  ........
    r61645 | david.wolever | 2008-03-19 23:22:35 +0100 (Mi, 19 M?\195?\164r 2008) | 1 line
    SVN is happier when you add the files you create... -_-'
  ........
    r61654 | david.wolever | 2008-03-20 01:09:56 +0100 (Do, 20 M?\195?\164r 2008) | 1 line
    Added an explicit sort order to fixers -- fixes problems like #2427
  ........
    r61664 | david.wolever | 2008-03-20 04:32:40 +0100 (Do, 20 M?\195?\164r 2008) | 3 lines
    Fixes #2428 -- comments are no longer eatten by __future__ fixer.
  ........
    r61673 | david.wolever | 2008-03-20 17:22:40 +0100 (Do, 20 M?\195?\164r 2008) | 1 line
    Added 2to3 node pretty-printer
  ........
    r61679 | david.wolever | 2008-03-20 20:50:42 +0100 (Do, 20 M?\195?\164r 2008) | 1 line
    Made node printing a little bit prettier
  ........
    r61723 | martin.v.loewis | 2008-03-22 00:59:27 +0100 (Sa, 22 M?\195?\164r 2008) | 2 lines
    Fix whitespace.
  ........
................
  r61725 | martin.v.loewis | 2008-03-22 01:02:41 +0100 (Sat, 22 Mar 2008) | 2 lines
  Install lib2to3.
................
  r61731 | facundo.batista | 2008-03-22 03:45:37 +0100 (Sat, 22 Mar 2008) | 4 lines
  Small fix that complicated the test actually when that
  test failed.
................
  r61732 | alexandre.vassalotti | 2008-03-22 05:08:44 +0100 (Sat, 22 Mar 2008) | 2 lines
  Added warning for the removal of 'hotshot' in Py3k.
................
  r61733 | georg.brandl | 2008-03-22 11:07:29 +0100 (Sat, 22 Mar 2008) | 4 lines
  #1918: document that weak references *to* an object are
  cleared before the object's __del__ is called, to ensure that the weak
  reference callback (if any) finds the object healthy.
................
  r61734 | georg.brandl | 2008-03-22 11:56:23 +0100 (Sat, 22 Mar 2008) | 2 lines
  Activate the Sphinx doctest extension and convert howto/functional to use it.
................
  r61735 | georg.brandl | 2008-03-22 11:58:38 +0100 (Sat, 22 Mar 2008) | 2 lines
  Allow giving source names on the cmdline.
................
  r61737 | georg.brandl | 2008-03-22 12:00:48 +0100 (Sat, 22 Mar 2008) | 2 lines
  Fixup this HOWTO's doctest blocks so that they can be run with sphinx' doctest builder.
................
  r61739 | georg.brandl | 2008-03-22 12:47:10 +0100 (Sat, 22 Mar 2008) | 2 lines
  Test decimal.rst doctests as far as possible with sphinx doctest.
................
  r61741 | georg.brandl | 2008-03-22 13:04:26 +0100 (Sat, 22 Mar 2008) | 2 lines
  Make doctests in re docs usable with sphinx' doctest.
................
  r61743 | georg.brandl | 2008-03-22 13:59:37 +0100 (Sat, 22 Mar 2008) | 2 lines
  Make more doctests in pprint docs testable.
................
  r61744 | georg.brandl | 2008-03-22 14:07:06 +0100 (Sat, 22 Mar 2008) | 2 lines
  No need to specify explicit "doctest_block" anymore.
................
  r61753 | georg.brandl | 2008-03-22 21:08:43 +0100 (Sat, 22 Mar 2008) | 2 lines
  Fix-up syntax problems.
................
  r61761 | georg.brandl | 2008-03-22 22:06:20 +0100 (Sat, 22 Mar 2008) | 4 lines
  Make collections' doctests executable.
  (The <BLANKLINE>s will be stripped from presentation output.)
................
  r61765 | georg.brandl | 2008-03-22 22:21:57 +0100 (Sat, 22 Mar 2008) | 2 lines
  Test doctests in datetime docs.
................
  r61766 | georg.brandl | 2008-03-22 22:26:44 +0100 (Sat, 22 Mar 2008) | 2 lines
  Test doctests in operator docs.
................
  r61767 | georg.brandl | 2008-03-22 22:38:33 +0100 (Sat, 22 Mar 2008) | 2 lines
  Enable doctests in functions.rst.  Already found two errors :)
................
  r61769 | georg.brandl | 2008-03-22 23:04:10 +0100 (Sat, 22 Mar 2008) | 3 lines
  Enable doctest running for several other documents.
  We have now over 640 doctests that are run with "make doctest".
................
  r61773 | raymond.hettinger | 2008-03-23 01:55:46 +0100 (Sun, 23 Mar 2008) | 1 line
  Simplify demo code.
................
  r61776 | neal.norwitz | 2008-03-23 04:43:33 +0100 (Sun, 23 Mar 2008) | 7 lines
  Try to make this test a little more robust and not fail with:
    timeout (10.0025) is more than 2 seconds more than expected (0.001)
  I'm assuming this problem is caused by DNS lookup.  This change
  does a DNS lookup of the hostname before trying to connect, so the time
  is not included.
................
  r61777 | neal.norwitz | 2008-03-23 05:08:30 +0100 (Sun, 23 Mar 2008) | 1 line
  Speed up the test by avoiding socket timeouts.
................
  r61778 | neal.norwitz | 2008-03-23 05:43:09 +0100 (Sun, 23 Mar 2008) | 1 line
  Skip the epoll test if epoll() does not work
................
  r61780 | neal.norwitz | 2008-03-23 06:47:20 +0100 (Sun, 23 Mar 2008) | 1 line
  Suppress failure (to avoid a flaky test) if we cannot connect to svn.python.org
................
  r61781 | neal.norwitz | 2008-03-23 07:13:25 +0100 (Sun, 23 Mar 2008) | 4 lines
  Move itertools before future_builtins since the latter depends on the former.
  From a clean build importing future_builtins would fail since itertools
  wasn't built yet.
................
  r61782 | neal.norwitz | 2008-03-23 07:16:04 +0100 (Sun, 23 Mar 2008) | 1 line
  Try to prevent the alarm going off early in tearDown
................
  r61783 | neal.norwitz | 2008-03-23 07:19:57 +0100 (Sun, 23 Mar 2008) | 4 lines
  Remove compiler warnings (on Alpha at least) about using chars as
  array subscripts.  Using chars are dangerous b/c they are signed
  on some platforms and unsigned on others.
................
  r61788 | georg.brandl | 2008-03-23 09:05:30 +0100 (Sun, 23 Mar 2008) | 2 lines
  Make the doctests presentation-friendlier.
................
  r61793 | amaury.forgeotdarc | 2008-03-23 10:55:29 +0100 (Sun, 23 Mar 2008) | 4 lines
  #1477: ur'\U0010FFFF' raised in narrow unicode builds.
  Corrected the raw-unicode-escape codec to use UTF-16 surrogates in
  this case, just like the unicode-escape codec.
................
  r61796 | raymond.hettinger | 2008-03-23 14:32:32 +0100 (Sun, 23 Mar 2008) | 1 line
  Issue 1681432:  Add triangular distribution the random module.
................
  r61807 | raymond.hettinger | 2008-03-23 20:37:53 +0100 (Sun, 23 Mar 2008) | 4 lines
  Adopt Nick's suggestion for useful default arguments.
  Clean-up floating point issues by adding true division and float constants.
................
  r61813 | gregory.p.smith | 2008-03-23 22:04:43 +0100 (Sun, 23 Mar 2008) | 6 lines
  Fix gzip to deal with CRC's being signed values in Python 2.x properly and to
  read 32bit values as unsigned to start with rather than applying signedness
  fixups allover the place afterwards.
  This hopefully fixes the test_tarfile failure on the alpha/tru64 buildbot.
................
											
										 
											2008-03-23 21:54:12 +00:00
										 |  |  |         g.random = x[:].pop; g.triangular(0.0, 1.0, 1.0/3.0) | 
					
						
							| 
									
										
										
										
											2003-01-05 01:08:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-01-05 09:20:06 +00:00
										 |  |  |     def test_avg_std(self): | 
					
						
							|  |  |  |         # Use integration to test distribution average and standard deviation. | 
					
						
							|  |  |  |         # Only works for distributions which do not consume variates in pairs | 
					
						
							|  |  |  |         g = random.Random() | 
					
						
							|  |  |  |         N = 5000 | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |         x = [i/float(N) for i in range(1,N)] | 
					
						
							| 
									
										
										
										
											2003-01-05 09:20:06 +00:00
										 |  |  |         for variate, args, mu, sigmasqrd in [ | 
					
						
							|  |  |  |                 (g.uniform, (1.0,10.0), (10.0+1.0)/2, (10.0-1.0)**2/12), | 
					
						
							| 
									
										
											  
											
												Merged revisions 61724-61725,61731-61735,61737,61739,61741,61743-61744,61753,61761,61765-61767,61769,61773,61776-61778,61780-61783,61788,61793,61796,61807,61813 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
................
  r61724 | martin.v.loewis | 2008-03-22 01:01:12 +0100 (Sat, 22 Mar 2008) | 49 lines
  Merged revisions 61602-61723 via svnmerge from
  svn+ssh://pythondev@svn.python.org/sandbox/trunk/2to3/lib2to3
  ........
    r61626 | david.wolever | 2008-03-19 17:19:16 +0100 (Mi, 19 M?\195?\164r 2008) | 1 line
    Added fixer for implicit local imports.  See #2414.
  ........
    r61628 | david.wolever | 2008-03-19 17:57:43 +0100 (Mi, 19 M?\195?\164r 2008) | 1 line
    Added a class for tests which should not run if a particular import is found.
  ........
    r61629 | collin.winter | 2008-03-19 17:58:19 +0100 (Mi, 19 M?\195?\164r 2008) | 1 line
    Two more relative import fixes in pgen2.
  ........
    r61635 | david.wolever | 2008-03-19 20:16:03 +0100 (Mi, 19 M?\195?\164r 2008) | 1 line
    Fixed print fixer so it will do the Right Thing when it encounters __future__.print_function.  2to3 gets upset, though, so the tests have been commented out.
  ........
    r61637 | david.wolever | 2008-03-19 21:37:17 +0100 (Mi, 19 M?\195?\164r 2008) | 3 lines
    Added a fixer for itertools imports (from itertools import imap, ifilterfalse --> from itertools import filterfalse)
  ........
    r61645 | david.wolever | 2008-03-19 23:22:35 +0100 (Mi, 19 M?\195?\164r 2008) | 1 line
    SVN is happier when you add the files you create... -_-'
  ........
    r61654 | david.wolever | 2008-03-20 01:09:56 +0100 (Do, 20 M?\195?\164r 2008) | 1 line
    Added an explicit sort order to fixers -- fixes problems like #2427
  ........
    r61664 | david.wolever | 2008-03-20 04:32:40 +0100 (Do, 20 M?\195?\164r 2008) | 3 lines
    Fixes #2428 -- comments are no longer eatten by __future__ fixer.
  ........
    r61673 | david.wolever | 2008-03-20 17:22:40 +0100 (Do, 20 M?\195?\164r 2008) | 1 line
    Added 2to3 node pretty-printer
  ........
    r61679 | david.wolever | 2008-03-20 20:50:42 +0100 (Do, 20 M?\195?\164r 2008) | 1 line
    Made node printing a little bit prettier
  ........
    r61723 | martin.v.loewis | 2008-03-22 00:59:27 +0100 (Sa, 22 M?\195?\164r 2008) | 2 lines
    Fix whitespace.
  ........
................
  r61725 | martin.v.loewis | 2008-03-22 01:02:41 +0100 (Sat, 22 Mar 2008) | 2 lines
  Install lib2to3.
................
  r61731 | facundo.batista | 2008-03-22 03:45:37 +0100 (Sat, 22 Mar 2008) | 4 lines
  Small fix that complicated the test actually when that
  test failed.
................
  r61732 | alexandre.vassalotti | 2008-03-22 05:08:44 +0100 (Sat, 22 Mar 2008) | 2 lines
  Added warning for the removal of 'hotshot' in Py3k.
................
  r61733 | georg.brandl | 2008-03-22 11:07:29 +0100 (Sat, 22 Mar 2008) | 4 lines
  #1918: document that weak references *to* an object are
  cleared before the object's __del__ is called, to ensure that the weak
  reference callback (if any) finds the object healthy.
................
  r61734 | georg.brandl | 2008-03-22 11:56:23 +0100 (Sat, 22 Mar 2008) | 2 lines
  Activate the Sphinx doctest extension and convert howto/functional to use it.
................
  r61735 | georg.brandl | 2008-03-22 11:58:38 +0100 (Sat, 22 Mar 2008) | 2 lines
  Allow giving source names on the cmdline.
................
  r61737 | georg.brandl | 2008-03-22 12:00:48 +0100 (Sat, 22 Mar 2008) | 2 lines
  Fixup this HOWTO's doctest blocks so that they can be run with sphinx' doctest builder.
................
  r61739 | georg.brandl | 2008-03-22 12:47:10 +0100 (Sat, 22 Mar 2008) | 2 lines
  Test decimal.rst doctests as far as possible with sphinx doctest.
................
  r61741 | georg.brandl | 2008-03-22 13:04:26 +0100 (Sat, 22 Mar 2008) | 2 lines
  Make doctests in re docs usable with sphinx' doctest.
................
  r61743 | georg.brandl | 2008-03-22 13:59:37 +0100 (Sat, 22 Mar 2008) | 2 lines
  Make more doctests in pprint docs testable.
................
  r61744 | georg.brandl | 2008-03-22 14:07:06 +0100 (Sat, 22 Mar 2008) | 2 lines
  No need to specify explicit "doctest_block" anymore.
................
  r61753 | georg.brandl | 2008-03-22 21:08:43 +0100 (Sat, 22 Mar 2008) | 2 lines
  Fix-up syntax problems.
................
  r61761 | georg.brandl | 2008-03-22 22:06:20 +0100 (Sat, 22 Mar 2008) | 4 lines
  Make collections' doctests executable.
  (The <BLANKLINE>s will be stripped from presentation output.)
................
  r61765 | georg.brandl | 2008-03-22 22:21:57 +0100 (Sat, 22 Mar 2008) | 2 lines
  Test doctests in datetime docs.
................
  r61766 | georg.brandl | 2008-03-22 22:26:44 +0100 (Sat, 22 Mar 2008) | 2 lines
  Test doctests in operator docs.
................
  r61767 | georg.brandl | 2008-03-22 22:38:33 +0100 (Sat, 22 Mar 2008) | 2 lines
  Enable doctests in functions.rst.  Already found two errors :)
................
  r61769 | georg.brandl | 2008-03-22 23:04:10 +0100 (Sat, 22 Mar 2008) | 3 lines
  Enable doctest running for several other documents.
  We have now over 640 doctests that are run with "make doctest".
................
  r61773 | raymond.hettinger | 2008-03-23 01:55:46 +0100 (Sun, 23 Mar 2008) | 1 line
  Simplify demo code.
................
  r61776 | neal.norwitz | 2008-03-23 04:43:33 +0100 (Sun, 23 Mar 2008) | 7 lines
  Try to make this test a little more robust and not fail with:
    timeout (10.0025) is more than 2 seconds more than expected (0.001)
  I'm assuming this problem is caused by DNS lookup.  This change
  does a DNS lookup of the hostname before trying to connect, so the time
  is not included.
................
  r61777 | neal.norwitz | 2008-03-23 05:08:30 +0100 (Sun, 23 Mar 2008) | 1 line
  Speed up the test by avoiding socket timeouts.
................
  r61778 | neal.norwitz | 2008-03-23 05:43:09 +0100 (Sun, 23 Mar 2008) | 1 line
  Skip the epoll test if epoll() does not work
................
  r61780 | neal.norwitz | 2008-03-23 06:47:20 +0100 (Sun, 23 Mar 2008) | 1 line
  Suppress failure (to avoid a flaky test) if we cannot connect to svn.python.org
................
  r61781 | neal.norwitz | 2008-03-23 07:13:25 +0100 (Sun, 23 Mar 2008) | 4 lines
  Move itertools before future_builtins since the latter depends on the former.
  From a clean build importing future_builtins would fail since itertools
  wasn't built yet.
................
  r61782 | neal.norwitz | 2008-03-23 07:16:04 +0100 (Sun, 23 Mar 2008) | 1 line
  Try to prevent the alarm going off early in tearDown
................
  r61783 | neal.norwitz | 2008-03-23 07:19:57 +0100 (Sun, 23 Mar 2008) | 4 lines
  Remove compiler warnings (on Alpha at least) about using chars as
  array subscripts.  Using chars are dangerous b/c they are signed
  on some platforms and unsigned on others.
................
  r61788 | georg.brandl | 2008-03-23 09:05:30 +0100 (Sun, 23 Mar 2008) | 2 lines
  Make the doctests presentation-friendlier.
................
  r61793 | amaury.forgeotdarc | 2008-03-23 10:55:29 +0100 (Sun, 23 Mar 2008) | 4 lines
  #1477: ur'\U0010FFFF' raised in narrow unicode builds.
  Corrected the raw-unicode-escape codec to use UTF-16 surrogates in
  this case, just like the unicode-escape codec.
................
  r61796 | raymond.hettinger | 2008-03-23 14:32:32 +0100 (Sun, 23 Mar 2008) | 1 line
  Issue 1681432:  Add triangular distribution the random module.
................
  r61807 | raymond.hettinger | 2008-03-23 20:37:53 +0100 (Sun, 23 Mar 2008) | 4 lines
  Adopt Nick's suggestion for useful default arguments.
  Clean-up floating point issues by adding true division and float constants.
................
  r61813 | gregory.p.smith | 2008-03-23 22:04:43 +0100 (Sun, 23 Mar 2008) | 6 lines
  Fix gzip to deal with CRC's being signed values in Python 2.x properly and to
  read 32bit values as unsigned to start with rather than applying signedness
  fixups allover the place afterwards.
  This hopefully fixes the test_tarfile failure on the alpha/tru64 buildbot.
................
											
										 
											2008-03-23 21:54:12 +00:00
										 |  |  |                 (g.triangular, (0.0, 1.0, 1.0/3.0), 4.0/9.0, 7.0/9.0/18.0), | 
					
						
							| 
									
										
										
										
											2003-01-05 09:20:06 +00:00
										 |  |  |                 (g.expovariate, (1.5,), 1/1.5, 1/1.5**2), | 
					
						
							| 
									
										
										
										
											2013-02-10 19:28:56 +02:00
										 |  |  |                 (g.vonmisesvariate, (1.23, 0), pi, pi**2/3), | 
					
						
							| 
									
										
										
										
											2003-01-05 09:20:06 +00:00
										 |  |  |                 (g.paretovariate, (5.0,), 5.0/(5.0-1), | 
					
						
							|  |  |  |                                   5.0/((5.0-1)**2*(5.0-2))), | 
					
						
							|  |  |  |                 (g.weibullvariate, (1.0, 3.0), gamma(1+1/3.0), | 
					
						
							|  |  |  |                                   gamma(1+2/3.0)-gamma(1+1/3.0)**2) ]: | 
					
						
							|  |  |  |             g.random = x[:].pop | 
					
						
							|  |  |  |             y = [] | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |             for i in range(len(x)): | 
					
						
							| 
									
										
										
										
											2003-01-05 09:20:06 +00:00
										 |  |  |                 try: | 
					
						
							|  |  |  |                     y.append(variate(*args)) | 
					
						
							|  |  |  |                 except IndexError: | 
					
						
							|  |  |  |                     pass | 
					
						
							|  |  |  |             s1 = s2 = 0 | 
					
						
							|  |  |  |             for e in y: | 
					
						
							|  |  |  |                 s1 += e | 
					
						
							|  |  |  |                 s2 += (e - mu) ** 2 | 
					
						
							|  |  |  |             N = len(y) | 
					
						
							| 
									
										
										
										
											2013-02-10 19:28:56 +02:00
										 |  |  |             self.assertAlmostEqual(s1/N, mu, places=2, | 
					
						
							|  |  |  |                                    msg='%s%r' % (variate.__name__, args)) | 
					
						
							|  |  |  |             self.assertAlmostEqual(s2/(N-1), sigmasqrd, places=2, | 
					
						
							|  |  |  |                                    msg='%s%r' % (variate.__name__, args)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_constant(self): | 
					
						
							|  |  |  |         g = random.Random() | 
					
						
							|  |  |  |         N = 100 | 
					
						
							|  |  |  |         for variate, args, expected in [ | 
					
						
							|  |  |  |                 (g.uniform, (10.0, 10.0), 10.0), | 
					
						
							|  |  |  |                 (g.triangular, (10.0, 10.0), 10.0), | 
					
						
							| 
									
										
										
										
											2013-04-13 18:00:04 +03:00
										 |  |  |                 #(g.triangular, (10.0, 10.0, 10.0), 10.0), | 
					
						
							| 
									
										
										
										
											2013-02-10 19:28:56 +02:00
										 |  |  |                 (g.expovariate, (float('inf'),), 0.0), | 
					
						
							|  |  |  |                 (g.vonmisesvariate, (3.0, float('inf')), 3.0), | 
					
						
							|  |  |  |                 (g.gauss, (10.0, 0.0), 10.0), | 
					
						
							|  |  |  |                 (g.lognormvariate, (0.0, 0.0), 1.0), | 
					
						
							|  |  |  |                 (g.lognormvariate, (-float('inf'), 0.0), 0.0), | 
					
						
							|  |  |  |                 (g.normalvariate, (10.0, 0.0), 10.0), | 
					
						
							|  |  |  |                 (g.paretovariate, (float('inf'),), 1.0), | 
					
						
							|  |  |  |                 (g.weibullvariate, (10.0, float('inf')), 10.0), | 
					
						
							|  |  |  |                 (g.weibullvariate, (0.0, 10.0), 0.0), | 
					
						
							|  |  |  |             ]: | 
					
						
							|  |  |  |             for i in range(N): | 
					
						
							|  |  |  |                 self.assertEqual(variate(*args), expected) | 
					
						
							| 
									
										
										
										
											2003-01-05 09:20:06 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-10 14:16:10 +00:00
										 |  |  |     def test_von_mises_range(self): | 
					
						
							|  |  |  |         # Issue 17149: von mises variates were not consistently in the | 
					
						
							|  |  |  |         # range [0, 2*PI]. | 
					
						
							|  |  |  |         g = random.Random() | 
					
						
							|  |  |  |         N = 100 | 
					
						
							|  |  |  |         for mu in 0.0, 0.1, 3.1, 6.2: | 
					
						
							|  |  |  |             for kappa in 0.0, 2.3, 500.0: | 
					
						
							|  |  |  |                 for _ in range(N): | 
					
						
							|  |  |  |                     sample = g.vonmisesvariate(mu, kappa) | 
					
						
							|  |  |  |                     self.assertTrue( | 
					
						
							|  |  |  |                         0 <= sample <= random.TWOPI, | 
					
						
							|  |  |  |                         msg=("vonmisesvariate({}, {}) produced a result {} out" | 
					
						
							|  |  |  |                              " of range [0, 2*pi]").format(mu, kappa, sample)) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-10 19:28:56 +02:00
										 |  |  |     def test_von_mises_large_kappa(self): | 
					
						
							|  |  |  |         # Issue #17141: vonmisesvariate() was hang for large kappas | 
					
						
							|  |  |  |         random.vonmisesvariate(0, 1e15) | 
					
						
							|  |  |  |         random.vonmisesvariate(0, 1e100) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-02 12:47:23 -04:00
										 |  |  |     def test_gammavariate_errors(self): | 
					
						
							|  |  |  |         # Both alpha and beta must be > 0.0 | 
					
						
							|  |  |  |         self.assertRaises(ValueError, random.gammavariate, -1, 3) | 
					
						
							|  |  |  |         self.assertRaises(ValueError, random.gammavariate, 0, 2) | 
					
						
							|  |  |  |         self.assertRaises(ValueError, random.gammavariate, 2, 0) | 
					
						
							|  |  |  |         self.assertRaises(ValueError, random.gammavariate, 1, -3) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     @unittest.mock.patch('random.Random.random') | 
					
						
							|  |  |  |     def test_gammavariate_full_code_coverage(self, random_mock): | 
					
						
							|  |  |  |         # There are three different possibilities in the current implementation | 
					
						
							|  |  |  |         # of random.gammavariate(), depending on the value of 'alpha'. What we | 
					
						
							|  |  |  |         # are going to do here is to fix the values returned by random() to | 
					
						
							|  |  |  |         # generate test cases that provide 100% line coverage of the method. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # #1: alpha > 1.0: we want the first random number to be outside the | 
					
						
							|  |  |  |         # [1e-7, .9999999] range, so that the continue statement executes | 
					
						
							|  |  |  |         # once. The values of u1 and u2 will be 0.5 and 0.3, respectively. | 
					
						
							|  |  |  |         random_mock.side_effect = [1e-8, 0.5, 0.3] | 
					
						
							|  |  |  |         returned_value = random.gammavariate(1.1, 2.3) | 
					
						
							|  |  |  |         self.assertAlmostEqual(returned_value, 2.53) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # #2: alpha == 1: first random number less than 1e-7 to that the body | 
					
						
							|  |  |  |         # of the while loop executes once. Then random.random() returns 0.45, | 
					
						
							|  |  |  |         # which causes while to stop looping and the algorithm to terminate. | 
					
						
							|  |  |  |         random_mock.side_effect = [1e-8, 0.45] | 
					
						
							|  |  |  |         returned_value = random.gammavariate(1.0, 3.14) | 
					
						
							|  |  |  |         self.assertAlmostEqual(returned_value, 2.507314166123803) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # #3: 0 < alpha < 1. This is the most complex region of code to cover, | 
					
						
							|  |  |  |         # as there are multiple if-else statements. Let's take a look at the | 
					
						
							|  |  |  |         # source code, and determine the values that we need accordingly: | 
					
						
							|  |  |  |         # | 
					
						
							|  |  |  |         # while 1: | 
					
						
							|  |  |  |         #     u = random() | 
					
						
							|  |  |  |         #     b = (_e + alpha)/_e | 
					
						
							|  |  |  |         #     p = b*u | 
					
						
							|  |  |  |         #     if p <= 1.0: # <=== (A) | 
					
						
							|  |  |  |         #         x = p ** (1.0/alpha) | 
					
						
							|  |  |  |         #     else: # <=== (B) | 
					
						
							|  |  |  |         #         x = -_log((b-p)/alpha) | 
					
						
							|  |  |  |         #     u1 = random() | 
					
						
							|  |  |  |         #     if p > 1.0: # <=== (C) | 
					
						
							|  |  |  |         #         if u1 <= x ** (alpha - 1.0): # <=== (D) | 
					
						
							|  |  |  |         #             break | 
					
						
							|  |  |  |         #     elif u1 <= _exp(-x): # <=== (E) | 
					
						
							|  |  |  |         #         break | 
					
						
							|  |  |  |         # return x * beta | 
					
						
							|  |  |  |         # | 
					
						
							|  |  |  |         # First, we want (A) to be True. For that we need that: | 
					
						
							|  |  |  |         # b*random() <= 1.0 | 
					
						
							|  |  |  |         # r1 = random() <= 1.0 / b | 
					
						
							|  |  |  |         # | 
					
						
							|  |  |  |         # We now get to the second if-else branch, and here, since p <= 1.0, | 
					
						
							|  |  |  |         # (C) is False and we take the elif branch, (E). For it to be True, | 
					
						
							|  |  |  |         # so that the break is executed, we need that: | 
					
						
							|  |  |  |         # r2 = random() <= _exp(-x) | 
					
						
							|  |  |  |         # r2 <= _exp(-(p ** (1.0/alpha))) | 
					
						
							|  |  |  |         # r2 <= _exp(-((b*r1) ** (1.0/alpha))) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         _e = random._e | 
					
						
							|  |  |  |         _exp = random._exp | 
					
						
							|  |  |  |         _log = random._log | 
					
						
							|  |  |  |         alpha = 0.35 | 
					
						
							|  |  |  |         beta = 1.45 | 
					
						
							|  |  |  |         b = (_e + alpha)/_e | 
					
						
							|  |  |  |         epsilon = 0.01 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         r1 = 0.8859296441566 # 1.0 / b | 
					
						
							|  |  |  |         r2 = 0.3678794411714 # _exp(-((b*r1) ** (1.0/alpha))) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # These four "random" values result in the following trace: | 
					
						
							|  |  |  |         # (A) True, (E) False --> [next iteration of while] | 
					
						
							|  |  |  |         # (A) True, (E) True --> [while loop breaks] | 
					
						
							|  |  |  |         random_mock.side_effect = [r1, r2 + epsilon, r1, r2] | 
					
						
							|  |  |  |         returned_value = random.gammavariate(alpha, beta) | 
					
						
							|  |  |  |         self.assertAlmostEqual(returned_value, 1.4499999999997544) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # Let's now make (A) be False. If this is the case, when we get to the | 
					
						
							|  |  |  |         # second if-else 'p' is greater than 1, so (C) evaluates to True. We | 
					
						
							|  |  |  |         # now encounter a second if statement, (D), which in order to execute | 
					
						
							|  |  |  |         # must satisfy the following condition: | 
					
						
							|  |  |  |         # r2 <= x ** (alpha - 1.0) | 
					
						
							|  |  |  |         # r2 <= (-_log((b-p)/alpha)) ** (alpha - 1.0) | 
					
						
							|  |  |  |         # r2 <= (-_log((b-(b*r1))/alpha)) ** (alpha - 1.0) | 
					
						
							|  |  |  |         r1 = 0.8959296441566 # (1.0 / b) + epsilon -- so that (A) is False | 
					
						
							|  |  |  |         r2 = 0.9445400408898141 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # And these four values result in the following trace: | 
					
						
							|  |  |  |         # (B) and (C) True, (D) False --> [next iteration of while] | 
					
						
							|  |  |  |         # (B) and (C) True, (D) True [while loop breaks] | 
					
						
							|  |  |  |         random_mock.side_effect = [r1, r2 + epsilon, r1, r2] | 
					
						
							|  |  |  |         returned_value = random.gammavariate(alpha, beta) | 
					
						
							|  |  |  |         self.assertAlmostEqual(returned_value, 1.5830349561760781) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     @unittest.mock.patch('random.Random.gammavariate') | 
					
						
							|  |  |  |     def test_betavariate_return_zero(self, gammavariate_mock): | 
					
						
							|  |  |  |         # betavariate() returns zero when the Gamma distribution | 
					
						
							|  |  |  |         # that it uses internally returns this same value. | 
					
						
							|  |  |  |         gammavariate_mock.return_value = 0.0 | 
					
						
							|  |  |  |         self.assertEqual(0.0, random.betavariate(2.71828, 3.14159)) | 
					
						
							| 
									
										
										
										
											2013-02-10 19:28:56 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  | class TestModule(unittest.TestCase): | 
					
						
							|  |  |  |     def testMagicConstants(self): | 
					
						
							|  |  |  |         self.assertAlmostEqual(random.NV_MAGICCONST, 1.71552776992141) | 
					
						
							|  |  |  |         self.assertAlmostEqual(random.TWOPI, 6.28318530718) | 
					
						
							|  |  |  |         self.assertAlmostEqual(random.LOG4, 1.38629436111989) | 
					
						
							|  |  |  |         self.assertAlmostEqual(random.SG_MAGICCONST, 2.50407739677627) | 
					
						
							| 
									
										
										
										
											2002-05-05 20:40:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  |     def test__all__(self): | 
					
						
							|  |  |  |         # tests validity but not completeness of the __all__ list | 
					
						
							| 
									
										
										
										
											2009-06-30 23:06:06 +00:00
										 |  |  |         self.assertTrue(set(random.__all__) <= set(dir(random))) | 
					
						
							| 
									
										
										
										
											2002-05-05 20:40:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 53451-53537 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r53454 | brett.cannon | 2007-01-15 20:12:08 +0100 (Mon, 15 Jan 2007) | 3 lines
  Add a note for strptime that just because strftime supports some extra
  directive that is not documented that strptime will as well.
........
  r53458 | vinay.sajip | 2007-01-16 10:50:07 +0100 (Tue, 16 Jan 2007) | 1 line
  Updated rotating file handlers to use _open().
........
  r53459 | marc-andre.lemburg | 2007-01-16 14:03:06 +0100 (Tue, 16 Jan 2007) | 2 lines
  Add news items for the recent pybench and platform changes.
........
  r53460 | sjoerd.mullender | 2007-01-16 17:42:38 +0100 (Tue, 16 Jan 2007) | 4 lines
  Fixed ntpath.expandvars to not replace references to non-existing
  variables with nothing.  Also added tests.
  This fixes bug #494589.
........
  r53464 | neal.norwitz | 2007-01-17 07:23:51 +0100 (Wed, 17 Jan 2007) | 1 line
  Give Calvin Spealman access for python-dev summaries.
........
  r53465 | neal.norwitz | 2007-01-17 09:37:26 +0100 (Wed, 17 Jan 2007) | 1 line
  Remove Calvin since he only has access to the website currently.
........
  r53466 | thomas.heller | 2007-01-17 10:40:34 +0100 (Wed, 17 Jan 2007) | 2 lines
  Replace C++ comments with C comments.
........
  r53472 | andrew.kuchling | 2007-01-17 20:55:06 +0100 (Wed, 17 Jan 2007) | 1 line
  [Part of bug #1599254] Add suggestion to Mailbox docs to use Maildir, and warn user to lock/unlock mailboxes when modifying them
........
  r53475 | georg.brandl | 2007-01-17 22:09:04 +0100 (Wed, 17 Jan 2007) | 2 lines
  Bug #1637967: missing //= operator in list.
........
  r53477 | georg.brandl | 2007-01-17 22:19:58 +0100 (Wed, 17 Jan 2007) | 2 lines
  Bug #1629125: fix wrong data type (int -> Py_ssize_t) in PyDict_Next docs.
........
  r53481 | neal.norwitz | 2007-01-18 06:40:58 +0100 (Thu, 18 Jan 2007) | 1 line
  Try reverting part of r53145 that seems to cause the Windows buildbots to fail in test_uu.UUFileTest.test_encode
........
  r53482 | fred.drake | 2007-01-18 06:42:30 +0100 (Thu, 18 Jan 2007) | 1 line
  add missing version entry
........
  r53483 | neal.norwitz | 2007-01-18 07:20:55 +0100 (Thu, 18 Jan 2007) | 7 lines
  This test doesn't pass on Windows.  The cause seems to be that chmod
  doesn't support the same funcationality as on Unix.  I'm not sure if
  this fix is the best (or if it will even work)--it's a test to see
  if the buildbots start passing again.
  It might be better to not even run this test if it's windows (or non-posix).
........
  r53488 | neal.norwitz | 2007-01-19 06:53:33 +0100 (Fri, 19 Jan 2007) | 1 line
  SF #1635217, Fix unbalanced paren
........
  r53489 | martin.v.loewis | 2007-01-19 07:42:22 +0100 (Fri, 19 Jan 2007) | 3 lines
  Prefix AST symbols with _Py_. Fixes #1637022.
  Will backport.
........
  r53497 | martin.v.loewis | 2007-01-19 19:01:38 +0100 (Fri, 19 Jan 2007) | 2 lines
  Add UUIDs for 2.5.1 and 2.5.2
........
  r53499 | raymond.hettinger | 2007-01-19 19:07:18 +0100 (Fri, 19 Jan 2007) | 1 line
  SF# 1635892:  Fix docs for betavariate's input parameters .
........
  r53503 | martin.v.loewis | 2007-01-20 15:05:39 +0100 (Sat, 20 Jan 2007) | 2 lines
  Merge 53501 and 53502 from 25 branch:
  Add /GS- for AMD64 and Itanium builds where missing.
........
  r53504 | walter.doerwald | 2007-01-20 18:28:31 +0100 (Sat, 20 Jan 2007) | 2 lines
  Port test_resource.py to unittest.
........
  r53505 | walter.doerwald | 2007-01-20 19:19:33 +0100 (Sat, 20 Jan 2007) | 2 lines
  Add argument tests an calls of resource.getrusage().
........
  r53506 | walter.doerwald | 2007-01-20 20:03:17 +0100 (Sat, 20 Jan 2007) | 2 lines
  resource.RUSAGE_BOTH might not exist.
........
  r53507 | walter.doerwald | 2007-01-21 00:07:28 +0100 (Sun, 21 Jan 2007) | 2 lines
  Port test_new.py to unittest.
........
  r53508 | martin.v.loewis | 2007-01-21 10:33:07 +0100 (Sun, 21 Jan 2007) | 2 lines
  Patch #1610575: Add support for _Bool to struct.
........
  r53509 | georg.brandl | 2007-01-21 11:28:43 +0100 (Sun, 21 Jan 2007) | 3 lines
  Bug #1486663: don't reject keyword arguments for subclasses of builtin
  types.
........
  r53511 | georg.brandl | 2007-01-21 11:35:10 +0100 (Sun, 21 Jan 2007) | 2 lines
  Patch #1627441: close sockets properly in urllib2.
........
  r53517 | georg.brandl | 2007-01-22 20:40:21 +0100 (Mon, 22 Jan 2007) | 3 lines
  Use new email module names (#1637162, #1637159, #1637157).
........
  r53518 | andrew.kuchling | 2007-01-22 21:26:40 +0100 (Mon, 22 Jan 2007) | 1 line
  Improve pattern used for mbox 'From' lines; add a simple test
........
  r53519 | andrew.kuchling | 2007-01-22 21:27:50 +0100 (Mon, 22 Jan 2007) | 1 line
  Make comment match the code
........
  r53522 | georg.brandl | 2007-01-22 22:10:33 +0100 (Mon, 22 Jan 2007) | 2 lines
  Bug #1249573: fix rfc822.parsedate not accepting a certain date format
........
  r53524 | georg.brandl | 2007-01-22 22:23:41 +0100 (Mon, 22 Jan 2007) | 2 lines
  Bug #1627316: handle error in condition/ignore pdb commands more gracefully.
........
  r53526 | lars.gustaebel | 2007-01-23 12:17:33 +0100 (Tue, 23 Jan 2007) | 4 lines
  Patch #1507247: tarfile.py: use current umask for intermediate
  directories.
........
  r53527 | thomas.wouters | 2007-01-23 14:42:00 +0100 (Tue, 23 Jan 2007) | 13 lines
  SF patch #1630975: Fix crash when replacing sys.stdout in sitecustomize
  When running the interpreter in an environment that would cause it to set
  stdout/stderr/stdin's encoding, having a sitecustomize that would replace
  them with something other than PyFile objects would crash the interpreter.
  Fix it by simply ignoring the encoding-setting for non-files.
  This could do with a test, but I can think of no maintainable and portable
  way to test this bug, short of adding a sitecustomize.py to the buildsystem
  and have it always run with it (hmmm....)
........
  r53528 | thomas.wouters | 2007-01-23 14:50:49 +0100 (Tue, 23 Jan 2007) | 4 lines
  Add news entry about last checkin (oops.)
........
  r53531 | martin.v.loewis | 2007-01-23 22:11:47 +0100 (Tue, 23 Jan 2007) | 4 lines
  Make PyTraceBack_Here use the current thread, not the
  frame's thread state. Fixes #1579370.
  Will backport.
........
  r53535 | brett.cannon | 2007-01-24 00:21:22 +0100 (Wed, 24 Jan 2007) | 5 lines
  Fix crasher for when an object's __del__ creates a new weakref to itself.
  Patch only fixes new-style classes; classic classes still buggy.
  Closes bug #1377858.  Already backported.
........
  r53536 | walter.doerwald | 2007-01-24 01:42:19 +0100 (Wed, 24 Jan 2007) | 2 lines
  Port test_popen.py to unittest.
........
											
										 
											2007-02-01 18:02:27 +00:00
										 |  |  |     def test_random_subclass_with_kwargs(self): | 
					
						
							|  |  |  |         # SF bug #1486663 -- this used to erroneously raise a TypeError | 
					
						
							|  |  |  |         class Subclass(random.Random): | 
					
						
							|  |  |  |             def __init__(self, newarg=None): | 
					
						
							|  |  |  |                 random.Random.__init__(self) | 
					
						
							|  |  |  |         Subclass(newarg=1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-12-29 23:03:38 +00:00
										 |  |  | if __name__ == "__main__": | 
					
						
							| 
									
										
										
										
											2013-04-19 05:45:27 +03:00
										 |  |  |     unittest.main() |