mirror of
https://github.com/python/cpython.git
synced 2025-10-09 08:31:26 +00:00
Issue #1512791: In setframerate method of Wave_write, round non-integral
inputs to the nearest integer. Thanks Neil Tallim for the patch.
This commit is contained in:
parent
a62074883b
commit
64a38c0eb5
5 changed files with 21 additions and 3 deletions
|
@ -157,6 +157,10 @@ Wave_write objects, as returned by :func:`.open`, have the following methods:
|
|||
|
||||
Set the frame rate to *n*.
|
||||
|
||||
.. versionchanged:: 3.2
|
||||
A non-integral input to this method is rounded to the nearest
|
||||
integer.
|
||||
|
||||
|
||||
.. method:: Wave_write.setnframes(n)
|
||||
|
||||
|
|
|
@ -22,10 +22,13 @@ class TestWave(unittest.TestCase):
|
|||
except OSError:
|
||||
pass
|
||||
|
||||
def test_it(self):
|
||||
def test_it(self, test_rounding=False):
|
||||
self.f = wave.open(TESTFN, 'wb')
|
||||
self.f.setnchannels(nchannels)
|
||||
self.f.setsampwidth(sampwidth)
|
||||
if test_rounding:
|
||||
self.f.setframerate(framerate - 0.1)
|
||||
else:
|
||||
self.f.setframerate(framerate)
|
||||
self.f.setnframes(nframes)
|
||||
output = b'\0' * nframes * nchannels * sampwidth
|
||||
|
@ -39,6 +42,13 @@ class TestWave(unittest.TestCase):
|
|||
self.assertEqual(nframes, self.f.getnframes())
|
||||
self.assertEqual(self.f.readframes(nframes), output)
|
||||
|
||||
def test_fractional_framerate(self):
|
||||
"""
|
||||
Addresses [ 1512791 ] module wave does no rounding
|
||||
Floating point framerates should be rounded, rather than truncated.
|
||||
"""
|
||||
self.test_it(test_rounding=True)
|
||||
|
||||
def test_issue7681(self):
|
||||
self.f = wave.open(TESTFN, 'wb')
|
||||
self.f.setnchannels(nchannels)
|
||||
|
|
|
@ -355,7 +355,7 @@ class Wave_write:
|
|||
raise Error('cannot change parameters after starting to write')
|
||||
if framerate <= 0:
|
||||
raise Error('bad frame rate')
|
||||
self._framerate = framerate
|
||||
self._framerate = int(round(framerate))
|
||||
|
||||
def getframerate(self):
|
||||
if not self._framerate:
|
||||
|
|
|
@ -792,6 +792,7 @@ Paul Swartz
|
|||
Thenault Sylvain
|
||||
Péter Szabó
|
||||
Arfrever Frehtes Taifersar Arahesis
|
||||
Neil Tallim
|
||||
Geoff Talvola
|
||||
Musashi Tamura
|
||||
William Tanksley
|
||||
|
|
|
@ -132,6 +132,9 @@ Extensions
|
|||
Library
|
||||
-------
|
||||
|
||||
- Issue #1512791: In setframerate() in the wave module, non-integral
|
||||
frame rates are rounded to the nearest integer.
|
||||
|
||||
- Issue #8797: urllib2 does a retry for Basic Authentication failure instead of
|
||||
falling into recursion.
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue