summaryrefslogtreecommitdiffstats
path: root/roles/openshift_health_checker
diff options
context:
space:
mode:
authorJohn Lamb <jolamb@redhat.com>2017-07-28 13:46:03 +0200
committerGitHub <noreply@github.com>2017-07-28 13:46:03 +0200
commitbdd97b01cf743b81b66ba252883ecf26fd5d1aef (patch)
treeb988a53a46daee702f5a32049af01b57cedb8c3f /roles/openshift_health_checker
parentd0761aee7107dffa4803f39b2aaecb660d767752 (diff)
parent32710db7c1ae34f884c73a7d3b3c1cbc2e368eca (diff)
downloadopenshift-bdd97b01cf743b81b66ba252883ecf26fd5d1aef.tar.gz
openshift-bdd97b01cf743b81b66ba252883ecf26fd5d1aef.tar.bz2
openshift-bdd97b01cf743b81b66ba252883ecf26fd5d1aef.tar.xz
openshift-bdd97b01cf743b81b66ba252883ecf26fd5d1aef.zip
Merge pull request #4923 from openshift/revert-4372-jvallejo/verify-disk-memory-before-upgrade
Revert "Add health checks to upgrade playbook"
Diffstat (limited to 'roles/openshift_health_checker')
-rw-r--r--roles/openshift_health_checker/openshift_checks/disk_availability.py34
-rw-r--r--roles/openshift_health_checker/test/disk_availability_test.py69
2 files changed, 5 insertions, 98 deletions
diff --git a/roles/openshift_health_checker/openshift_checks/disk_availability.py b/roles/openshift_health_checker/openshift_checks/disk_availability.py
index 39ac0e4ec..283461294 100644
--- a/roles/openshift_health_checker/openshift_checks/disk_availability.py
+++ b/roles/openshift_health_checker/openshift_checks/disk_availability.py
@@ -35,15 +35,6 @@ class DiskAvailability(OpenShiftCheck):
},
}
- # recommended disk space for each location under an upgrade context
- recommended_disk_upgrade_bytes = {
- '/var': {
- 'masters': 10 * 10**9,
- 'nodes': 5 * 10 ** 9,
- 'etcd': 5 * 10 ** 9,
- },
- }
-
def is_active(self):
"""Skip hosts that do not have recommended disk space requirements."""
group_names = self.get_var("group_names", default=[])
@@ -89,34 +80,9 @@ class DiskAvailability(OpenShiftCheck):
config_bytes = max(config.get(name, 0) for name in group_names) * 10**9
recommended_bytes = config_bytes or recommended_bytes
- # if an "upgrade" context is set, update the minimum disk requirement
- # as this signifies an in-place upgrade - the node might have the
- # required total disk space, but some of that space may already be
- # in use by the existing OpenShift deployment.
- context = self.get_var("r_openshift_health_checker_playbook_context", default="")
- if context == "upgrade":
- recommended_upgrade_paths = self.recommended_disk_upgrade_bytes.get(path, {})
- if recommended_upgrade_paths:
- recommended_bytes = config_bytes or max(recommended_upgrade_paths.get(name, 0)
- for name in group_names)
-
if free_bytes < recommended_bytes:
free_gb = float(free_bytes) / 10**9
recommended_gb = float(recommended_bytes) / 10**9
- msg = (
- 'Available disk space in "{}" ({:.1f} GB) '
- 'is below minimum recommended ({:.1f} GB)'
- ).format(path, free_gb, recommended_gb)
-
- # warn if check failed under an "upgrade" context
- # due to limits imposed by the user config
- if config_bytes and context == "upgrade":
- msg += ('\n\nMake sure to account for decreased disk space during an upgrade\n'
- 'due to an existing OpenShift deployment. Please check the value of\n'
- ' openshift_check_min_host_disk_gb={}\n'
- 'in your Ansible inventory, and lower the recommended disk space availability\n'
- 'if necessary for this upgrade.').format(config_bytes)
-
return {
'failed': True,
'msg': (
diff --git a/roles/openshift_health_checker/test/disk_availability_test.py b/roles/openshift_health_checker/test/disk_availability_test.py
index 5720eeacf..e98d02c58 100644
--- a/roles/openshift_health_checker/test/disk_availability_test.py
+++ b/roles/openshift_health_checker/test/disk_availability_test.py
@@ -97,9 +97,8 @@ def test_succeeds_with_recommended_disk_space(group_names, configured_min, ansib
assert not result.get('failed', False)
-@pytest.mark.parametrize('name,group_names,configured_min,ansible_mounts,extra_words', [
+@pytest.mark.parametrize('group_names,configured_min,ansible_mounts,extra_words', [
(
- 'test with no space available',
['masters'],
0,
[{
@@ -109,7 +108,6 @@ def test_succeeds_with_recommended_disk_space(group_names, configured_min, ansib
['0.0 GB'],
),
(
- 'test with a higher configured required value',
['masters'],
100, # set a higher threshold
[{
@@ -119,7 +117,6 @@ def test_succeeds_with_recommended_disk_space(group_names, configured_min, ansib
['100.0 GB'],
),
(
- 'test with 1GB available, but "0" GB space requirement',
['nodes'],
0,
[{
@@ -129,7 +126,6 @@ def test_succeeds_with_recommended_disk_space(group_names, configured_min, ansib
['1.0 GB'],
),
(
- 'test with no space available, but "0" GB space requirement',
['etcd'],
0,
[{
@@ -139,17 +135,16 @@ def test_succeeds_with_recommended_disk_space(group_names, configured_min, ansib
['0.0 GB'],
),
(
- 'test with enough space for a node, but not for a master',
['nodes', 'masters'],
0,
[{
'mount': '/',
+ # enough space for a node, not enough for a master
'size_available': 15 * 10**9 + 1,
}],
['15.0 GB'],
),
(
- 'test failure with enough space on "/", but not enough on "/var"',
['etcd'],
0,
[{
@@ -163,8 +158,8 @@ def test_succeeds_with_recommended_disk_space(group_names, configured_min, ansib
}],
['0.0 GB'],
),
-], ids=lambda argval: argval[0])
-def test_fails_with_insufficient_disk_space(name, group_names, configured_min, ansible_mounts, extra_words):
+])
+def test_fails_with_insufficient_disk_space(group_names, configured_min, ansible_mounts, extra_words):
task_vars = dict(
group_names=group_names,
openshift_check_min_host_disk_gb=configured_min,
@@ -175,61 +170,7 @@ def test_fails_with_insufficient_disk_space(name, group_names, configured_min, a
assert result['failed']
for word in 'below recommended'.split() + extra_words:
- assert word in result.get('msg', '')
-
-
-@pytest.mark.parametrize('name,group_names,context,ansible_mounts,failed,extra_words', [
- (
- 'test without enough space for master under "upgrade" context',
- ['nodes', 'masters'],
- "upgrade",
- [{
- 'mount': '/',
- 'size_available': 1 * 10**9 + 1,
- 'size_total': 21 * 10**9 + 1,
- }],
- True,
- ["1.0 GB"],
- ),
- (
- 'test with enough space for master under "upgrade" context',
- ['nodes', 'masters'],
- "upgrade",
- [{
- 'mount': '/',
- 'size_available': 10 * 10**9 + 1,
- 'size_total': 21 * 10**9 + 1,
- }],
- False,
- [],
- ),
- (
- 'test with not enough space for master, and non-upgrade context',
- ['nodes', 'masters'],
- "health",
- [{
- 'mount': '/',
- # not enough space for a master,
- # "health" context should not lower requirement
- 'size_available': 20 * 10**9 + 1,
- }],
- True,
- ["20.0 GB", "below minimum"],
- ),
-], ids=lambda argval: argval[0])
-def test_min_required_space_changes_with_upgrade_context(name, group_names, context, ansible_mounts, failed, extra_words):
- task_vars = dict(
- r_openshift_health_checker_playbook_context=context,
- group_names=group_names,
- ansible_mounts=ansible_mounts,
- )
-
- check = DiskAvailability(fake_execute_module, task_vars)
- result = check.run()
-
- assert result.get("failed", False) == failed
- for word in extra_words:
- assert word in result.get('msg', '')
+ assert word in result['msg']
def fake_execute_module(*args):