From f5e646ddcc28a0f6266090b06d871c152ac4b7e4 Mon Sep 17 00:00:00 2001 From: Julien Jerphanion Date: Wed, 4 Dec 2024 14:58:41 +0100 Subject: [PATCH] fix: Handle environment with empty or absent `dependencies` Signed-off-by: Julien Jerphanion --- libmamba/src/api/install.cpp | 14 ++++++++---- micromamba/tests/test_create.py | 39 +++++++++++++++++++++++++++++++++ 2 files changed, 49 insertions(+), 4 deletions(-) diff --git a/libmamba/src/api/install.cpp b/libmamba/src/api/install.cpp index ff33bcfa70..9e64576b08 100644 --- a/libmamba/src/api/install.cpp +++ b/libmamba/src/api/install.cpp @@ -110,9 +110,8 @@ namespace mamba } else { - LOG_ERROR << "No 'dependencies' specified in YAML spec file '" << file.string() - << "'"; - throw std::runtime_error("Invalid spec file. Aborting."); + // Empty of absent `dependencies` key + deps = YAML::Node(YAML::NodeType::Null); } YAML::Node final_deps; @@ -165,7 +164,14 @@ namespace mamba std::vector dependencies; try { - dependencies = final_deps.as>(); + if (final_deps.IsNull()) + { + dependencies = {}; + } + else + { + dependencies = final_deps.as>(); + } } catch (const YAML::Exception& e) { diff --git a/micromamba/tests/test_create.py b/micromamba/tests/test_create.py index 3d45da1852..51f78e3d40 100644 --- a/micromamba/tests/test_create.py +++ b/micromamba/tests/test_create.py @@ -1357,3 +1357,42 @@ def test_create_dry_run_json(tmp_path): } assert res == expected_output + + +env_spec_empty_dependencies = """ +name: empty_dependencies +channels: + - conda-forge +dependencies: [] +""" + +env_spec_absent_dependencies = """ +name: absent_dependencies +channels: + - conda-forge +""" + + +def test_create_empty_or_absent_dependencies(tmp_path): + env_prefix = tmp_path / "env-empty_dependencies" + # Write the env specification to a file and pass it to the create command + + with open(tmp_path / "env_spec_empty_dependencies.yaml", "w") as f: + f.write(env_spec_empty_dependencies) + + with open(tmp_path / "env_spec_absent_dependencies.yaml", "w") as f: + f.write(env_spec_absent_dependencies) + + # Create the environment with empty dependencies, check that it is created successfully + # and that no packages are installed in the environment + res = helpers.create( + "-p", env_prefix, "-f", tmp_path / "env_spec_empty_dependencies.yaml", "--json" + ) + assert res["success"] + + # Create the environment with absent dependencies, check that it is created successfully + # and that no packages are installed in the environment + res = helpers.create( + "-p", env_prefix, "-f", tmp_path / "env_spec_absent_dependencies.yaml", "--json" + ) + assert res["success"]