From 6f1c01094cea839402a74adca11a25c43072aea2 Mon Sep 17 00:00:00 2001 From: Michael Sarahan Date: Tue, 13 Aug 2024 17:14:21 -0500 Subject: [PATCH 1/2] Avoid undefined jinja errors for skipped recipes --- conda_build/metadata.py | 4 ++++ news/5458-avoid-undefined-jinja-in-skipped | 19 +++++++++++++++++ tests/test_metadata.py | 24 ++++++++++++++++++++++ 3 files changed, 47 insertions(+) create mode 100644 news/5458-avoid-undefined-jinja-in-skipped diff --git a/conda_build/metadata.py b/conda_build/metadata.py index c254329d28..071036bd0c 100644 --- a/conda_build/metadata.py +++ b/conda_build/metadata.py @@ -1338,6 +1338,10 @@ def parse_until_resolved( ) self.final = final + if self.skip(): + self.final = True + return + # recursively parse again so long as each iteration has fewer undefined jinja variables undefined_jinja_vars = () while set(undefined_jinja_vars) != set(self.undefined_jinja_vars): diff --git a/news/5458-avoid-undefined-jinja-in-skipped b/news/5458-avoid-undefined-jinja-in-skipped new file mode 100644 index 0000000000..29fcc26c4c --- /dev/null +++ b/news/5458-avoid-undefined-jinja-in-skipped @@ -0,0 +1,19 @@ +### Enhancements + +* + +### Bug fixes + +* Allow undefined jinja variables when a particular metadata block evaluates as skipped + +### Deprecations + +* + +### Docs + +* + +### Other + +* diff --git a/tests/test_metadata.py b/tests/test_metadata.py index b8dc9df8e4..99b26dd424 100644 --- a/tests/test_metadata.py +++ b/tests/test_metadata.py @@ -623,3 +623,27 @@ def test_parse_until_resolved(testing_metadata: MetaData, tmp_path: Path) -> Non match=("Failed to render jinja template"), ): testing_metadata.parse_until_resolved() + + +def test_parse_until_resolved_skip_avoids_undefined_jinja( + testing_metadata: MetaData, tmp_path: Path +) -> None: + (recipe := tmp_path / (name := "meta.yaml")).write_text( + """ +package: + name: dummy + version: {{version}} +build: + skip: True +""" + ) + testing_metadata._meta_path = recipe + testing_metadata._meta_name = name + + # because skip is True, we should not error out here - so no exception should be raised + try: + testing_metadata.parse_until_resolved() + except CondaBuildUserError: + pytest.fail( + "Undefined variable caused error, even though this build is skipped" + ) From 1bfece626375b42904091861a4070d81afd2a5c9 Mon Sep 17 00:00:00 2001 From: Bianca Henderson Date: Thu, 22 Aug 2024 11:40:49 -0400 Subject: [PATCH 2/2] Update news/5458-avoid-undefined-jinja-in-skipped --- news/5458-avoid-undefined-jinja-in-skipped | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/news/5458-avoid-undefined-jinja-in-skipped b/news/5458-avoid-undefined-jinja-in-skipped index 29fcc26c4c..e1c232a65e 100644 --- a/news/5458-avoid-undefined-jinja-in-skipped +++ b/news/5458-avoid-undefined-jinja-in-skipped @@ -4,7 +4,7 @@ ### Bug fixes -* Allow undefined jinja variables when a particular metadata block evaluates as skipped +* Allow undefined jinja variables when a particular metadata block evaluates as skipped. (#5458) ### Deprecations