From 7ba02705521f892b8d925563d32f24ff734ca3be Mon Sep 17 00:00:00 2001 From: Akihiro Nitta Date: Thu, 14 Jul 2022 21:28:38 +0900 Subject: [PATCH] Remove deprecated `max_steps=None` (#13591) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Remove max_steps=None * Update changelog * Update docs * Unused import Co-authored-by: Carlos MocholĂ­ --- docs/source-pytorch/common/trainer.rst | 2 +- src/pytorch_lightning/CHANGELOG.md | 3 +++ .../loops/epoch/training_epoch_loop.py | 8 +------- src/pytorch_lightning/loops/fit_loop.py | 10 ++-------- tests/tests_pytorch/deprecated_api/test_remove_1-7.py | 10 ---------- 5 files changed, 7 insertions(+), 26 deletions(-) diff --git a/docs/source-pytorch/common/trainer.rst b/docs/source-pytorch/common/trainer.rst index 775b582307..ee4cd6c5c0 100644 --- a/docs/source-pytorch/common/trainer.rst +++ b/docs/source-pytorch/common/trainer.rst @@ -954,7 +954,7 @@ Training will stop if max_steps or max_epochs have reached (earliest). .. testcode:: # Default (disabled) - trainer = Trainer(max_steps=None) + trainer = Trainer(max_steps=-1) # Stop after 100 steps trainer = Trainer(max_steps=100) diff --git a/src/pytorch_lightning/CHANGELOG.md b/src/pytorch_lightning/CHANGELOG.md index b34d2a2f9b..340b6ae15e 100644 --- a/src/pytorch_lightning/CHANGELOG.md +++ b/src/pytorch_lightning/CHANGELOG.md @@ -264,6 +264,9 @@ The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/). - Removed the deprecated `test_transforms` argument from the `LightningDataModule` constructor ([#12773](https://github.com/PyTorchLightning/pytorch-lightning/pull/12773)) +- Removed deprecated `Trainer(max_steps=None)` ([#13591](https://github.com/Lightning-AI/lightning/pull/13591)) + + - Removed deprecated `dataloader_idx` argument from `on_train_batch_start/end` hooks `Callback` and `LightningModule` ([#12769](https://github.com/PyTorchLightning/pytorch-lightning/pull/12769), [#12977](https://github.com/PyTorchLightning/pytorch-lightning/pull/12977)) diff --git a/src/pytorch_lightning/loops/epoch/training_epoch_loop.py b/src/pytorch_lightning/loops/epoch/training_epoch_loop.py index 36a594b45a..630b3acf17 100644 --- a/src/pytorch_lightning/loops/epoch/training_epoch_loop.py +++ b/src/pytorch_lightning/loops/epoch/training_epoch_loop.py @@ -48,13 +48,7 @@ class TrainingEpochLoop(loops.Loop[_OUTPUTS_TYPE]): def __init__(self, min_steps: Optional[int] = None, max_steps: int = -1) -> None: super().__init__() - if max_steps is None: - rank_zero_deprecation( - "Setting `max_steps = None` is deprecated in v1.5 and will no longer be supported in v1.7." - " Use `max_steps = -1` instead." - ) - max_steps = -1 - elif max_steps < -1: + if max_steps < -1: raise MisconfigurationException( f"`max_steps` must be a non-negative integer or -1 (infinite steps). You passed in {max_steps}." ) diff --git a/src/pytorch_lightning/loops/fit_loop.py b/src/pytorch_lightning/loops/fit_loop.py index 0771a4a71d..ab63b0e6df 100644 --- a/src/pytorch_lightning/loops/fit_loop.py +++ b/src/pytorch_lightning/loops/fit_loop.py @@ -33,7 +33,7 @@ from pytorch_lightning.utilities.fetching import ( InterBatchParallelDataFetcher, ) from pytorch_lightning.utilities.model_helpers import is_overridden -from pytorch_lightning.utilities.rank_zero import rank_zero_deprecation, rank_zero_warn +from pytorch_lightning.utilities.rank_zero import rank_zero_warn from pytorch_lightning.utilities.signature_utils import is_param_in_hook_signature log = logging.getLogger(__name__) @@ -104,13 +104,7 @@ class FitLoop(Loop[None]): def max_steps(self, value: int) -> None: """Sets the maximum number of steps (forwards to epoch_loop)""" # TODO(@awaelchli): This setter is required by debugging connector (fast dev run), should be avoided - if value is None: - rank_zero_deprecation( - "Setting `max_steps = None` is deprecated in v1.5 and will no longer be supported in v1.7." - " Use `max_steps = -1` instead." - ) - value = -1 - elif value < -1: + if value < -1: raise MisconfigurationException( f"`max_steps` must be a non-negative integer or -1 (infinite steps). You passed in {value}." ) diff --git a/tests/tests_pytorch/deprecated_api/test_remove_1-7.py b/tests/tests_pytorch/deprecated_api/test_remove_1-7.py index 8ab04076f8..bf6ffdc33e 100644 --- a/tests/tests_pytorch/deprecated_api/test_remove_1-7.py +++ b/tests/tests_pytorch/deprecated_api/test_remove_1-7.py @@ -17,19 +17,9 @@ from re import escape import pytest import torch -from pytorch_lightning import Trainer from pytorch_lightning.strategies import SingleDeviceStrategy -def test_v1_7_0_deprecated_max_steps_none(tmpdir): - with pytest.deprecated_call(match="`max_steps = None` is deprecated in v1.5"): - _ = Trainer(max_steps=None) - - trainer = Trainer() - with pytest.deprecated_call(match="`max_steps = None` is deprecated in v1.5"): - trainer.fit_loop.max_steps = None - - def test_v1_7_0_post_dispatch_hook(): class CustomPlugin(SingleDeviceStrategy): def post_dispatch(self, trainer):