diff --git a/swh/deposit/cli/client.py b/swh/deposit/cli/client.py --- a/swh/deposit/cli/client.py +++ b/swh/deposit/cli/client.py @@ -251,6 +251,20 @@ "Please provide an actionable command. See --help for more information" ) + if metadata: + from swh.deposit.utils import parse_xml + + metadata_raw = open(metadata, "r").read() + metadata_dict = parse_xml(metadata_raw).get("swh:deposit", {}) + if ( + "swh:create_origin" not in metadata_dict + and "swh:add_to_origin" not in metadata_dict + ): + logger.warning( + "The metadata file provided should at least contain one " + '"" or "" tag', + ) + if replace and not deposit_id: raise InputError("To update an existing deposit, you must provide its id") diff --git a/swh/deposit/tests/cli/test_client.py b/swh/deposit/tests/cli/test_client.py --- a/swh/deposit/tests/cli/test_client.py +++ b/swh/deposit/tests/cli/test_client.py @@ -805,3 +805,73 @@ catch_exceptions=False, ) # fmt: on + + +def test_cli_deposit_warning_when_incomplete( + sample_archive, caplog, patched_tmp_path, cli_runner +): + """ Deposit failure due to maintenance down time should be explicit + + """ + # fmt: off + cli_runner.invoke( + cli, + [ + "upload", + "--url", "https://deposit.swh.test/1", + "--username", TEST_USER["username"], + "--password", TEST_USER["password"], + "--name", "test-project", + "--archive", sample_archive["path"], + "--author", "Jane Doe", + ], + ) + # fmt: on + + # we only care for the presence of the warning due to the missing presence of + # create_origin or add_to_origin, so we do not check anything else + warning_log_record = ( + "swh.deposit.cli.client", + logging.WARNING, + "The metadata file provided should at least contain one " + '"" or "" tag', + ) + assert warning_log_record in caplog.record_tuples + + +@pytest.mark.parametrize( + "metadata_entry_key", ["entry-data-with-add-to-origin", "entry-only-create-origin"] +) +def test_cli_deposit_no_warning_when_origin_tags_present( + metadata_entry_key, tmp_path, atom_dataset, caplog, patched_tmp_path, cli_runner +): + """ Deposit failure due to maintenance down time should be explicit + + """ + metadata_raw = atom_dataset[metadata_entry_key] % "some-url" + metadata_path = os.path.join(tmp_path, "metadata-with-origin-tag-to-deposit.xml") + with open(metadata_path, "w") as f: + f.write(metadata_raw) + + # fmt: off + cli_runner.invoke( + cli, + [ + "upload", + "--url", "https://deposit.swh.test/1", + "--username", TEST_USER["username"], + "--password", TEST_USER["password"], + "--metadata", metadata_path, + ], + ) + # fmt: on + + # we only care for the absence of the warning + # As either or is present + warning_log_record = ( + "swh.deposit.cli.client", + logging.WARNING, + "The metadata file provided should at least contain one " + '"" or "" tag', + ) + assert warning_log_record not in caplog.record_tuples