From a493e15aa0f7fe65f437a723292e255f55b91045 Mon Sep 17 00:00:00 2001 From: to-bar <46519524+to-bar@users.noreply.github.com> Date: Thu, 26 Nov 2020 10:24:05 +0100 Subject: [PATCH] epicli upgrade fails when there is no kubernetes_master group in inventory (#1876) * Require repository group in inventory * Update changelog --- CHANGELOG-0.9.md | 1 + .../engine/ansible/AnsibleInventoryUpgrade.py | 25 +++++++------------ 2 files changed, 10 insertions(+), 16 deletions(-) diff --git a/CHANGELOG-0.9.md b/CHANGELOG-0.9.md index 1d1980d0f9..c9ae8165e6 100644 --- a/CHANGELOG-0.9.md +++ b/CHANGELOG-0.9.md @@ -14,6 +14,7 @@ - [#1833](https://github.com/epiphany-platform/epiphany/issues/1833) - DaemonSets of Node Exporter and Filebeat deploy in default namespace - [#1872](https://github.com/epiphany-platform/epiphany/issues/1872) - pythonPath in launch.json is not supported - [#1868](https://github.com/epiphany-platform/epiphany/issues/1868) - Repository host runs Ubuntu on Azure/RHEL cluster +- [#1875](https://github.com/epiphany-platform/epiphany/issues/1875) - epicli upgrade fails when there is no kubernetes_master group in inventory ### Updated diff --git a/core/src/epicli/cli/engine/ansible/AnsibleInventoryUpgrade.py b/core/src/epicli/cli/engine/ansible/AnsibleInventoryUpgrade.py index c49ccb3eb8..7a33560ef9 100644 --- a/core/src/epicli/cli/engine/ansible/AnsibleInventoryUpgrade.py +++ b/core/src/epicli/cli/engine/ansible/AnsibleInventoryUpgrade.py @@ -101,26 +101,19 @@ def upgrade(self): merge_objdict(default_cluster_model, self.cluster_model) self.cluster_model = default_cluster_model - # Check if repo roles are present and if not add them - master = self.get_role(new_inventory, 'kubernetes_master') - if master == None: - raise Exception('No kubernetes_master to use as repository') - master_node = master.hosts[0] + # repository & image_registry roles added in v0.4.0 + repository = self.get_role(new_inventory, 'repository') + if repository is None: + raise Exception('repository group not found in inventory. ' + 'Your deployment may not be supported by this version of Epiphany. ' + 'You may try to use older version first.') - # add image_registry + # add image_registry if not present image_registry = self.get_role(new_inventory, 'image_registry') - if image_registry == None: - hosts = [] - hosts.append(AnsibleHostModel(master_node.name, master_node.ip)) + if image_registry is None: + hosts = [AnsibleHostModel(repository.hosts[0].name, repository.hosts[0].ip)] new_inventory.append(AnsibleInventoryItem('image_registry', hosts)) - # add repository - repository = self.get_role(new_inventory, 'repository') - if repository == None: - hosts = [] - hosts.append(AnsibleHostModel(master_node.name, master_node.ip)) - new_inventory.append(AnsibleInventoryItem('repository', hosts)) - # save new inventory save_inventory(new_inventory, self.cluster_model, self.build_dir)