2022-08-05 08:31:19 +00:00
|
|
|
# Copyright The PyTorch Lightning team.
|
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
2022-08-12 08:24:04 +00:00
|
|
|
"""Test deprecated functionality which will be removed in v1.10.0."""
|
2022-09-19 14:07:16 +00:00
|
|
|
from re import escape
|
2022-09-04 19:43:08 +00:00
|
|
|
from unittest import mock
|
|
|
|
|
2022-09-03 13:03:39 +00:00
|
|
|
import numpy
|
2022-08-05 08:31:19 +00:00
|
|
|
import pytest
|
2022-09-03 13:03:39 +00:00
|
|
|
import torch
|
2022-09-07 15:25:23 +00:00
|
|
|
from torch.utils.data import DataLoader
|
2022-08-05 08:31:19 +00:00
|
|
|
|
2022-09-19 14:07:16 +00:00
|
|
|
from lightning_lite.accelerators import CUDAAccelerator as LiteCUDAAccelerator
|
|
|
|
from lightning_lite.accelerators import TPUAccelerator as LiteTPUAccelerator
|
2022-08-05 08:31:19 +00:00
|
|
|
from pytorch_lightning import Trainer
|
2022-09-12 16:00:14 +00:00
|
|
|
from pytorch_lightning.accelerators.cpu import CPUAccelerator
|
2022-10-05 09:10:29 +00:00
|
|
|
from pytorch_lightning.cli import LightningCLI
|
2022-09-03 12:16:28 +00:00
|
|
|
from pytorch_lightning.core.mixins.device_dtype_mixin import DeviceDtypeModuleMixin
|
2022-09-07 15:25:23 +00:00
|
|
|
from pytorch_lightning.demos.boring_classes import BoringModel, RandomDataset
|
2022-09-19 14:07:16 +00:00
|
|
|
from pytorch_lightning.lite import LightningLite
|
2022-08-12 08:24:04 +00:00
|
|
|
from pytorch_lightning.overrides import LightningDistributedModule, LightningParallelModule
|
|
|
|
from pytorch_lightning.overrides.base import unwrap_lightning_module
|
|
|
|
from pytorch_lightning.overrides.fairscale import LightningShardedDataParallel, unwrap_lightning_module_sharded
|
2022-09-12 11:19:32 +00:00
|
|
|
from pytorch_lightning.plugins.environments import LightningEnvironment
|
2022-08-12 08:24:04 +00:00
|
|
|
from pytorch_lightning.strategies.bagua import LightningBaguaModule
|
|
|
|
from pytorch_lightning.strategies.deepspeed import LightningDeepSpeedModule
|
2022-08-18 18:34:21 +00:00
|
|
|
from pytorch_lightning.strategies.utils import on_colab_kaggle
|
2022-10-13 13:29:50 +00:00
|
|
|
from pytorch_lightning.trainer.states import RunningStage, TrainerFn
|
2022-09-03 13:03:39 +00:00
|
|
|
from pytorch_lightning.utilities.apply_func import (
|
|
|
|
apply_to_collection,
|
|
|
|
apply_to_collections,
|
|
|
|
convert_to_tensors,
|
|
|
|
from_numpy,
|
|
|
|
move_data_to_device,
|
|
|
|
to_dtype_tensor,
|
|
|
|
TransferableDataType,
|
|
|
|
)
|
2022-09-03 12:33:22 +00:00
|
|
|
from pytorch_lightning.utilities.cloud_io import atomic_save, get_filesystem, load
|
2022-09-07 15:25:23 +00:00
|
|
|
from pytorch_lightning.utilities.data import has_iterable_dataset, has_len
|
|
|
|
from pytorch_lightning.utilities.device_parser import (
|
|
|
|
determine_root_gpu_device,
|
|
|
|
is_cuda_available,
|
|
|
|
num_cuda_devices,
|
|
|
|
parse_cpu_cores,
|
|
|
|
parse_gpu_ids,
|
2022-09-18 22:48:45 +00:00
|
|
|
parse_hpus,
|
2022-09-07 15:25:23 +00:00
|
|
|
parse_tpu_cores,
|
|
|
|
)
|
|
|
|
from pytorch_lightning.utilities.distributed import (
|
|
|
|
all_gather_ddp_if_available,
|
|
|
|
distributed_available,
|
|
|
|
gather_all_tensors,
|
|
|
|
get_default_process_group_backend_for_device,
|
|
|
|
init_dist_connection,
|
|
|
|
sync_ddp,
|
|
|
|
sync_ddp_if_available,
|
|
|
|
tpu_distributed,
|
|
|
|
)
|
|
|
|
from pytorch_lightning.utilities.optimizer import optimizer_to_device, optimizers_to_device
|
|
|
|
from pytorch_lightning.utilities.seed import pl_worker_init_function, reset_seed, seed_everything
|
2022-09-04 19:43:08 +00:00
|
|
|
from pytorch_lightning.utilities.xla_device import inner_f, pl_multi_process, XLADeviceUtils
|
2022-08-12 08:24:04 +00:00
|
|
|
from tests_pytorch.helpers.runif import RunIf
|
|
|
|
from tests_pytorch.helpers.utils import no_warning_call
|
2022-08-05 08:31:19 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_deprecated_amp_level():
|
|
|
|
with pytest.deprecated_call(match="Setting `amp_level` inside the `Trainer` is deprecated in v1.8.0"):
|
|
|
|
Trainer(amp_level="O3", amp_backend="apex")
|
2022-08-12 08:24:04 +00:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"wrapper_class",
|
|
|
|
[
|
|
|
|
LightningParallelModule,
|
|
|
|
LightningDistributedModule,
|
|
|
|
LightningBaguaModule,
|
|
|
|
LightningDeepSpeedModule,
|
|
|
|
pytest.param(LightningShardedDataParallel, marks=RunIf(fairscale=True)),
|
|
|
|
],
|
|
|
|
)
|
|
|
|
def test_v1_10_deprecated_pl_module_init_parameter(wrapper_class):
|
|
|
|
with no_warning_call(
|
|
|
|
DeprecationWarning, match=rf"The argument `pl_module` in `{wrapper_class.__name__}` is deprecated in v1.8.0"
|
|
|
|
):
|
|
|
|
wrapper_class(BoringModel())
|
|
|
|
|
|
|
|
with pytest.deprecated_call(
|
|
|
|
match=rf"The argument `pl_module` in `{wrapper_class.__name__}` is deprecated in v1.8.0"
|
|
|
|
):
|
|
|
|
wrapper_class(pl_module=BoringModel())
|
|
|
|
|
|
|
|
|
|
|
|
def test_v1_10_deprecated_unwrap_lightning_module():
|
|
|
|
with pytest.deprecated_call(match=r"The function `unwrap_lightning_module` is deprecated in v1.8.0"):
|
|
|
|
unwrap_lightning_module(BoringModel())
|
|
|
|
|
|
|
|
|
|
|
|
@RunIf(fairscale=True)
|
|
|
|
def test_v1_10_deprecated_unwrap_lightning_module_sharded():
|
|
|
|
with pytest.deprecated_call(match=r"The function `unwrap_lightning_module_sharded` is deprecated in v1.8.0"):
|
|
|
|
unwrap_lightning_module_sharded(BoringModel())
|
2022-08-18 18:34:21 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_v1_10_deprecated_on_colab_kaggle_func():
|
|
|
|
with pytest.deprecated_call(match="The function `on_colab_kaggle` has been deprecated in v1.8.0"):
|
|
|
|
on_colab_kaggle()
|
2022-09-03 12:16:28 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_v1_10_deprecated_device_dtype_module_mixin():
|
|
|
|
class MyModule(DeviceDtypeModuleMixin):
|
|
|
|
pass
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="mixins.DeviceDtypeModuleMixin` has been deprecated in v1.8.0"):
|
|
|
|
MyModule()
|
2022-09-04 19:43:08 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_v1_10_deprecated_xla_device_utilities():
|
|
|
|
with pytest.deprecated_call(match="xla_device.inner_f` has been deprecated in v1.8.0"):
|
|
|
|
inner_f(mock.Mock(), mock.Mock())
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="xla_device.pl_multi_process` has been deprecated in v1.8.0"):
|
|
|
|
pl_multi_process(mock.Mock)
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="xla_device.XLADeviceUtils` has been deprecated in v1.8.0"):
|
|
|
|
XLADeviceUtils()
|
|
|
|
|
2022-10-04 22:54:14 +00:00
|
|
|
with pytest.deprecated_call(match="xla_device.XLADeviceUtils.xla_available` has been deprecated in v1.8.0"):
|
2022-09-04 19:43:08 +00:00
|
|
|
XLADeviceUtils.xla_available()
|
|
|
|
|
2022-10-04 22:54:14 +00:00
|
|
|
with pytest.deprecated_call(match="xla_device.XLADeviceUtils.tpu_device_exists` has been deprecated in v1.8.0"):
|
2022-09-04 19:43:08 +00:00
|
|
|
XLADeviceUtils.tpu_device_exists()
|
2022-09-03 12:33:22 +00:00
|
|
|
|
2022-10-04 22:54:14 +00:00
|
|
|
from pytorch_lightning.utilities.distributed import tpu_distributed
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="tpu_distributed` has been deprecated in v1.8.0"):
|
|
|
|
tpu_distributed()
|
|
|
|
|
2022-09-03 12:33:22 +00:00
|
|
|
|
2022-09-03 13:03:39 +00:00
|
|
|
def test_v1_10_deprecated_apply_func_utilities():
|
|
|
|
with pytest.deprecated_call(match="apply_func.apply_to_collection` has been deprecated in v1.8.0"):
|
|
|
|
apply_to_collection([], dtype=object, function=(lambda x: x))
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="apply_func.apply_to_collections` has been deprecated in v1.8.0"):
|
|
|
|
apply_to_collections([], [], dtype=object, function=(lambda x, y: x))
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="apply_func.convert_to_tensors` has been deprecated in v1.8.0"):
|
|
|
|
convert_to_tensors([], torch.device("cpu"))
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="apply_func.from_numpy` has been deprecated in v1.8.0"):
|
|
|
|
from_numpy(numpy.zeros(2), torch.device("cpu"))
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="apply_func.move_data_to_device` has been deprecated in v1.8.0"):
|
|
|
|
move_data_to_device(torch.tensor(2), torch.device("cpu"))
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="apply_func.to_dtype_tensor` has been deprecated in v1.8.0"):
|
|
|
|
to_dtype_tensor(torch.tensor(2), dtype=torch.float32, device=torch.device("cpu"))
|
|
|
|
|
|
|
|
class MyModule(TransferableDataType):
|
|
|
|
pass
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="apply_func.TransferableDataType` has been deprecated in v1.8.0"):
|
|
|
|
MyModule()
|
2022-09-07 15:25:23 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_v1_10_deprecated_cloud_io_utilities(tmpdir):
|
|
|
|
with pytest.deprecated_call(match="cloud_io.atomic_save` has been deprecated in v1.8.0"):
|
|
|
|
atomic_save({}, tmpdir / "atomic_save.ckpt")
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="cloud_io.get_filesystem` has been deprecated in v1.8.0"):
|
|
|
|
get_filesystem(tmpdir)
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="cloud_io.load` has been deprecated in v1.8.0"):
|
|
|
|
load(str(tmpdir / "atomic_save.ckpt"))
|
|
|
|
|
|
|
|
|
|
|
|
def test_v1_10_deprecated_data_utilities():
|
|
|
|
with pytest.deprecated_call(match="data.has_iterable_dataset` has been deprecated in v1.8.0"):
|
|
|
|
has_iterable_dataset(DataLoader(RandomDataset(2, 4)))
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="data.has_len` has been deprecated in v1.8.0"):
|
|
|
|
has_len(DataLoader(RandomDataset(2, 4)))
|
|
|
|
|
|
|
|
|
|
|
|
def test_v1_10_deprecated_device_parser_utilities():
|
|
|
|
with pytest.deprecated_call(match="device_parser.determine_root_gpu_device` has been deprecated in v1.8.0"):
|
|
|
|
determine_root_gpu_device(None)
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="device_parser.is_cuda_available` has been deprecated in v1.8.0"):
|
|
|
|
is_cuda_available()
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="device_parser.num_cuda_devices` has been deprecated in v1.8.0"):
|
|
|
|
num_cuda_devices()
|
|
|
|
|
2022-09-18 22:48:45 +00:00
|
|
|
with pytest.deprecated_call(match="device_parser.parse_hpus` has been deprecated in v1.8.0"):
|
|
|
|
parse_hpus(1)
|
|
|
|
|
2022-09-07 15:25:23 +00:00
|
|
|
with pytest.deprecated_call(match="device_parser.parse_cpu_cores` has been deprecated in v1.8.0"):
|
|
|
|
parse_cpu_cores(1)
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="device_parser.parse_gpu_ids` has been deprecated in v1.8.0"):
|
|
|
|
parse_gpu_ids(None)
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="device_parser.parse_tpu_cores` has been deprecated in v1.8.0"):
|
|
|
|
parse_tpu_cores(None)
|
|
|
|
|
|
|
|
|
|
|
|
def test_v1_10_deprecated_distributed_utilities():
|
|
|
|
with pytest.deprecated_call(match="distributed.all_gather_ddp_if_available` has been deprecated in v1.8.0"):
|
|
|
|
all_gather_ddp_if_available(torch.tensor(1))
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="distributed.distributed_available` has been deprecated in v1.8.0"):
|
|
|
|
distributed_available()
|
|
|
|
|
|
|
|
with mock.patch("torch.distributed.get_world_size", return_value=2), mock.patch(
|
|
|
|
"torch.distributed.barrier"
|
|
|
|
), mock.patch("torch.distributed.all_gather"):
|
|
|
|
with pytest.deprecated_call(match="distributed.gather_all_tensors` has been deprecated in v1.8.0"):
|
|
|
|
gather_all_tensors(torch.tensor(1))
|
|
|
|
|
|
|
|
with pytest.deprecated_call(
|
|
|
|
match="distributed.get_default_process_group_backend_for_device` has been deprecated in v1.8.0"
|
|
|
|
):
|
|
|
|
get_default_process_group_backend_for_device(torch.device("cpu"))
|
|
|
|
|
|
|
|
with mock.patch("torch.distributed.is_initialized", return_value=True):
|
|
|
|
with pytest.deprecated_call(match="distributed.init_dist_connection` has been deprecated in v1.8.0"):
|
|
|
|
init_dist_connection(LightningEnvironment(), "gloo")
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="distributed.sync_ddp_if_available` has been deprecated in v1.8.0"):
|
|
|
|
sync_ddp_if_available(torch.tensor(1))
|
|
|
|
|
|
|
|
with mock.patch("torch.distributed.barrier"), mock.patch("torch.distributed.all_reduce"):
|
|
|
|
with pytest.deprecated_call(match="distributed.sync_ddp` has been deprecated in v1.8.0"):
|
|
|
|
sync_ddp(torch.tensor(1))
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="distributed.tpu_distributed` has been deprecated in v1.8.0"):
|
|
|
|
tpu_distributed()
|
|
|
|
|
|
|
|
|
|
|
|
def test_v1_10_deprecated_optimizer_utilities():
|
|
|
|
with pytest.deprecated_call(match="optimizer.optimizers_to_device` has been deprecated in v1.8.0"):
|
|
|
|
optimizers_to_device([torch.optim.Adam(torch.nn.Linear(1, 1).parameters())], "cpu")
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="optimizer.optimizer_to_device` has been deprecated in v1.8.0"):
|
|
|
|
optimizer_to_device(torch.optim.Adam(torch.nn.Linear(1, 1).parameters()), "cpu")
|
|
|
|
|
|
|
|
|
|
|
|
def test_v1_10_deprecated_seed_utilities():
|
|
|
|
with pytest.deprecated_call(match="seed.seed_everything` has been deprecated in v1.8.0"):
|
|
|
|
seed_everything(1)
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="seed.reset_seed` has been deprecated in v1.8.0"):
|
|
|
|
reset_seed()
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="seed.pl_worker_init_function` has been deprecated in v1.8.0"):
|
|
|
|
pl_worker_init_function(0)
|
2022-09-12 16:00:14 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_v1_10_deprecated_accelerator_setup_environment_method():
|
|
|
|
with pytest.deprecated_call(match="`Accelerator.setup_environment` has been deprecated in deprecated in v1.8.0"):
|
|
|
|
CPUAccelerator().setup_environment(torch.device("cpu"))
|
2022-09-19 14:07:16 +00:00
|
|
|
|
|
|
|
|
|
|
|
class EmptyLite(LightningLite):
|
|
|
|
def run(self):
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
def test_lite_convert_deprecated_gpus_argument(cuda_count_2):
|
|
|
|
with pytest.deprecated_call(match=escape("Setting `Lite(gpus=2)` is deprecated in v1.8.0")):
|
|
|
|
lite = EmptyLite(gpus=2)
|
|
|
|
assert isinstance(lite._accelerator, LiteCUDAAccelerator)
|
|
|
|
assert lite._connector._parallel_devices == [torch.device("cuda", 0), torch.device("cuda", 1)]
|
|
|
|
|
|
|
|
|
|
|
|
@RunIf(skip_windows=True)
|
2022-10-04 22:54:14 +00:00
|
|
|
def test_lite_convert_deprecated_tpus_argument(tpu_available):
|
2022-09-19 14:07:16 +00:00
|
|
|
with pytest.deprecated_call(match=escape("Setting `Lite(tpu_cores=8)` is deprecated in v1.8.0")):
|
|
|
|
lite = EmptyLite(tpu_cores=8)
|
|
|
|
assert isinstance(lite._accelerator, LiteTPUAccelerator)
|
|
|
|
assert lite._connector._parallel_devices == list(range(8))
|
2022-10-05 09:10:29 +00:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
["name", "value"],
|
|
|
|
[("save_config_filename", "config.yaml"), ("save_config_overwrite", False), ("save_config_multifile", False)],
|
|
|
|
)
|
|
|
|
def test_lightningCLI_save_config_init_params_deprecation_warning(name, value):
|
|
|
|
with mock.patch("sys.argv", ["any.py"]), pytest.deprecated_call(match=f".*{name!r} init parameter is deprecated.*"):
|
|
|
|
LightningCLI(BoringModel, run=False, **{name: value})
|
2022-10-13 13:29:50 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_tuning_enum():
|
|
|
|
with pytest.deprecated_call(
|
|
|
|
match="`TrainerFn.TUNING` has been deprecated in v1.8.0 and will be removed in v1.10.0."
|
|
|
|
):
|
|
|
|
TrainerFn.TUNING
|
|
|
|
|
|
|
|
with pytest.deprecated_call(
|
|
|
|
match="`RunningStage.TUNING` has been deprecated in v1.8.0 and will be removed in v1.10.0."
|
|
|
|
):
|
|
|
|
RunningStage.TUNING
|
|
|
|
|
|
|
|
|
|
|
|
def test_tuning_trainer_property():
|
|
|
|
trainer = Trainer()
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="`Trainer.tuning` has been deprecated in v1.8.0 and will be removed in v1.10.0."):
|
|
|
|
trainer.tuning
|
|
|
|
|
|
|
|
with pytest.deprecated_call(
|
|
|
|
match="Setting `Trainer.tuning` has been deprecated in v1.8.0 and will be removed in v1.10.0."
|
|
|
|
):
|
|
|
|
trainer.tuning = True
|
2022-10-28 19:51:27 +00:00
|
|
|
|
|
|
|
|
|
|
|
@RunIf(skip_windows=True)
|
|
|
|
def test_v1_8_0_deprecated_all_gather_grad():
|
|
|
|
tensor1 = torch.ones(1, requires_grad=True)
|
|
|
|
with mock.patch("torch.distributed.all_gather"), mock.patch("torch.distributed.get_world_size", return_value=1):
|
|
|
|
from pytorch_lightning.utilities import AllGatherGrad
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="`AllGatherGrad` has been deprecated in v1.8"):
|
|
|
|
AllGatherGrad.apply(tensor1)
|
2022-11-07 19:23:30 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_v1_8_1_deprecated_rank_zero_only():
|
|
|
|
from pytorch_lightning.utilities.distributed import rank_zero_only
|
|
|
|
|
|
|
|
with pytest.deprecated_call(match="rank_zero_only` has been deprecated in v1.8.1"):
|
|
|
|
rank_zero_only(lambda: None)
|