2022-02-09 22:39:41 +00:00
|
|
|
# Copyright The Lightning AI 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-03-04 23:01:43 +00:00
|
|
|
import pytest
|
2023-02-02 10:06:45 +00:00
|
|
|
from lightning.pytorch import Trainer
|
|
|
|
from lightning.pytorch.loggers import TensorBoardLogger
|
ruff: replace isort with ruff +TPU (#17684)
* ruff: replace isort with ruff
* [pre-commit.ci] auto fixes from pre-commit.com hooks
for more information, see https://pre-commit.ci
* fixing & imports
* lines in warning test
* docs
* fix enum import
* [pre-commit.ci] auto fixes from pre-commit.com hooks
for more information, see https://pre-commit.ci
* [pre-commit.ci] auto fixes from pre-commit.com hooks
for more information, see https://pre-commit.ci
* [pre-commit.ci] auto fixes from pre-commit.com hooks
for more information, see https://pre-commit.ci
* [pre-commit.ci] auto fixes from pre-commit.com hooks
for more information, see https://pre-commit.ci
* [pre-commit.ci] auto fixes from pre-commit.com hooks
for more information, see https://pre-commit.ci
* [pre-commit.ci] auto fixes from pre-commit.com hooks
for more information, see https://pre-commit.ci
* [pre-commit.ci] auto fixes from pre-commit.com hooks
for more information, see https://pre-commit.ci
* [pre-commit.ci] auto fixes from pre-commit.com hooks
for more information, see https://pre-commit.ci
* [pre-commit.ci] auto fixes from pre-commit.com hooks
for more information, see https://pre-commit.ci
* [pre-commit.ci] auto fixes from pre-commit.com hooks
for more information, see https://pre-commit.ci
* [pre-commit.ci] auto fixes from pre-commit.com hooks
for more information, see https://pre-commit.ci
* [pre-commit.ci] auto fixes from pre-commit.com hooks
for more information, see https://pre-commit.ci
* fixing
* import
* fix lines
* [pre-commit.ci] auto fixes from pre-commit.com hooks
for more information, see https://pre-commit.ci
* type ClusterEnvironment
* [pre-commit.ci] auto fixes from pre-commit.com hooks
for more information, see https://pre-commit.ci
---------
Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
2023-09-26 15:54:55 +00:00
|
|
|
|
2022-06-15 22:10:49 +00:00
|
|
|
from tests_pytorch.loggers.test_logger import CustomLogger
|
2022-02-09 22:39:41 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_trainer_loggers_property():
|
|
|
|
"""Test for correct initialization of loggers in Trainer."""
|
|
|
|
logger1 = CustomLogger()
|
|
|
|
logger2 = CustomLogger()
|
|
|
|
|
|
|
|
# trainer.loggers should be a copy of the input list
|
|
|
|
trainer = Trainer(logger=[logger1, logger2])
|
|
|
|
|
|
|
|
assert trainer.loggers == [logger1, logger2]
|
|
|
|
|
|
|
|
# trainer.loggers should create a list of size 1
|
|
|
|
trainer = Trainer(logger=logger1)
|
|
|
|
|
2022-02-26 00:01:04 +00:00
|
|
|
assert trainer.logger == logger1
|
2022-02-09 22:39:41 +00:00
|
|
|
assert trainer.loggers == [logger1]
|
|
|
|
|
|
|
|
# trainer.loggers should be a list of size 1 holding the default logger
|
|
|
|
trainer = Trainer(logger=True)
|
|
|
|
|
|
|
|
assert trainer.loggers == [trainer.logger]
|
2022-02-26 00:01:04 +00:00
|
|
|
assert isinstance(trainer.logger, TensorBoardLogger)
|
2022-02-09 22:39:41 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_trainer_loggers_setters():
|
|
|
|
"""Test the behavior of setters for trainer.logger and trainer.loggers."""
|
|
|
|
logger1 = CustomLogger()
|
|
|
|
logger2 = CustomLogger()
|
|
|
|
|
|
|
|
trainer = Trainer()
|
2023-10-31 01:16:02 +00:00
|
|
|
assert type(trainer.logger) is TensorBoardLogger
|
2022-02-09 22:39:41 +00:00
|
|
|
assert trainer.loggers == [trainer.logger]
|
|
|
|
|
|
|
|
# Test setters for trainer.logger
|
|
|
|
trainer.logger = logger1
|
|
|
|
assert trainer.logger == logger1
|
|
|
|
assert trainer.loggers == [logger1]
|
|
|
|
|
|
|
|
trainer.logger = None
|
|
|
|
assert trainer.logger is None
|
|
|
|
assert trainer.loggers == []
|
|
|
|
|
|
|
|
# Test setters for trainer.loggers
|
|
|
|
trainer.loggers = [logger1, logger2]
|
|
|
|
assert trainer.loggers == [logger1, logger2]
|
|
|
|
|
|
|
|
trainer.loggers = [logger1]
|
|
|
|
assert trainer.loggers == [logger1]
|
|
|
|
assert trainer.logger == logger1
|
|
|
|
|
|
|
|
trainer.loggers = []
|
|
|
|
assert trainer.loggers == []
|
|
|
|
assert trainer.logger is None
|
|
|
|
|
|
|
|
trainer.loggers = None
|
|
|
|
assert trainer.loggers == []
|
|
|
|
assert trainer.logger is None
|
2022-03-18 02:18:28 +00:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"logger_value",
|
|
|
|
[
|
|
|
|
False,
|
|
|
|
[],
|
|
|
|
],
|
|
|
|
)
|
2024-03-17 05:41:51 +00:00
|
|
|
def test_no_logger(tmp_path, logger_value):
|
2022-03-18 02:18:28 +00:00
|
|
|
"""Test the cases where logger=None, logger=False, logger=[] are passed to Trainer."""
|
|
|
|
trainer = Trainer(
|
|
|
|
logger=logger_value,
|
2024-03-17 05:41:51 +00:00
|
|
|
default_root_dir=tmp_path,
|
2022-03-18 02:18:28 +00:00
|
|
|
max_steps=1,
|
|
|
|
)
|
|
|
|
assert trainer.logger is None
|
|
|
|
assert trainer.loggers == []
|
2024-03-17 05:41:51 +00:00
|
|
|
assert trainer.log_dir == str(tmp_path)
|