diff options
author | Tim Peters <tim.peters@gmail.com> | 2006-04-01 00:26:53 (GMT) |
---|---|---|
committer | Tim Peters <tim.peters@gmail.com> | 2006-04-01 00:26:53 (GMT) |
commit | c17976e9833f3093adb1019356737e728a24f7c9 (patch) | |
tree | fd8ea78a830d3eb5978bfbe96a72401839c11ac7 /Lib/test/test_random.py | |
parent | 2a9a6b0e86320ba0793051f3050034ae4290c764 (diff) | |
download | cpython-c17976e9833f3093adb1019356737e728a24f7c9.zip cpython-c17976e9833f3093adb1019356737e728a24f7c9.tar.gz cpython-c17976e9833f3093adb1019356737e728a24f7c9.tar.bz2 |
Another crack at bug #1460340: make random.sample(dict)
work, this time by ugly brute force.
Diffstat (limited to 'Lib/test/test_random.py')
-rw-r--r-- | Lib/test/test_random.py | 20 |
1 files changed, 18 insertions, 2 deletions
diff --git a/Lib/test/test_random.py b/Lib/test/test_random.py index c9431b3..bba4c7c 100644 --- a/Lib/test/test_random.py +++ b/Lib/test/test_random.py @@ -93,12 +93,28 @@ class TestBasicOps(unittest.TestCase): self.gen.sample(set(range(20)), 2) self.gen.sample(range(20), 2) self.gen.sample(xrange(20), 2) - self.gen.sample(dict.fromkeys('abcdefghijklmnopqrst'), 2) self.gen.sample(str('abcdefghijklmnopqrst'), 2) self.gen.sample(tuple('abcdefghijklmnopqrst'), 2) + + def test_sample_on_dicts(self): + self.gen.sample(dict.fromkeys('abcdefghijklmnopqrst'), 2) + # SF bug #1460340 -- random.sample can raise KeyError a = dict.fromkeys(range(10)+range(10,100,2)+range(100,110)) - self.gen.sample(a,3) + self.gen.sample(a, 3) + + # A followup to bug #1460340: sampling from a dict could return + # a subset of its keys or of its values, depending on the size of + # the subset requested. + N = 30 + d = dict((i, complex(i, i)) for i in xrange(N)) + for k in xrange(N+1): + samp = self.gen.sample(d, k) + # Verify that we got ints back (keys); the values are complex. + for x in samp: + self.assert_(type(x) is int) + samp.sort() + self.assertEqual(samp, range(N)) def test_gauss(self): # Ensure that the seed() method initializes all the hidden state. In |