def test_flush_n_steps(tmpdir): logger = CSVLogger(tmpdir, flush_logs_every_n_steps=2) metrics = { "float": 0.3, "int": 1, "FloatTensor": torch.tensor(0.1), "IntTensor": torch.tensor(1) } logger.save = MagicMock() logger.log_metrics(metrics, step=0) logger.save.assert_not_called() logger.log_metrics(metrics, step=1) logger.save.assert_called_once()
def test_file_logger_log_metrics(tmpdir, step_idx): logger = CSVLogger(tmpdir) metrics = { "float": 0.3, "int": 1, "FloatTensor": torch.tensor(0.1), "IntTensor": torch.tensor(1) } logger.log_metrics(metrics, step_idx) logger.save() path_csv = os.path.join(logger.log_dir, ExperimentWriter.NAME_METRICS_FILE) with open(path_csv) as fp: lines = fp.readlines() assert len(lines) == 2 assert all(n in lines[0] for n in metrics)