From 6ba479823ec891281c63c36843cbf15b5d596ddc Mon Sep 17 00:00:00 2001 From: Simon Gerber Date: Mon, 17 Jun 2024 11:11:13 +0200 Subject: [PATCH 1/2] Ensure that we can update components that have been rendered from old template versions We fall back to the Commodore default values for `automerge_patch` , `automerge_patch_v0` and `auto_release` if an existing `.cruft.json` doesn't have those cookiecutter args. --- commodore/component/template.py | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/commodore/component/template.py b/commodore/component/template.py index 0ed365f7..e6241128 100644 --- a/commodore/component/template.py +++ b/commodore/component/template.py @@ -107,9 +107,11 @@ def _initialize_from_cookiecutter_args(self, cookiecutter_args: dict[str, str]): self.library = cookiecutter_args["add_lib"] == "y" self.post_process = cookiecutter_args["add_pp"] == "y" self.matrix_tests = cookiecutter_args["add_matrix"] == "y" - self.automerge_patch = cookiecutter_args["automerge_patch"] == "y" - self.automerge_patch_v0 = cookiecutter_args["automerge_patch_v0"] == "y" - self.autorelease = cookiecutter_args["auto_release"] == "y" + self.automerge_patch = cookiecutter_args.get("automerge_patch", "y") == "y" + self.automerge_patch_v0 = ( + cookiecutter_args.get("automerge_patch_v0", "n") == "y" + ) + self.autorelease = cookiecutter_args.get("auto_release", "y") == "y" self._initialize_automerge_pattern_lists_from_cookiecutter_args( cookiecutter_args From ba0be416323bb5be1c96b3592b30e0ee57244ce3 Mon Sep 17 00:00:00 2001 From: Simon Gerber Date: Mon, 17 Jun 2024 11:22:28 +0200 Subject: [PATCH 2/2] Add test for initializing `ComponentTemplater` when automerge options are missing in `.cruft.json` --- tests/test_component_template.py | 38 ++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) diff --git a/tests/test_component_template.py b/tests/test_component_template.py index 8aea1e70..984cd360 100644 --- a/tests/test_component_template.py +++ b/tests/test_component_template.py @@ -1896,3 +1896,41 @@ def test_component_templater_read_from_modulesync_config( assert t.cookiecutter_args["copyright_holder"] == expected_holder assert t.cookiecutter_args["copyright_year"] == expected_year + + +def test_component_templater_read_from_old_cruft_json( + tmp_path: P, + cli_runner: RunnerFunc, + config: Config, +): + component_name = "test-component" + call_component_new(tmp_path, cli_runner, component_name) + component_path = tmp_path / "dependencies" / component_name + r = Repo(component_path) + + with open(component_path / ".cruft.json", "r", encoding="utf-8") as f: + cruft_json = json.load(f) + + # remove all the automerge settings from the cruft json + del cruft_json["context"]["cookiecutter"]["automerge_patch"] + del cruft_json["context"]["cookiecutter"]["automerge_patch_v0"] + del cruft_json["context"]["cookiecutter"]["auto_release"] + del cruft_json["context"]["cookiecutter"]["automerge_patch_regexp_blocklist"] + del cruft_json["context"]["cookiecutter"]["automerge_patch_v0_regexp_allowlist"] + del cruft_json["context"]["cookiecutter"]["automerge_minor_regexp_allowlist"] + + with open(component_path / ".cruft.json", "w", encoding="utf-8") as f: + json.dump(cruft_json, f, indent=2) + f.write("\n") + r.index.add([".cruft.json"]) + + r.index.commit("Update component template metadata") + + t = template.ComponentTemplater.from_existing(config, component_path) + + assert t.cookiecutter_args["automerge_patch"] == "y" + assert t.cookiecutter_args["automerge_patch_v0"] == "n" + assert t.cookiecutter_args["auto_release"] == "y" + assert t.cookiecutter_args["automerge_patch_regexp_blocklist"] == "" + assert t.cookiecutter_args["automerge_patch_v0_regexp_allowlist"] == "" + assert t.cookiecutter_args["automerge_minor_regexp_allowlist"] == ""