diff --git a/tests/common.py b/tests/common.py index ea3748f2b..e53537471 100644 --- a/tests/common.py +++ b/tests/common.py @@ -173,7 +173,9 @@ def assertIs(self, a, b, msg=None): def assertIsNot(self, a, b, msg=None): if a is b: - self.fail(msg or "both are {!r} at 0x{:x}; {!r}".format(type(a), id(a), a)) + self.fail( + msg or "both are {!r} at 0x{:x}; {!r}".format(type(a), id(a), a) + ) def assertIsNone(self, x, msg=None): if x is not None: @@ -193,7 +195,9 @@ def assertNotIn(self, a, b, msg=None): def assertIsInstance(self, instance, types, msg=None): if not isinstance(instance, types): - self.fail(msg or "not an instance of {!r}; {!r}".format(types, instance)) + self.fail( + msg or "not an instance of {!r}; {!r}".format(types, instance) + ) def assertNotIsInstance(self, instance, types, msg=None): if isinstance(instance, types): diff --git a/tests/requirements.txt b/tests/requirements.txt index 2a321a28d..d3e3ad32c 100644 --- a/tests/requirements.txt +++ b/tests/requirements.txt @@ -1,8 +1,5 @@ -autopep8 Cython -editorconfig flake8 isort numpy -Pillow -sphinx < 4.4 +Pillow \ No newline at end of file diff --git a/tests/test_audiofifo.py b/tests/test_audiofifo.py index f04995b89..30862f2bb 100644 --- a/tests/test_audiofifo.py +++ b/tests/test_audiofifo.py @@ -5,7 +5,6 @@ class TestAudioFifo(TestCase): def test_data(self): - container = av.open(fate_suite("audio-reference/chorusnoise_2ch_44kHz_s16.wav")) stream = container.streams.audio[0] @@ -31,7 +30,6 @@ def test_data(self): self.assertTrue(input_[:min_len] == output[:min_len]) def test_pts_simple(self): - fifo = av.AudioFifo() iframe = av.AudioFrame(samples=1024) @@ -61,7 +59,6 @@ def test_pts_simple(self): self.assertRaises(ValueError, fifo.write, iframe) def test_pts_complex(self): - fifo = av.AudioFifo() iframe = av.AudioFrame(samples=1024) @@ -79,7 +76,6 @@ def test_pts_complex(self): self.assertEqual(fifo.pts_per_sample, 2.0) def test_missing_sample_rate(self): - fifo = av.AudioFifo() iframe = av.AudioFrame(samples=1024) @@ -96,7 +92,6 @@ def test_missing_sample_rate(self): self.assertEqual(oframe.time_base, iframe.time_base) def test_missing_time_base(self): - fifo = av.AudioFifo() iframe = av.AudioFrame(samples=1024) diff --git a/tests/test_audioresampler.py b/tests/test_audioresampler.py index fe1907c14..9b66968c1 100644 --- a/tests/test_audioresampler.py +++ b/tests/test_audioresampler.py @@ -69,7 +69,6 @@ def test_matching_passthrough(self): self.assertEqual(len(oframes), 0) def test_pts_assertion_same_rate(self): - resampler = AudioResampler("s16", "mono") # resample one frame @@ -115,7 +114,6 @@ def test_pts_assertion_same_rate(self): self.assertEqual(len(oframes), 0) def test_pts_assertion_new_rate(self): - resampler = AudioResampler("s16", "mono", 44100) # resample one frame @@ -144,7 +142,6 @@ def test_pts_assertion_new_rate(self): self.assertEqual(oframe.samples, 16) def test_pts_missing_time_base(self): - resampler = AudioResampler("s16", "mono", 44100) # resample one frame diff --git a/tests/test_codec_context.py b/tests/test_codec_context.py index 7a8e4a19b..946f26cc8 100644 --- a/tests/test_codec_context.py +++ b/tests/test_codec_context.py @@ -117,7 +117,6 @@ def test_encoder_pix_fmt(self): self.assertEqual(ctx.pix_fmt, "yuv420p") def test_parse(self): - # This one parses into a single packet. self._assert_parse("mpeg4", fate_suite("h264/interlaced_crop.mp4")) @@ -125,7 +124,6 @@ def test_parse(self): self._assert_parse("mpeg2video", fate_suite("mpeg2/mpeg2_field_encoding.ts")) def _assert_parse(self, codec_name, path): - fh = av.open(path) packets = [] for packet in fh.demux(video=0): @@ -134,7 +132,6 @@ def _assert_parse(self, codec_name, path): full_source = b"".join(bytes(p) for p in packets) for size in 1024, 8192, 65535: - ctx = Codec(codec_name).create() packets = [] @@ -159,7 +156,6 @@ def test_encoding_tiff(self): self.image_sequence_encode("tiff") def image_sequence_encode(self, codec_name): - try: codec = Codec(codec_name, "w") except UnknownCodecError: @@ -184,7 +180,6 @@ def image_sequence_encode(self, codec_name): frame_count = 1 path_list = [] for frame in iter_frames(container, video_stream): - new_frame = frame.reformat(width, height, pix_fmt) new_packets = ctx.encode(new_frame) @@ -246,7 +241,6 @@ def test_encoding_dnxhd(self): self.video_encoding("dnxhd", options) def video_encoding(self, codec_name, options={}, codec_tag=None): - try: codec = Codec(codec_name, "w") except UnknownCodecError: @@ -277,9 +271,7 @@ def video_encoding(self, codec_name, options={}, codec_tag=None): frame_count = 0 with open(path, "wb") as f: - for frame in iter_frames(container, video_stream): - new_frame = frame.reformat(width, height, pix_fmt) # reset the picture type @@ -323,7 +315,6 @@ def test_encoding_mp2(self): self.audio_encoding("mp2") def audio_encoding(self, codec_name): - try: codec = Codec(codec_name, "w") except UnknownCodecError: @@ -358,7 +349,6 @@ def audio_encoding(self, codec_name): with open(path, "wb") as f: for frame in iter_frames(container, audio_stream): - resampled_frames = resampler.resample(frame) for resampled_frame in resampled_frames: samples += resampled_frame.samples diff --git a/tests/test_decode.py b/tests/test_decode.py index 185b7ec8e..564ea24cd 100644 --- a/tests/test_decode.py +++ b/tests/test_decode.py @@ -7,7 +7,6 @@ class TestDecode(TestCase): def test_decoded_video_frame_count(self): - container = av.open(fate_suite("h264/interlaced_crop.mp4")) video_stream = next(s for s in container.streams if s.type == "video") @@ -40,7 +39,6 @@ def test_decode_audio_corrupt(self): self.assertEqual(frame_count, 0) def test_decode_audio_sample_count(self): - container = av.open(fate_suite("audio-reference/chorusnoise_2ch_44kHz_s16.wav")) audio_stream = next(s for s in container.streams if s.type == "audio") @@ -58,7 +56,6 @@ def test_decode_audio_sample_count(self): self.assertEqual(sample_count, total_samples) def test_decoded_time_base(self): - container = av.open(fate_suite("h264/interlaced_crop.mp4")) stream = container.streams.video[0] @@ -71,7 +68,6 @@ def test_decoded_time_base(self): return def test_decoded_motion_vectors(self): - container = av.open(fate_suite("h264/interlaced_crop.mp4")) stream = container.streams.video[0] codec_context = stream.codec_context @@ -88,7 +84,6 @@ def test_decoded_motion_vectors(self): return def test_decoded_motion_vectors_no_flag(self): - container = av.open(fate_suite("h264/interlaced_crop.mp4")) stream = container.streams.video[0] diff --git a/tests/test_deprecation.py b/tests/test_deprecation.py index 166104c42..f8857ab73 100644 --- a/tests/test_deprecation.py +++ b/tests/test_deprecation.py @@ -23,7 +23,6 @@ def foo(self, a, b): def test_renamed_attr(self): class Example: - new_value = "foo" old_value = deprecation.renamed_attr("new_value") @@ -35,7 +34,6 @@ def new_func(self, a, b): obj = Example() with warnings.catch_warnings(record=True) as captured: - self.assertEqual(obj.old_value, "foo") self.assertIn( "Example.old_value is deprecated", captured[0].message.args[0] diff --git a/tests/test_dictionary.py b/tests/test_dictionary.py index 4e2c4995e..a1c2f80d8 100644 --- a/tests/test_dictionary.py +++ b/tests/test_dictionary.py @@ -5,7 +5,6 @@ class TestDictionary(TestCase): def test_basics(self): - d = Dictionary() d["key"] = "value" diff --git a/tests/test_doctests.py b/tests/test_doctests.py index c2144eab1..07cfdd574 100644 --- a/tests/test_doctests.py +++ b/tests/test_doctests.py @@ -7,9 +7,7 @@ def fix_doctests(suite): - for case in suite._tests: - # Add some more flags. case._dt_optionflags = ( (case._dt_optionflags or 0) @@ -24,14 +22,12 @@ def fix_doctests(suite): ) for example in case._dt_test.examples: - # Remove b prefix from strings. if example.want.startswith("b'"): example.want = example.want[1:] def register_doctests(mod): - if isinstance(mod, str): mod = __import__(mod, fromlist=[""]) diff --git a/tests/test_encode.py b/tests/test_encode.py index 4f942354a..a293cbf83 100644 --- a/tests/test_encode.py +++ b/tests/test_encode.py @@ -16,7 +16,6 @@ def write_rgb_rotate(output): - if not Image: raise SkipTest() @@ -29,7 +28,6 @@ def write_rgb_rotate(output): stream.pix_fmt = "yuv420p" for frame_i in range(DURATION): - frame = VideoFrame(WIDTH, HEIGHT, "rgb24") image = Image.new( "RGB", @@ -64,7 +62,6 @@ def write_rgb_rotate(output): def assert_rgb_rotate(self, input_, is_dash=False): - # Now inspect it a little. self.assertEqual(len(input_.streams), 1) if is_dash: diff --git a/tests/test_enums.py b/tests/test_enums.py index 6219785d7..bc8385f5e 100644 --- a/tests/test_enums.py +++ b/tests/test_enums.py @@ -22,7 +22,6 @@ def define_foobar(self, **kwargs): ) def test_basics(self): - cls = self.define_foobar() self.assertIsInstance(cls, EnumType) @@ -36,7 +35,6 @@ def test_basics(self): self.assertNotIsInstance(foo, PickleableFooBar) def test_access(self): - cls = self.define_foobar() foo1 = cls.FOO foo2 = cls["FOO"] @@ -58,7 +56,6 @@ def test_access(self): self.assertIs(cls.get("not a foo"), None) def test_casting(self): - cls = self.define_foobar() foo = cls.FOO @@ -77,7 +74,6 @@ def test_iteration(self): self.assertEqual(list(cls), [cls.FOO, cls.BAR]) def test_equality(self): - cls = self.define_foobar() foo = cls.FOO bar = cls.BAR @@ -94,7 +90,6 @@ def test_equality(self): self.assertRaises(TypeError, lambda: foo == ()) def test_as_key(self): - cls = self.define_foobar() foo = cls.FOO @@ -104,7 +99,6 @@ def test_as_key(self): self.assertIs(d.get(1), None) def test_pickleable(self): - cls = PickleableFooBar foo = cls.FOO @@ -115,7 +109,6 @@ def test_pickleable(self): self.assertIs(foo, foo2) def test_create_unknown(self): - cls = self.define_foobar() baz = cls.get(3, create=True) @@ -123,7 +116,6 @@ def test_create_unknown(self): self.assertEqual(baz.value, 3) def test_multiple_names(self): - cls = define_enum( "FFooBBar", __name__, @@ -147,7 +139,6 @@ def test_multiple_names(self): self.assertRaises(ValueError, lambda: cls.F == "x") def test_flag_basics(self): - cls = define_enum( "FoobarAllFlags", __name__, @@ -178,7 +169,6 @@ def test_flag_basics(self): self.assertIs(x, cls.FOO) def test_multi_flags_basics(self): - cls = self.define_foobar(is_flags=True) foo = cls.FOO @@ -202,7 +192,6 @@ def test_multi_flags_basics(self): self.assertEqual(list(cls), [foo, bar]) def test_multi_flags_create_missing(self): - cls = self.define_foobar(is_flags=True) foobar = cls[3] @@ -212,7 +201,6 @@ def test_multi_flags_create_missing(self): self.assertRaises(KeyError, lambda: cls[7]) # FOO and BAR and missing flag. def test_properties(self): - Flags = self.define_foobar(is_flags=True) foobar = Flags.FOO | Flags.BAR diff --git a/tests/test_errors.py b/tests/test_errors.py index 56069515e..088838625 100644 --- a/tests/test_errors.py +++ b/tests/test_errors.py @@ -8,7 +8,6 @@ class TestErrorBasics(TestCase): def test_stringify(self): - for cls in (av.ValueError, av.FileNotFoundError, av.DecoderNotFoundError): e = cls(1, "foo") self.assertEqual(str(e), "[Errno 1] foo") @@ -34,7 +33,6 @@ def test_stringify(self): ) def test_bases(self): - self.assertTrue(issubclass(av.ValueError, ValueError)) self.assertTrue(issubclass(av.ValueError, av.FFmpegError)) diff --git a/tests/test_filters.py b/tests/test_filters.py index f73bf4cc8..2514693ac 100644 --- a/tests/test_filters.py +++ b/tests/test_filters.py @@ -15,15 +15,6 @@ def generate_audio_frame( frame_num, input_format="s16", layout="stereo", sample_rate=44100, frame_size=1024 ): - """ - Generate audio frame representing part of the sinusoidal wave - :param input_format: default: s16 - :param layout: default: stereo - :param sample_rate: default: 44100 - :param frame_size: default: 1024 - :param frame_num: frame number - :return: audio frame for sinusoidal wave audio signal slice - """ frame = AudioFrame(format=input_format, layout=layout, samples=frame_size) frame.sample_rate = sample_rate frame.pts = frame_num * frame_size @@ -50,7 +41,6 @@ def pull_until_blocked(graph): class TestFilters(TestCase): def test_filter_descriptor(self): - f = Filter("testsrc") self.assertEqual(f.name, "testsrc") self.assertEqual(f.description, "Generate test pattern.") @@ -62,7 +52,6 @@ def test_filter_descriptor(self): self.assertEqual(f.outputs[0].type, "video") def test_dynamic_filter_descriptor(self): - f = Filter("split") self.assertFalse(f.dynamic_inputs) self.assertEqual(len(f.inputs), 1) @@ -70,7 +59,6 @@ def test_dynamic_filter_descriptor(self): self.assertEqual(len(f.outputs), 0) def test_generator_graph(self): - graph = Graph() src = graph.add("testsrc") lutrgb = graph.add( @@ -93,7 +81,6 @@ def test_generator_graph(self): frame.to_image().save(self.sandboxed("mandelbrot2.png")) def test_auto_find_sink(self): - graph = Graph() src = graph.add("testsrc") src.link_to(graph.add("buffersink")) @@ -105,7 +92,6 @@ def test_auto_find_sink(self): frame.to_image().save(self.sandboxed("mandelbrot3.png")) def test_delegate_sink(self): - graph = Graph() src = graph.add("testsrc") src.link_to(graph.add("buffersink")) @@ -117,7 +103,6 @@ def test_delegate_sink(self): frame.to_image().save(self.sandboxed("mandelbrot4.png")) def test_haldclut_graph(self): - raise SkipTest() graph = Graph() diff --git a/tests/test_logging.py b/tests/test_logging.py index 7a8e94d3d..2e35879e1 100644 --- a/tests/test_logging.py +++ b/tests/test_logging.py @@ -22,7 +22,6 @@ def test_adapt_level(self): ) def test_threaded_captures(self): - with av.logging.Capture(local=True) as logs: do_log("main") thread = threading.Thread(target=do_log, args=("thread",)) @@ -32,7 +31,6 @@ def test_threaded_captures(self): self.assertIn((av.logging.INFO, "test", "main"), logs) def test_global_captures(self): - with av.logging.Capture(local=False) as logs: do_log("main") thread = threading.Thread(target=do_log, args=("thread",)) @@ -43,7 +41,6 @@ def test_global_captures(self): self.assertIn((av.logging.INFO, "test", "thread"), logs) def test_repeats(self): - with av.logging.Capture() as logs: do_log("foo") do_log("foo") @@ -66,7 +63,6 @@ def test_repeats(self): ) def test_error(self): - log = (av.logging.ERROR, "test", "This is a test.") av.logging.log(*log) try: diff --git a/tests/test_options.py b/tests/test_options.py index cf76252d9..790780b20 100644 --- a/tests/test_options.py +++ b/tests/test_options.py @@ -6,7 +6,6 @@ class TestOptions(TestCase): def test_mov_options(self): - mov = ContainerFormat("mov") options = mov.descriptor.options by_name = {opt.name: opt for opt in options} diff --git a/tests/test_python_io.py b/tests/test_python_io.py index 8d372a84a..209f7268f 100644 --- a/tests/test_python_io.py +++ b/tests/test_python_io.py @@ -171,7 +171,6 @@ def test_writing_to_buffer_broken_with_close(self): @run_in_sandbox def test_writing_to_custom_io_dash(self): - # Custom I/O that opens file and logs calls wrapped_custom_io = CustomIOLogger() @@ -207,7 +206,6 @@ def test_writing_to_custom_io_dash(self): assert_rgb_rotate(self, container, is_dash=True) def test_writing_to_custom_io_image2(self): - if not Image: raise SkipTest() diff --git a/tests/test_seek.py b/tests/test_seek.py index 4a753bb0e..c29b3c9d6 100644 --- a/tests/test_seek.py +++ b/tests/test_seek.py @@ -88,7 +88,6 @@ def test_seek_end(self): self.assertTrue(seek_packet_count < middle_packet_count) def test_decode_half(self): - container = av.open(fate_suite("h264/interlaced_crop.mp4")) video_stream = next(s for s in container.streams if s.type == "video") @@ -127,7 +126,6 @@ def test_decode_half(self): self.assertEqual(frame_count, total_frame_count - target_frame) def test_stream_seek(self): - container = av.open(fate_suite("h264/interlaced_crop.mp4")) video_stream = next(s for s in container.streams if s.type == "video") diff --git a/tests/test_streams.py b/tests/test_streams.py index beab831ba..b2871d43d 100644 --- a/tests/test_streams.py +++ b/tests/test_streams.py @@ -5,9 +5,7 @@ class TestStreams(TestCase): def test_stream_tuples(self): - for fate_name in ("h264/interlaced_crop.mp4",): - container = av.open(fate_suite(fate_name)) video_streams = tuple([s for s in container.streams if s.type == "video"]) @@ -17,7 +15,6 @@ def test_stream_tuples(self): self.assertEqual(audio_streams, container.streams.audio) def test_selection(self): - container = av.open(fate_suite("h264/interlaced_crop.mp4")) video = container.streams.video[0] # audio_stream = container.streams.audio[0] diff --git a/tests/test_subtitles.py b/tests/test_subtitles.py index 04981a938..04e613203 100644 --- a/tests/test_subtitles.py +++ b/tests/test_subtitles.py @@ -6,7 +6,6 @@ class TestSubtitle(TestCase): def test_movtext(self): - path = fate_suite("sub/MovText_capability_tester.mp4") subs = [] @@ -27,7 +26,6 @@ def test_movtext(self): self.assertEqual(sub.ass, "0,0,Default,,0,0,0,,- Test 1.\\N- Test 2.") def test_vobsub(self): - path = fate_suite("sub/vobsub.sub") subs = [] diff --git a/tests/test_videoframe.py b/tests/test_videoframe.py index 77a5c215b..0d36616e1 100644 --- a/tests/test_videoframe.py +++ b/tests/test_videoframe.py @@ -508,7 +508,6 @@ def test_reformat_identity(self): self.assertIs(frame1, frame2) def test_reformat_colourspace(self): - # This is allowed. frame = VideoFrame(640, 480, "rgb24") frame.reformat(src_colorspace=None, dst_colorspace="smpte240")