diff --git a/molecule/command/base.py b/molecule/command/base.py index 6948918894..d6cccdb89a 100644 --- a/molecule/command/base.py +++ b/molecule/command/base.py @@ -93,8 +93,11 @@ def execute_cmdline_scenarios(scenario_name, args, command_args, ansible_args=() :returns: None """ + glob_str = MOLECULE_GLOB + if scenario_name: + glob_str = glob_str.replace("*", scenario_name) scenarios = molecule.scenarios.Scenarios( - get_configs(args, command_args, ansible_args), scenario_name + get_configs(args, command_args, ansible_args, glob_str), scenario_name ) scenarios.print_matrix() for scenario in scenarios: @@ -157,7 +160,7 @@ def execute_scenario(scenario): scenario._remove_scenario_state_directory() -def get_configs(args, command_args, ansible_args=()): +def get_configs(args, command_args, ansible_args=(), glob_str=MOLECULE_GLOB): """ Glob the current directory for Molecule config files, instantiate config \ objects, and returns a list. @@ -176,14 +179,14 @@ def get_configs(args, command_args, ansible_args=()): command_args=command_args, ansible_args=ansible_args, ) - for c in glob.glob(MOLECULE_GLOB) + for c in glob.glob(glob_str) ] - _verify_configs(configs) + _verify_configs(configs, glob_str) return configs -def _verify_configs(configs): +def _verify_configs(configs, glob_str=MOLECULE_GLOB): """ Verify a Molecule config was found and returns None. @@ -200,7 +203,7 @@ def _verify_configs(configs): util.sysexit_with_message(msg) else: - msg = "'{}' glob failed. Exiting.".format(MOLECULE_GLOB) + msg = "'{}' glob failed. Exiting.".format(glob_str) util.sysexit_with_message(msg) diff --git a/molecule/test/unit/command/test_base.py b/molecule/test/unit/command/test_base.py index 21e4b6a7d5..26c27e5732 100644 --- a/molecule/test/unit/command/test_base.py +++ b/molecule/test/unit/command/test_base.py @@ -266,7 +266,7 @@ def test_get_configs(config_instance): def test_get_configs_calls_verify_configs(_patched_verify_configs): base.get_configs({}, {}) - _patched_verify_configs.assert_called_once_with([]) + _patched_verify_configs.assert_called_once_with([], "molecule/*/molecule.yml") def test_verify_configs(config_instance):