| import pytest |
| import json |
| import os |
| import logging |
| |
| |
| def test_k8s_get_cs_status(local_salt_client): |
| result = local_salt_client.cmd( |
| tgt='etcd:server', |
| param='kubectl get cs', |
| expr_form='pillar' |
| ) |
| errors = [] |
| if not result: |
| pytest.skip("k8s is not found on this environment") |
| for node in result: |
| for line in result[node].split('\n'): |
| line = line.strip() |
| if 'MESSAGE' in line or 'proto' in line: |
| continue |
| else: |
| if 'Healthy' not in line: |
| errors.append(line) |
| break |
| assert not errors, 'k8s is not healthy: {}'.format(json.dumps( |
| errors, |
| indent=4)) |
| |
| |
| @pytest.mark.xfail |
| def test_k8s_get_nodes_status(local_salt_client): |
| result = local_salt_client.cmd( |
| tgt='etcd:server', |
| param='kubectl get nodes', |
| expr_form='pillar' |
| ) |
| errors = [] |
| if not result: |
| pytest.skip("k8s is not found on this environment") |
| for node in result: |
| for line in result[node].split('\n'): |
| line = line.strip() |
| if 'STATUS' in line or 'proto' in line: |
| continue |
| else: |
| if 'Ready' != line.split()[1]: |
| errors.append(line) |
| break |
| assert not errors, 'k8s is not healthy: {}'.format(json.dumps( |
| errors, |
| indent=4)) |
| |
| |
| def test_k8s_get_calico_status(local_salt_client): |
| result = local_salt_client.cmd( |
| tgt='kubernetes:pool', |
| param='calicoctl node status', |
| expr_form='pillar' |
| ) |
| errors = [] |
| if not result: |
| pytest.skip("k8s is not found on this environment") |
| for node in result: |
| for line in result[node].split('\n'): |
| line = line.strip('|') |
| if 'STATE' in line or '| ' not in line: |
| continue |
| else: |
| if 'up' not in line or 'Established' not in line: |
| errors.append(line) |
| assert not errors, 'Calico node status is not good: {}'.format(json.dumps( |
| errors, |
| indent=4)) |
| |
| |
| def test_k8s_cluster_status(local_salt_client): |
| result = local_salt_client.cmd( |
| tgt='kubernetes:master', |
| param='kubectl cluster-info', |
| expr_form='pillar' |
| ) |
| errors = [] |
| if not result: |
| pytest.skip("k8s is not found on this environment") |
| for node in result: |
| for line in result[node].split('\n'): |
| if 'proto' in line or 'further' in line or line == '': |
| continue |
| else: |
| if 'is running' not in line: |
| errors.append(line) |
| break |
| assert not errors, 'k8s cluster info is not good: {}'.format(json.dumps( |
| errors, |
| indent=4)) |
| |
| |
| def test_k8s_kubelet_status(local_salt_client): |
| result = local_salt_client.cmd( |
| tgt='kubernetes:pool', |
| fun='service.status', |
| param='kubelet', |
| expr_form='pillar' |
| ) |
| errors = [] |
| if not result: |
| pytest.skip("k8s is not found on this environment") |
| for node in result: |
| if not result[node]: |
| errors.append(node) |
| assert not errors, 'Kublete is not running on these nodes: {}'.format( |
| errors) |
| |
| |
| def test_k8s_check_system_pods_status(local_salt_client): |
| result = local_salt_client.cmd( |
| tgt='etcd:server', |
| param='kubectl --namespace="kube-system" get pods', |
| expr_form='pillar' |
| ) |
| errors = [] |
| if not result: |
| pytest.skip("k8s is not found on this environment") |
| for node in result: |
| for line in result[node].split('\n'): |
| line = line.strip('|') |
| if 'STATUS' in line or 'proto' in line: |
| continue |
| else: |
| if 'Running' not in line: |
| errors.append(line) |
| break |
| assert not errors, 'Some system pods are not running: {}'.format(json.dumps( |
| errors, |
| indent=4)) |
| |
| |
| def test_check_k8s_image_availability(local_salt_client): |
| # not a test actually |
| hostname = 'https://docker-dev-virtual.docker.mirantis.net/artifactory/webapp/' |
| response = os.system('curl -s --insecure {} > /dev/null'.format(hostname)) |
| if response == 0: |
| logging.info('{} is AVAILABLE'.format(hostname)) |
| else: |
| logging.error('{} IS NOT AVAILABLE'.format(hostname)) |
| |
| |
| @pytest.mark.xfail |
| def test_k8s_dashboard_available(local_salt_client): |
| """ |
| # Check is kubernetes enabled on the cluster with command `salt -C 'etcd:server' cmd.run 'kubectl get svc -n kube-system'` |
| # If yes then check Dashboard addon with next command: `salt -C 'etcd:server' pillar.get kubernetes:common:addons:dashboard:enabled` |
| # If dashboard enabled get its IP from pillar `salt -C 'etcd:server' pillar.get kubernetes:common:addons:dashboard:public_ip` |
| # Check that public_ip exists |
| # Check that public_ip:8443 is accessible with curl |
| """ |
| result = local_salt_client.cmd( |
| tgt='etcd:server', |
| param='kubectl get svc -n kube-system', |
| expr_form='pillar' |
| ) |
| if not result: |
| pytest.skip("k8s is not found on this environment") |
| |
| # service name 'kubernetes-dashboard' is hardcoded in kubernetes formula |
| dashboard_enabled = local_salt_client.pillar_get( |
| tgt='etcd:server', |
| param='kubernetes:common:addons:dashboard:enabled',) |
| if not dashboard_enabled: |
| pytest.skip("Kubernetes dashboard is not enabled in the cluster.") |
| |
| external_ip = local_salt_client.pillar_get( |
| tgt='etcd:server', |
| param='kubernetes:common:addons:dashboard:public_ip') |
| |
| assert external_ip, "Kubernetes dashboard public ip is not found in pillars" |
| assert external_ip.__len__() > 0, "Kubernetes dashboard is enabled but not defined in pillars" |
| # dashboard port 8443 is hardcoded in kubernetes formula |
| url = "https://{}:8443".format(external_ip) |
| check = local_salt_client.cmd( |
| tgt='etcd:server', |
| param='curl {} 2>&1 | grep kubernetesDashboard'.format(url), |
| expr_form='pillar' |
| ) |
| assert len(check.values()[0]) != 0, \ |
| 'Kubernetes dashboard is not reachable on {} ' \ |
| 'from ctl nodes'.format(url) |