Fixed error when using W&B project name from environment variables (#16222)

Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
Co-authored-by: Jirka <jirka.borovec@seznam.cz>
Co-authored-by: Jirka Borovec <6035284+Borda@users.noreply.github.com>
Co-authored-by: Adrian Wälchli <aedu.waelchli@gmail.com>
This commit is contained in:
Manan Goel 2023-05-20 19:42:48 -07:00 committed by GitHub
parent 61246c3b35
commit 4d5df5fa8a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 20 additions and 4 deletions

View File

@ -126,6 +126,9 @@ The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/).
- Fixed a formatting issue when the filename in `ModelCheckpoint` contained metrics that were substrings of each other ([#17610](https://github.com/Lightning-AI/lightning/pull/17610)) - Fixed a formatting issue when the filename in `ModelCheckpoint` contained metrics that were substrings of each other ([#17610](https://github.com/Lightning-AI/lightning/pull/17610))
- Fixed `WandbLogger` ignoring the `WANDB_PROJECT` environment variable ([#16222](https://github.com/Lightning-AI/lightning/pull/16222))
## [2.0.1.post0] - 2023-04-11 ## [2.0.1.post0] - 2023-04-11
### Fixed ### Fixed

View File

@ -260,7 +260,8 @@ class WandbLogger(Logger):
dir: Same as save_dir. dir: Same as save_dir.
id: Same as version. id: Same as version.
anonymous: Enables or explicitly disables anonymous logging. anonymous: Enables or explicitly disables anonymous logging.
project: The name of the project to which this run will belong. project: The name of the project to which this run will belong. If not set, the environment variable
`WANDB_PROJECT` will be used as a fallback. If both are not set, it defaults to ``'lightning_logs'``.
log_model: Log checkpoints created by :class:`~lightning.pytorch.callbacks.ModelCheckpoint` log_model: Log checkpoints created by :class:`~lightning.pytorch.callbacks.ModelCheckpoint`
as W&B artifacts. `latest` and `best` aliases are automatically set. as W&B artifacts. `latest` and `best` aliases are automatically set.
@ -293,7 +294,7 @@ class WandbLogger(Logger):
dir: Optional[_PATH] = None, dir: Optional[_PATH] = None,
id: Optional[str] = None, id: Optional[str] = None,
anonymous: Optional[bool] = None, anonymous: Optional[bool] = None,
project: str = "lightning_logs", project: Optional[str] = None,
log_model: Union[str, bool] = False, log_model: Union[str, bool] = False,
experiment: Union[Run, RunDisabled, None] = None, experiment: Union[Run, RunDisabled, None] = None,
prefix: str = "", prefix: str = "",
@ -334,6 +335,8 @@ class WandbLogger(Logger):
elif dir is not None: elif dir is not None:
dir = os.fspath(dir) dir = os.fspath(dir)
project = project or os.environ.get("WANDB_PROJECT", "lightning_logs")
# set wandb init arguments # set wandb init arguments
self._wandb_init: Dict[str, Any] = { self._wandb_init: Dict[str, Any] = {
"name": name, "name": name,

View File

@ -29,10 +29,20 @@ from lightning.pytorch.utilities.exceptions import MisconfigurationException
@mock.patch("lightning.pytorch.loggers.wandb.Run", new=mock.Mock) @mock.patch("lightning.pytorch.loggers.wandb.Run", new=mock.Mock)
@mock.patch("lightning.pytorch.loggers.wandb.wandb") @mock.patch("lightning.pytorch.loggers.wandb.wandb")
def test_wandb_project_name(*_): def test_wandb_project_name(*_):
logger = WandbLogger() with mock.patch.dict(os.environ, {}):
logger = WandbLogger()
assert logger.name == "lightning_logs" assert logger.name == "lightning_logs"
logger = WandbLogger(project="project") with mock.patch.dict(os.environ, {}):
logger = WandbLogger(project="project")
assert logger.name == "project"
with mock.patch.dict(os.environ, {"WANDB_PROJECT": "env_project"}):
logger = WandbLogger()
assert logger.name == "env_project"
with mock.patch.dict(os.environ, {"WANDB_PROJECT": "env_project"}):
logger = WandbLogger(project="project")
assert logger.name == "project" assert logger.name == "project"