From 2a4ab28016624aca0cf93d3c1c0b327becbbb6e1 Mon Sep 17 00:00:00 2001 From: Abulafia Date: Sun, 7 Apr 2024 18:48:18 +0200 Subject: [PATCH 01/12] Fixes #3614 Setting background_transparency=0.0 should have the same effect than setting transparent=True. The output format must be compatible with transparency (.mov, .webm). Otherwise ffpmeg fails. This patch ensures that background_transparency=0.0 triggers the change of the output format. Also a WARNING is raised about the change in the output format. I want to thank @SirJamesClarkMaxwell for inspiring me to tackle this issue. --- manim/_config/utils.py | 9 +++++++++ tests/test_config.py | 10 ++++++++++ 2 files changed, 19 insertions(+) diff --git a/manim/_config/utils.py b/manim/_config/utils.py index 814db08a3e..cb9a2c7b7d 100644 --- a/manim/_config/utils.py +++ b/manim/_config/utils.py @@ -1042,6 +1042,7 @@ def format(self, val: str) -> None: val, [None, "png", "gif", "mp4", "mov", "webm"], ) + self.resolve_movie_file_extension(self.transparent) if self.format == "webm": logging.getLogger("manim").warning( "Output format set as webm, this can be slower than other formats", @@ -1269,6 +1270,8 @@ def background_opacity(self) -> float: @background_opacity.setter def background_opacity(self, value: float) -> None: self._set_between("background_opacity", value, 0, 1) + if self.background_opacity == 0: + self.transparent = True @property def frame_size(self) -> tuple[int, int]: @@ -1422,6 +1425,7 @@ def window_size(self, value: str) -> None: self._d.__setitem__("window_size", value) def resolve_movie_file_extension(self, is_transparent: bool) -> None: + prev_file_extension = self.movie_file_extension if is_transparent: self.movie_file_extension = ".webm" if self.format == "webm" else ".mov" elif self.format == "webm": @@ -1430,6 +1434,11 @@ def resolve_movie_file_extension(self, is_transparent: bool) -> None: self.movie_file_extension = ".mov" else: self.movie_file_extension = ".mp4" + if self.movie_file_extension != prev_file_extension: + logging.getLogger("manim").warning( + f"Output format changed to '{self.movie_file_extension}' " + "to support transparency", + ) @property def enable_gui(self) -> bool: diff --git a/tests/test_config.py b/tests/test_config.py index b543e8a5e6..dd11b69b5c 100644 --- a/tests/test_config.py +++ b/tests/test_config.py @@ -59,6 +59,16 @@ def test_transparent(): frame = scene.renderer.get_frame() np.testing.assert_allclose(frame[0, 0], [0, 0, 0, 0]) + # Test that setting background_opacity to 0.0 has the same + # effect as setting transparent to True + with tempconfig({"background_opacity": 0.0, "dry_run": False}): + scene = MyScene() + scene.render() + frame = scene.renderer.get_frame() + np.testing.assert_allclose(frame[0, 0], [0, 0, 0, 0]) + assert config["movie_file_extension"] == ".mov" + assert config["transparent"] is True + config["verbosity"] = orig_verbosity From e502ae5b9c5ec300ff82205d4d5b43f00a27e8a3 Mon Sep 17 00:00:00 2001 From: "pre-commit-ci[bot]" <66853113+pre-commit-ci[bot]@users.noreply.github.com> Date: Sat, 13 Jul 2024 08:08:51 +0000 Subject: [PATCH 02/12] [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci --- tests/test_config.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/tests/test_config.py b/tests/test_config.py index b5790b6257..9503bbc6f5 100644 --- a/tests/test_config.py +++ b/tests/test_config.py @@ -53,7 +53,7 @@ def test_transparent(config): np.testing.assert_allclose(frame[0, 0], [0, 0, 0, 255]) config.transparent = True - + scene = MyScene() scene.render() frame = scene.renderer.get_frame() @@ -63,7 +63,7 @@ def test_transparent(config): def test_transparent_by_background_opacity(config): config.dry_run = True config.background_opacity = 0.0 - + scene = MyScene() scene.render() frame = scene.renderer.get_frame() From e633a6d521ddc385d0ced19ce622963de02bc7c0 Mon Sep 17 00:00:00 2001 From: Benjamin Hackl Date: Sat, 13 Jul 2024 11:31:26 +0200 Subject: [PATCH 03/12] test config.background_opacity < 1 --- tests/test_config.py | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/tests/test_config.py b/tests/test_config.py index 9503bbc6f5..cba9f7ecb1 100644 --- a/tests/test_config.py +++ b/tests/test_config.py @@ -62,12 +62,13 @@ def test_transparent(config): def test_transparent_by_background_opacity(config): config.dry_run = True - config.background_opacity = 0.0 + config.background_opacity = 0.5 + assert config.transparent is True scene = MyScene() scene.render() frame = scene.renderer.get_frame() - np.testing.assert_allclose(frame[0, 0], [0, 0, 0, 0]) + np.testing.assert_allclose(frame[0, 0], [0, 0, 0, 127]) assert config.movie_file_extension == ".mov" assert config.transparent is True From afe49fdb3773f3841b02b0bb5e0b024db1120cb7 Mon Sep 17 00:00:00 2001 From: Benjamin Hackl Date: Sat, 13 Jul 2024 11:33:14 +0200 Subject: [PATCH 04/12] fix config behavior for config.background_opacity < 1 --- manim/_config/utils.py | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/manim/_config/utils.py b/manim/_config/utils.py index e37906b50b..61b02e33b8 100644 --- a/manim/_config/utils.py +++ b/manim/_config/utils.py @@ -1272,8 +1272,8 @@ def background_opacity(self) -> float: @background_opacity.setter def background_opacity(self, value: float) -> None: self._set_between("background_opacity", value, 0, 1) - if self.background_opacity == 0: - self.transparent = True + if self.background_opacity < 1: + self.resolve_movie_file_extension(is_transparent=True) @property def frame_size(self) -> tuple[int, int]: @@ -1308,8 +1308,8 @@ def quality(self, value: str | None) -> None: @property def transparent(self) -> bool: - """Whether the background opacity is 0.0 (-t).""" - return self._d["background_opacity"] == 0.0 + """Whether the background opacity is less than 1.0 (-t).""" + return self._d["background_opacity"] < 1.0 @transparent.setter def transparent(self, value: bool) -> None: From 78dfd412a51ca73cd292b30d54d20bafc07a7f45 Mon Sep 17 00:00:00 2001 From: Benjamin Hackl Date: Sat, 13 Jul 2024 11:33:40 +0200 Subject: [PATCH 05/12] fix logger messages being emitted twice --- manim/_config/logger_utils.py | 1 + manim/_config/utils.py | 12 +++++++----- 2 files changed, 8 insertions(+), 5 deletions(-) diff --git a/manim/_config/logger_utils.py b/manim/_config/logger_utils.py index f3b43f8f78..9205635eef 100644 --- a/manim/_config/logger_utils.py +++ b/manim/_config/logger_utils.py @@ -99,6 +99,7 @@ def make_logger( logger = logging.getLogger("manim") logger.addHandler(rich_handler) logger.setLevel(verbosity) + logger.propagate = False if not (libav_logger := logging.getLogger()).hasHandlers(): libav_logger.addHandler(rich_handler) diff --git a/manim/_config/utils.py b/manim/_config/utils.py index 61b02e33b8..46613e8d74 100644 --- a/manim/_config/utils.py +++ b/manim/_config/utils.py @@ -40,6 +40,8 @@ __all__ = ["config_file_paths", "make_config_parser", "ManimConfig", "ManimFrame"] +logger = logging.getLogger("manim") + def config_file_paths() -> list[Path]: """The paths where ``.cfg`` files will be searched for. @@ -799,7 +801,7 @@ def digest_args(self, args: argparse.Namespace) -> Self: try: self.upto_animation_number = nflag[1] except Exception: - logging.getLogger("manim").info( + logger.info( f"No end scene number specified in -n option. Rendering from {nflag[0]} onwards...", ) @@ -1038,7 +1040,7 @@ def verbosity(self, val: str) -> None: val, ["DEBUG", "INFO", "WARNING", "ERROR", "CRITICAL"], ) - logging.getLogger("manim").setLevel(val) + logger.setLevel(val) @property def format(self) -> str: @@ -1054,7 +1056,7 @@ def format(self, val: str) -> None: ) self.resolve_movie_file_extension(self.transparent) if self.format == "webm": - logging.getLogger("manim").warning( + logger.warning( "Output format set as webm, this can be slower than other formats", ) @@ -1437,7 +1439,7 @@ def resolve_movie_file_extension(self, is_transparent: bool) -> None: else: self.movie_file_extension = ".mp4" if self.movie_file_extension != prev_file_extension: - logging.getLogger("manim").warning( + logger.warning( f"Output format changed to '{self.movie_file_extension}' " "to support transparency", ) @@ -1786,7 +1788,7 @@ def tex_template_file(self) -> Path: def tex_template_file(self, val: str) -> None: if val: if not os.access(val, os.R_OK): - logging.getLogger("manim").warning( + logger.warning( f"Custom TeX template {val} not found or not readable.", ) else: From c800ba1fdd9d8e1aa38af9c12d17a96bc7ce6f66 Mon Sep 17 00:00:00 2001 From: Benjamin Hackl Date: Sat, 13 Jul 2024 17:07:02 +0200 Subject: [PATCH 06/12] actually cleanup usage of loggers, remove logger-imports; black --- manim/cli/render/global_options.py | 4 +++- manim/cli/render/render_options.py | 4 +++- manim/renderer/shader_wrapper.py | 5 +++-- manim/utils/deprecation.py | 9 ++++++--- manim/utils/testing/_frames_testers.py | 4 +++- tests/conftest.py | 10 ++++++++++ tests/helpers/graphical_units.py | 4 +++- tests/module/animation/test_animation.py | 8 ++++---- tests/module/mobject/geometry/test_unit_geometry.py | 5 ++--- tests/module/utils/test_deprecation.py | 5 ++++- 10 files changed, 41 insertions(+), 17 deletions(-) diff --git a/manim/cli/render/global_options.py b/manim/cli/render/global_options.py index d7424dd1ee..103b3cecd2 100644 --- a/manim/cli/render/global_options.py +++ b/manim/cli/render/global_options.py @@ -1,13 +1,15 @@ from __future__ import annotations +import logging import re from cloup import Choice, option, option_group -from ... import logger __all__ = ["global_options"] +logger = logging.getLogger("manim") + def validate_gui_location(ctx, param, value): if value: diff --git a/manim/cli/render/render_options.py b/manim/cli/render/render_options.py index 5a2d992db8..e306ba70d1 100644 --- a/manim/cli/render/render_options.py +++ b/manim/cli/render/render_options.py @@ -1,15 +1,17 @@ from __future__ import annotations +import logging import re from cloup import Choice, option, option_group from manim.constants import QUALITIES, RendererType -from ... import logger __all__ = ["render_options"] +logger = logging.getLogger("manim") + def validate_scene_range(ctx, param, value): try: diff --git a/manim/renderer/shader_wrapper.py b/manim/renderer/shader_wrapper.py index 00e111aad6..2da8da0355 100644 --- a/manim/renderer/shader_wrapper.py +++ b/manim/renderer/shader_wrapper.py @@ -4,11 +4,10 @@ import re from pathlib import Path +import logging import moderngl import numpy as np -from .. import logger - # Mobjects that should be rendered with # the same shader will be organized and # clumped together based on keeping track @@ -17,6 +16,8 @@ __all__ = ["ShaderWrapper"] +logger = logging.getLogger("manim") + def get_shader_dir(): return Path(__file__).parent / "shaders" diff --git a/manim/utils/deprecation.py b/manim/utils/deprecation.py index 2d443c5e72..7ca2f2adb3 100644 --- a/manim/utils/deprecation.py +++ b/manim/utils/deprecation.py @@ -6,13 +6,14 @@ import inspect +import logging import re from collections.abc import Iterable from typing import Any, Callable from decorator import decorate, decorator -from .. import logger +logger = logging.getLogger("manim") def _get_callable_info(callable: Callable) -> tuple[str, str]: @@ -218,6 +219,7 @@ def deprecate(func: Callable, *args, **kwargs): The return value of the given callable when being passed the given arguments. """ + print("about to emit warning") logger.warning(warning_msg()) return func(*args, **kwargs) @@ -236,8 +238,9 @@ def deprecated_params( since: str | None = None, until: str | None = None, message: str | None = "", - redirections: None - | (Iterable[tuple[str, str] | Callable[..., dict[str, Any]]]) = None, + redirections: None | ( + Iterable[tuple[str, str] | Callable[..., dict[str, Any]]] + ) = None, ) -> Callable: """Decorator to mark parameters of a callable as deprecated. diff --git a/manim/utils/testing/_frames_testers.py b/manim/utils/testing/_frames_testers.py index be0bc38447..fef59758db 100644 --- a/manim/utils/testing/_frames_testers.py +++ b/manim/utils/testing/_frames_testers.py @@ -4,15 +4,17 @@ import warnings from pathlib import Path +import logging import numpy as np -from manim import logger from ._show_diff import show_diff_helper FRAME_ABSOLUTE_TOLERANCE = 1.01 FRAME_MISMATCH_RATIO_TOLERANCE = 1e-5 +logger = logging.getLogger("manim") + class _FramesTester: def __init__(self, file_path: Path, show_diff=False) -> None: diff --git a/tests/conftest.py b/tests/conftest.py index e69c1080d5..16962f4d2c 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -1,5 +1,6 @@ from __future__ import annotations +import logging import sys from pathlib import Path @@ -45,6 +46,15 @@ def pytest_collection_modifyitems(config, items): item.add_marker(slow_skip) +@pytest.fixture +def manim_caplog(caplog): + logger = logging.getLogger("manim") + logger.propagate = True + caplog.set_level(logging.INFO, logger="manim") + yield caplog + logger.propagate = False + + @pytest.fixture def config(): saved = manim.config.copy() diff --git a/tests/helpers/graphical_units.py b/tests/helpers/graphical_units.py index 01eae516a9..1b6cd82600 100644 --- a/tests/helpers/graphical_units.py +++ b/tests/helpers/graphical_units.py @@ -2,15 +2,17 @@ from __future__ import annotations +import logging import tempfile from pathlib import Path import numpy as np -from manim import logger from manim.scene.scene import Scene +logger = logging.getLogger("manim") + def set_test_scene(scene_object: type[Scene], module_name: str, config): """Function used to set up the test data for a new feature. This will basically set up a pre-rendered frame for a scene. This is meant to be used only when setting up tests. Please refer to the wiki. diff --git a/tests/module/animation/test_animation.py b/tests/module/animation/test_animation.py index d57f57247e..448c0e76d6 100644 --- a/tests/module/animation/test_animation.py +++ b/tests/module/animation/test_animation.py @@ -15,20 +15,20 @@ def test_animation_forbidden_run_time(run_time): test_scene.play(FadeIn(None, run_time=run_time)) -def test_animation_run_time_shorter_than_frame_rate(caplog, config): +def test_animation_run_time_shorter_than_frame_rate(manim_caplog, config): test_scene = Scene() test_scene.play(FadeIn(None, run_time=1 / (config.frame_rate + 1))) assert ( "Original run time of FadeIn(Mobject) is shorter than current frame rate" - in caplog.text + in manim_caplog.text ) @pytest.mark.parametrize("frozen_frame", [False, True]) -def test_wait_run_time_shorter_than_frame_rate(caplog, frozen_frame): +def test_wait_run_time_shorter_than_frame_rate(manim_caplog, frozen_frame): test_scene = Scene() test_scene.wait(1e-9, frozen_frame=frozen_frame) assert ( "Original run time of Wait(Mobject) is shorter than current frame rate" - in caplog.text + in manim_caplog.text ) diff --git a/tests/module/mobject/geometry/test_unit_geometry.py b/tests/module/mobject/geometry/test_unit_geometry.py index 45f4da279f..e953ef2de3 100644 --- a/tests/module/mobject/geometry/test_unit_geometry.py +++ b/tests/module/mobject/geometry/test_unit_geometry.py @@ -15,8 +15,7 @@ def test_get_arc_center(): ) -def test_BackgroundRectangle(caplog): - caplog.set_level(logging.INFO) +def test_BackgroundRectangle(manim_caplog): c = Circle() bg = BackgroundRectangle(c) bg.set_style(fill_opacity=0.42) @@ -24,5 +23,5 @@ def test_BackgroundRectangle(caplog): bg.set_style(fill_opacity=1, hello="world") assert ( "Argument {'hello': 'world'} is ignored in BackgroundRectangle.set_style." - in caplog.text + in manim_caplog.text ) diff --git a/tests/module/utils/test_deprecation.py b/tests/module/utils/test_deprecation.py index e498b8b196..98abf97821 100644 --- a/tests/module/utils/test_deprecation.py +++ b/tests/module/utils/test_deprecation.py @@ -14,8 +14,11 @@ def _get_caplog_record_msg(warn_caplog_manim): @pytest.fixture() def warn_caplog_manim(caplog): - caplog.set_level(logging.WARNING, logger="manim") + logger = logging.getLogger("manim") + logger.propagate = True + caplog.set_level(logging.INFO, logger="manim") yield caplog + logger.propagate = False @deprecated From f60184b1453a828c0b3e4ac9cfccb98c946b8be8 Mon Sep 17 00:00:00 2001 From: "pre-commit-ci[bot]" <66853113+pre-commit-ci[bot]@users.noreply.github.com> Date: Sat, 13 Jul 2024 15:10:14 +0000 Subject: [PATCH 07/12] [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci --- manim/cli/render/global_options.py | 1 - manim/cli/render/render_options.py | 1 - manim/renderer/shader_wrapper.py | 2 +- manim/utils/deprecation.py | 5 ++--- manim/utils/testing/_frames_testers.py | 3 +-- tests/helpers/graphical_units.py | 2 +- 6 files changed, 5 insertions(+), 9 deletions(-) diff --git a/manim/cli/render/global_options.py b/manim/cli/render/global_options.py index 103b3cecd2..5941d4fd68 100644 --- a/manim/cli/render/global_options.py +++ b/manim/cli/render/global_options.py @@ -5,7 +5,6 @@ from cloup import Choice, option, option_group - __all__ = ["global_options"] logger = logging.getLogger("manim") diff --git a/manim/cli/render/render_options.py b/manim/cli/render/render_options.py index e306ba70d1..21a91ce393 100644 --- a/manim/cli/render/render_options.py +++ b/manim/cli/render/render_options.py @@ -7,7 +7,6 @@ from manim.constants import QUALITIES, RendererType - __all__ = ["render_options"] logger = logging.getLogger("manim") diff --git a/manim/renderer/shader_wrapper.py b/manim/renderer/shader_wrapper.py index 2da8da0355..8a2b0d1fbe 100644 --- a/manim/renderer/shader_wrapper.py +++ b/manim/renderer/shader_wrapper.py @@ -1,10 +1,10 @@ from __future__ import annotations import copy +import logging import re from pathlib import Path -import logging import moderngl import numpy as np diff --git a/manim/utils/deprecation.py b/manim/utils/deprecation.py index 7ca2f2adb3..b9c1f82e55 100644 --- a/manim/utils/deprecation.py +++ b/manim/utils/deprecation.py @@ -238,9 +238,8 @@ def deprecated_params( since: str | None = None, until: str | None = None, message: str | None = "", - redirections: None | ( - Iterable[tuple[str, str] | Callable[..., dict[str, Any]]] - ) = None, + redirections: None + | (Iterable[tuple[str, str] | Callable[..., dict[str, Any]]]) = None, ) -> Callable: """Decorator to mark parameters of a callable as deprecated. diff --git a/manim/utils/testing/_frames_testers.py b/manim/utils/testing/_frames_testers.py index fef59758db..a0ca9ddd99 100644 --- a/manim/utils/testing/_frames_testers.py +++ b/manim/utils/testing/_frames_testers.py @@ -1,13 +1,12 @@ from __future__ import annotations import contextlib +import logging import warnings from pathlib import Path -import logging import numpy as np - from ._show_diff import show_diff_helper FRAME_ABSOLUTE_TOLERANCE = 1.01 diff --git a/tests/helpers/graphical_units.py b/tests/helpers/graphical_units.py index 1b6cd82600..1395559e52 100644 --- a/tests/helpers/graphical_units.py +++ b/tests/helpers/graphical_units.py @@ -10,9 +10,9 @@ from manim.scene.scene import Scene - logger = logging.getLogger("manim") + def set_test_scene(scene_object: type[Scene], module_name: str, config): """Function used to set up the test data for a new feature. This will basically set up a pre-rendered frame for a scene. This is meant to be used only when setting up tests. Please refer to the wiki. From 38ec8ee5bad5aa867d62bdc64f2b8c600a7b8c74 Mon Sep 17 00:00:00 2001 From: Benjamin Hackl Date: Sun, 14 Jul 2024 21:17:38 +0200 Subject: [PATCH 08/12] dry_run fixture --- tests/test_config.py | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/tests/test_config.py b/tests/test_config.py index cba9f7ecb1..f3902f9516 100644 --- a/tests/test_config.py +++ b/tests/test_config.py @@ -60,8 +60,7 @@ def test_transparent(config): np.testing.assert_allclose(frame[0, 0], [0, 0, 0, 0]) -def test_transparent_by_background_opacity(config): - config.dry_run = True +def test_transparent_by_background_opacity(config, dry_run): config.background_opacity = 0.5 assert config.transparent is True From 0d68eb2151458d4bde1ef8ab575c9a71f539b23d Mon Sep 17 00:00:00 2001 From: Benjamin Hackl Date: Sun, 14 Jul 2024 21:19:44 +0200 Subject: [PATCH 09/12] remove debug print --- manim/utils/deprecation.py | 1 - 1 file changed, 1 deletion(-) diff --git a/manim/utils/deprecation.py b/manim/utils/deprecation.py index b9c1f82e55..4fd76880b4 100644 --- a/manim/utils/deprecation.py +++ b/manim/utils/deprecation.py @@ -219,7 +219,6 @@ def deprecate(func: Callable, *args, **kwargs): The return value of the given callable when being passed the given arguments. """ - print("about to emit warning") logger.warning(warning_msg()) return func(*args, **kwargs) From ea8a11531b35abe8271990e71b1344e6ac46b75a Mon Sep 17 00:00:00 2001 From: Benjamin Hackl Date: Sun, 14 Jul 2024 21:29:50 +0200 Subject: [PATCH 10/12] applied suggestion from review --- tests/module/utils/test_deprecation.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/module/utils/test_deprecation.py b/tests/module/utils/test_deprecation.py index 98abf97821..e8de3850b0 100644 --- a/tests/module/utils/test_deprecation.py +++ b/tests/module/utils/test_deprecation.py @@ -16,7 +16,7 @@ def _get_caplog_record_msg(warn_caplog_manim): def warn_caplog_manim(caplog): logger = logging.getLogger("manim") logger.propagate = True - caplog.set_level(logging.INFO, logger="manim") + caplog.set_level(logging.WARNING, logger="manim") yield caplog logger.propagate = False From 5168c63eee76b7e365402956b0793be33666bdc1 Mon Sep 17 00:00:00 2001 From: Benjamin Hackl Date: Sun, 14 Jul 2024 21:37:28 +0200 Subject: [PATCH 11/12] remove custom fixture from test_deprecation, use manim_caplog --- tests/module/utils/test_deprecation.py | 127 ++++++++++++------------- 1 file changed, 59 insertions(+), 68 deletions(-) diff --git a/tests/module/utils/test_deprecation.py b/tests/module/utils/test_deprecation.py index e8de3850b0..f46fcaaf96 100644 --- a/tests/module/utils/test_deprecation.py +++ b/tests/module/utils/test_deprecation.py @@ -7,20 +7,11 @@ from manim.utils.deprecation import deprecated, deprecated_params -def _get_caplog_record_msg(warn_caplog_manim): - logger_name, level, message = warn_caplog_manim.record_tuples[0] +def _get_caplog_record_msg(manim_caplog): + logger_name, level, message = manim_caplog.record_tuples[0] return message -@pytest.fixture() -def warn_caplog_manim(caplog): - logger = logging.getLogger("manim") - logger.propagate = True - caplog.set_level(logging.WARNING, logger="manim") - yield caplog - logger.propagate = False - - @deprecated class Foo: def __init__(self): @@ -80,11 +71,11 @@ def __init__(self): doc_admonition = "\n\n.. attention:: Deprecated\n " -def test_deprecate_class_no_args(warn_caplog_manim): +def test_deprecate_class_no_args(manim_caplog): """Test the deprecation of a class (decorator with no arguments).""" f = Foo() - assert len(warn_caplog_manim.record_tuples) == 1 - msg = _get_caplog_record_msg(warn_caplog_manim) + assert len(manim_caplog.record_tuples) == 1 + msg = _get_caplog_record_msg(manim_caplog) assert ( msg == "The class Foo has been deprecated and may be removed in a later version." @@ -92,11 +83,11 @@ def test_deprecate_class_no_args(warn_caplog_manim): assert f.__doc__ == f"{doc_admonition}{msg}" -def test_deprecate_class_since(warn_caplog_manim): +def test_deprecate_class_since(manim_caplog): """Test the deprecation of a class (decorator with since argument).""" b = Bar() - assert len(warn_caplog_manim.record_tuples) == 1 - msg = _get_caplog_record_msg(warn_caplog_manim) + assert len(manim_caplog.record_tuples) == 1 + msg = _get_caplog_record_msg(manim_caplog) assert ( msg == "The class Bar has been deprecated since v0.6.0 and may be removed in a later version." @@ -104,11 +95,11 @@ def test_deprecate_class_since(warn_caplog_manim): assert b.__doc__ == f"The Bar class.{doc_admonition}{msg}" -def test_deprecate_class_until(warn_caplog_manim): +def test_deprecate_class_until(manim_caplog): """Test the deprecation of a class (decorator with until argument).""" bz = Baz() - assert len(warn_caplog_manim.record_tuples) == 1 - msg = _get_caplog_record_msg(warn_caplog_manim) + assert len(manim_caplog.record_tuples) == 1 + msg = _get_caplog_record_msg(manim_caplog) assert ( msg == "The class Baz has been deprecated and is expected to be removed after 06/01/2021." @@ -116,11 +107,11 @@ def test_deprecate_class_until(warn_caplog_manim): assert bz.__doc__ == f"The Baz class.{doc_admonition}{msg}" -def test_deprecate_class_since_and_until(warn_caplog_manim): +def test_deprecate_class_since_and_until(manim_caplog): """Test the deprecation of a class (decorator with since and until arguments).""" qx = Qux() - assert len(warn_caplog_manim.record_tuples) == 1 - msg = _get_caplog_record_msg(warn_caplog_manim) + assert len(manim_caplog.record_tuples) == 1 + msg = _get_caplog_record_msg(manim_caplog) assert ( msg == "The class Qux has been deprecated since 0.7.0 and is expected to be removed after 0.9.0-rc2." @@ -128,11 +119,11 @@ def test_deprecate_class_since_and_until(warn_caplog_manim): assert qx.__doc__ == f"{doc_admonition}{msg}" -def test_deprecate_class_msg(warn_caplog_manim): +def test_deprecate_class_msg(manim_caplog): """Test the deprecation of a class (decorator with msg argument).""" qu = Quux() - assert len(warn_caplog_manim.record_tuples) == 1 - msg = _get_caplog_record_msg(warn_caplog_manim) + assert len(manim_caplog.record_tuples) == 1 + msg = _get_caplog_record_msg(manim_caplog) assert ( msg == "The class Quux has been deprecated and may be removed in a later version. Use something else." @@ -140,11 +131,11 @@ def test_deprecate_class_msg(warn_caplog_manim): assert qu.__doc__ == f"{doc_admonition}{msg}" -def test_deprecate_class_replacement(warn_caplog_manim): +def test_deprecate_class_replacement(manim_caplog): """Test the deprecation of a class (decorator with replacement argument).""" qz = Quuz() - assert len(warn_caplog_manim.record_tuples) == 1 - msg = _get_caplog_record_msg(warn_caplog_manim) + assert len(manim_caplog.record_tuples) == 1 + msg = _get_caplog_record_msg(manim_caplog) assert ( msg == "The class Quuz has been deprecated and may be removed in a later version. Use ReplaceQuuz instead." @@ -153,11 +144,11 @@ def test_deprecate_class_replacement(warn_caplog_manim): assert qz.__doc__ == f"{doc_admonition}{doc_msg}" -def test_deprecate_class_all(warn_caplog_manim): +def test_deprecate_class_all(manim_caplog): """Test the deprecation of a class (decorator with all arguments).""" qza = QuuzAll() - assert len(warn_caplog_manim.record_tuples) == 1 - msg = _get_caplog_record_msg(warn_caplog_manim) + assert len(manim_caplog.record_tuples) == 1 + msg = _get_caplog_record_msg(manim_caplog) assert ( msg == "The class QuuzAll has been deprecated since 0.7.0 and is expected to be removed after 1.2.1. Use ReplaceQuuz instead. Don't use this please." @@ -246,11 +237,11 @@ def quuz(self, **kwargs): return kwargs -def test_deprecate_func_no_args(warn_caplog_manim): +def test_deprecate_func_no_args(manim_caplog): """Test the deprecation of a method (decorator with no arguments).""" useless() - assert len(warn_caplog_manim.record_tuples) == 1 - msg = _get_caplog_record_msg(warn_caplog_manim) + assert len(manim_caplog.record_tuples) == 1 + msg = _get_caplog_record_msg(manim_caplog) assert ( msg == "The function useless has been deprecated and may be removed in a later version." @@ -258,12 +249,12 @@ def test_deprecate_func_no_args(warn_caplog_manim): assert useless.__doc__ == f"{doc_admonition}{msg}" -def test_deprecate_func_in_class_since_and_message(warn_caplog_manim): +def test_deprecate_func_in_class_since_and_message(manim_caplog): """Test the deprecation of a method within a class (decorator with since and message arguments).""" t = Top() t.mid_func() - assert len(warn_caplog_manim.record_tuples) == 1 - msg = _get_caplog_record_msg(warn_caplog_manim) + assert len(manim_caplog.record_tuples) == 1 + msg = _get_caplog_record_msg(manim_caplog) assert ( msg == "The method Top.mid_func has been deprecated since 0.8.0 and may be removed in a later version. This method is useless." @@ -271,11 +262,11 @@ def test_deprecate_func_in_class_since_and_message(warn_caplog_manim): assert t.mid_func.__doc__ == f"Middle function in Top.{doc_admonition}{msg}" -def test_deprecate_nested_class_until_and_replacement(warn_caplog_manim): +def test_deprecate_nested_class_until_and_replacement(manim_caplog): """Test the deprecation of a nested class (decorator with until and replacement arguments).""" n = Top().Nested() - assert len(warn_caplog_manim.record_tuples) == 1 - msg = _get_caplog_record_msg(warn_caplog_manim) + assert len(manim_caplog.record_tuples) == 1 + msg = _get_caplog_record_msg(manim_caplog) assert ( msg == "The class Top.Nested has been deprecated and is expected to be removed after 1.4.0. Use Top.NewNested instead." @@ -284,12 +275,12 @@ def test_deprecate_nested_class_until_and_replacement(warn_caplog_manim): assert n.__doc__ == f"{doc_admonition}{doc_msg}" -def test_deprecate_nested_class_func_since_and_until(warn_caplog_manim): +def test_deprecate_nested_class_func_since_and_until(manim_caplog): """Test the deprecation of a method within a nested class (decorator with since and until arguments).""" n = Top().NewNested() n.nested_func() - assert len(warn_caplog_manim.record_tuples) == 1 - msg = _get_caplog_record_msg(warn_caplog_manim) + assert len(manim_caplog.record_tuples) == 1 + msg = _get_caplog_record_msg(manim_caplog) assert ( msg == "The method Top.NewNested.nested_func has been deprecated since 1.0.0 and is expected to be removed after 12/25/2025." @@ -300,13 +291,13 @@ def test_deprecate_nested_class_func_since_and_until(warn_caplog_manim): ) -def test_deprecate_nested_func(warn_caplog_manim): +def test_deprecate_nested_func(manim_caplog): """Test the deprecation of a nested method (decorator with no arguments).""" b = Top().Bottom() answer = b.normal_func() answer(1) - assert len(warn_caplog_manim.record_tuples) == 1 - msg = _get_caplog_record_msg(warn_caplog_manim) + assert len(manim_caplog.record_tuples) == 1 + msg = _get_caplog_record_msg(manim_caplog) assert ( msg == "The method Top.Bottom.normal_func..nested_func has been deprecated and may be removed in a later version." @@ -314,36 +305,36 @@ def test_deprecate_nested_func(warn_caplog_manim): assert answer.__doc__ == f"{doc_admonition}{msg}" -def test_deprecate_func_params(warn_caplog_manim): +def test_deprecate_func_params(manim_caplog): """Test the deprecation of method parameters (decorator with params argument).""" t = Top() t.foo(a=2, b=3, z=4) - assert len(warn_caplog_manim.record_tuples) == 1 - msg = _get_caplog_record_msg(warn_caplog_manim) + assert len(manim_caplog.record_tuples) == 1 + msg = _get_caplog_record_msg(manim_caplog) assert ( msg == "The parameters a and b of method Top.foo have been deprecated and may be removed in a later version. Use something else." ) -def test_deprecate_func_single_param_since_and_until(warn_caplog_manim): +def test_deprecate_func_single_param_since_and_until(manim_caplog): """Test the deprecation of a single method parameter (decorator with since and until arguments).""" t = Top() t.bar(a=1, b=2) - assert len(warn_caplog_manim.record_tuples) == 1 - msg = _get_caplog_record_msg(warn_caplog_manim) + assert len(manim_caplog.record_tuples) == 1 + msg = _get_caplog_record_msg(manim_caplog) assert ( msg == "The parameter a of method Top.bar has been deprecated since v0.2 and is expected to be removed after v0.4." ) -def test_deprecate_func_param_redirect_tuple(warn_caplog_manim): +def test_deprecate_func_param_redirect_tuple(manim_caplog): """Test the deprecation of a method parameter and redirecting it to a new one using tuple.""" t = Top() obj = t.baz(x=1, old_param=2) - assert len(warn_caplog_manim.record_tuples) == 1 - msg = _get_caplog_record_msg(warn_caplog_manim) + assert len(manim_caplog.record_tuples) == 1 + msg = _get_caplog_record_msg(manim_caplog) assert ( msg == "The parameter old_param of method Top.baz has been deprecated and may be removed in a later version." @@ -351,12 +342,12 @@ def test_deprecate_func_param_redirect_tuple(warn_caplog_manim): assert obj == {"x": 1, "new_param": 2} -def test_deprecate_func_param_redirect_lambda(warn_caplog_manim): +def test_deprecate_func_param_redirect_lambda(manim_caplog): """Test the deprecation of a method parameter and redirecting it to a new one using lambda function.""" t = Top() obj = t.qux(runtime_in_ms=500) - assert len(warn_caplog_manim.record_tuples) == 1 - msg = _get_caplog_record_msg(warn_caplog_manim) + assert len(manim_caplog.record_tuples) == 1 + msg = _get_caplog_record_msg(manim_caplog) assert ( msg == "The parameter runtime_in_ms of method Top.qux has been deprecated and may be removed in a later version." @@ -364,12 +355,12 @@ def test_deprecate_func_param_redirect_lambda(warn_caplog_manim): assert obj == {"run_time": 0.5} -def test_deprecate_func_param_redirect_many_to_one(warn_caplog_manim): +def test_deprecate_func_param_redirect_many_to_one(manim_caplog): """Test the deprecation of multiple method parameters and redirecting them to one.""" t = Top() obj = t.quux(point2D_x=3, point2D_y=5) - assert len(warn_caplog_manim.record_tuples) == 1 - msg = _get_caplog_record_msg(warn_caplog_manim) + assert len(manim_caplog.record_tuples) == 1 + msg = _get_caplog_record_msg(manim_caplog) assert ( msg == "The parameters point2D_x and point2D_y of method Top.quux have been deprecated and may be removed in a later version." @@ -377,23 +368,23 @@ def test_deprecate_func_param_redirect_many_to_one(warn_caplog_manim): assert obj == {"point2D": (3, 5)} -def test_deprecate_func_param_redirect_one_to_many(warn_caplog_manim): +def test_deprecate_func_param_redirect_one_to_many(manim_caplog): """Test the deprecation of one method parameter and redirecting it to many.""" t = Top() obj1 = t.quuz(point2D=0) - assert len(warn_caplog_manim.record_tuples) == 1 - msg = _get_caplog_record_msg(warn_caplog_manim) + assert len(manim_caplog.record_tuples) == 1 + msg = _get_caplog_record_msg(manim_caplog) assert ( msg == "The parameter point2D of method Top.quuz has been deprecated and may be removed in a later version." ) assert obj1 == {"x": 0, "y": 0} - warn_caplog_manim.clear() + manim_caplog.clear() obj2 = t.quuz(point2D=(2, 3)) - assert len(warn_caplog_manim.record_tuples) == 1 - msg = _get_caplog_record_msg(warn_caplog_manim) + assert len(manim_caplog.record_tuples) == 1 + msg = _get_caplog_record_msg(manim_caplog) assert ( msg == "The parameter point2D of method Top.quuz has been deprecated and may be removed in a later version." From a7e37cd7b5ec7c90a573632295f60602690c533a Mon Sep 17 00:00:00 2001 From: "pre-commit-ci[bot]" <66853113+pre-commit-ci[bot]@users.noreply.github.com> Date: Sun, 14 Jul 2024 19:39:22 +0000 Subject: [PATCH 12/12] [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci --- tests/module/utils/test_deprecation.py | 4 ---- 1 file changed, 4 deletions(-) diff --git a/tests/module/utils/test_deprecation.py b/tests/module/utils/test_deprecation.py index f46fcaaf96..c822a7cbdf 100644 --- a/tests/module/utils/test_deprecation.py +++ b/tests/module/utils/test_deprecation.py @@ -1,9 +1,5 @@ from __future__ import annotations -import logging - -import pytest - from manim.utils.deprecation import deprecated, deprecated_params