Skip to content

Commit

Permalink
Merge pull request #2555 from SFDO-Tooling/feature/named-services-fix
Browse files Browse the repository at this point in the history
Named service fixes
  • Loading branch information
David Glick authored Apr 19, 2021
2 parents 2a52ee1 + a557e60 commit a517090
Show file tree
Hide file tree
Showing 3 changed files with 16 additions and 18 deletions.
13 changes: 8 additions & 5 deletions cumulusci/cli/service.py
Original file line number Diff line number Diff line change
Expand Up @@ -126,7 +126,11 @@ def get_command(self, ctx, service_type):

def callback(*args, **kwargs):
service_name = kwargs["service_name"]
if service_name in runtime.keychain.list_services()[service_type]:
configured_services = runtime.keychain.list_services()
if (
service_type in configured_services
and service_name in configured_services[service_type]
):
click.confirm(
f"There is already a {service_type}:{service_name} service. Do you want to overwrite it?",
abort=True,
Expand Down Expand Up @@ -263,10 +267,9 @@ def service_rename(runtime, service_type, current_name, new_name):
@pass_runtime(require_project=False, require_keychain=True)
def service_remove(runtime, service_type, service_name):
new_default = None
if (
len(runtime.keychain.services[service_type].keys()) > 2
and service_name == runtime.keychain._default_services[service_type]
):
if len(
runtime.keychain.services.get(service_type, {}).keys()
) > 2 and service_name == runtime.keychain._default_services.get(service_type):
click.echo(
f"The service you would like to remove is currently the default for {service_type} services."
)
Expand Down
18 changes: 7 additions & 11 deletions cumulusci/core/keychain/encrypted_file_project_keychain.py
Original file line number Diff line number Diff line change
Expand Up @@ -352,10 +352,9 @@ def _set_default_services_from_dir(self, default_services_file: Path) -> None:
@param default_services_file path to a DEFAULT_SERVICES.json file
"""
if default_services_file.is_file():
default_services = self._read_default_services(default_services_file)
for s_type, alias in default_services.items():
self._default_services[s_type] = alias
default_services = self._read_default_services(default_services_file)
for s_type, alias in default_services.items():
self._default_services[s_type] = alias

def _save_default_service(
self, service_type: str, alias: str, project: bool = False
Expand Down Expand Up @@ -504,12 +503,9 @@ def _read_default_services(self, file_path: Path) -> T.Dict[str, str]:
@raises CumulusCIException if the file does not exist
"""
if not file_path.is_file() or file_path.name != DEFAULT_SERVICES_FILENAME:
raise CumulusCIException(
f"No {DEFAULT_SERVICES_FILENAME} file found at: {file_path}"
)

with open(file_path, "r") as f:
return json.loads(f.read())
return {}
else:
return json.loads(file_path.read_text(encoding="utf-8"))

def _write_default_services(
self, file_path: Path, default_services: T.Dict[str, str]
Expand All @@ -525,7 +521,7 @@ def _write_default_services(
f"No {DEFAULT_SERVICES_FILENAME} file found at: {file_path}"
)

with open(file_path, "w") as f:
with open(file_path, "w", encoding="utf-8") as f:
f.write(json.dumps(default_services))

def _iter_local_project_dirs(self):
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -610,8 +610,7 @@ def test_read_default_services(self, keychain):
assert actual_defaults == expected_defaults

def test_read_default_services__file_does_not_exist(self, keychain):
with pytest.raises(CumulusCIException):
keychain._read_default_services(Path("not-a-valid-filepath"))
assert keychain._read_default_services(Path("not-a-valid-filepath")) == {}

def test_write_default_services(self, keychain):
expected_defaults = {
Expand Down

0 comments on commit a517090

Please sign in to comment.