blob: 2ebc010c8944c8a7b62f59ad39f57eb1515d5b98 [file] [log] [blame]
# Copyright 2017 Mirantis, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
import pytest
import time
from tcp_tests import logger
from tcp_tests import settings
LOG = logger.logger
class TestMCPK8sActions(object):
"""Test class for different k8s actions"""
@pytest.mark.grab_versions
@pytest.mark.fail_snapshot
@pytest.mark.cz8116
@pytest.mark.k8s_calico
def test_k8s_externaldns_coredns(self, show_step, config, k8s_deployed):
"""Test externaldns integration with coredns
Scenario:
1. Install k8s with externaldns addon enabled(including etcd, coredns)
2. Start simple service
3. Expose deployment
4. Annotate service with domain name
5. Try to get service using nslookup
"""
if not (config.k8s_deploy.kubernetes_externaldns_enabled and
config.k8s_deploy.kubernetes_coredns_enabled):
pytest.skip("Test requires Externaldns and coredns addons enabled")
show_step(1)
k8sclient = k8s_deployed.api
assert k8sclient.nodes.list() is not None, "Can not get nodes list"
show_step(2)
name = 'test-nginx'
k8s_deployed.kubectl_run(name, 'nginx', '80')
show_step(3)
k8s_deployed.kubectl_expose('deployment', name, '80', 'ClusterIP')
hostname = "test.{0}.local.".format(settings.LAB_CONFIG_NAME)
annotation = "\"external-dns.alpha.kubernetes.io/" \
"hostname={0}\"".format(hostname)
show_step(4)
k8s_deployed.kubectl_annotate('service', name, annotation)
show_step(5)
dns_host = k8s_deployed.get_svc_ip('coredns')
k8s_deployed.nslookup(hostname, dns_host)
@pytest.mark.grab_versions
@pytest.mark.cncf_publisher(name=['e2e.log', 'junit_01.xml', 'version.txt',
'cncf_results.tar.gz'])
@pytest.mark.fail_snapshot
def test_k8s_cncf_certification(self, show_step, config, k8s_deployed,
cncf_log_helper):
"""Run cncf e2e suite and provide files needed for pull request
to the CNCF repo
Scenario:
1. Run cncf from https://github.com/cncf/k8s-conformance
"""
show_step(1)
k8s_deployed.start_k8s_cncf_verification()
@pytest.mark.grap_versions
@pytest.mark.fail_snapshot
def test_k8s_chain_update(self, show_step, underlay, config, k8s_deployed,
k8s_chain_update_log_helper):
"""Test for chain-upgrading k8s hypercube pool and checking it
Scenario:
1. Prepare salt on hosts
2. Setup controller nodes
3. Setup compute nodes
4. Setup Kubernetes cluster
5. Run and expose sample test service
6. Run conformance to check consistency
7. For every version in update chain:
Update cluster to new version, check test sample service
availability, run conformance
"""
deployment_name = 'test-dep-chain-upgrade'
show_step(5)
k8s_deployed.kubectl_run(
deployment_name, 'gcr.io/google-samples/node-hello:1.0', '8080')
k8s_deployed.kubectl_expose(
'deployment', deployment_name, '8080', 'ClusterIP')
sample_service_ip = k8s_deployed.get_svc_ip(deployment_name, 'default')
k8s_deployed.wait_deploy_ready(deployment_name)
# workaround for PROD-20720
time.sleep(30)
def check_is_test_service_available():
assert "Hello Kubernetes!" in k8s_deployed.curl(
"http://{}:{}".format(sample_service_ip, 8080))
check_is_test_service_available()
show_step(6)
k8s_deployed.run_conformance(log_out="k8s_conformance.log")
show_step(7)
chain_versions = config.k8s.k8s_update_chain.split(" ")
for version in chain_versions:
LOG.info("Chain update to '{}' version".format(version))
k8s_deployed.update_k8s_images(version)
LOG.info("Checking test service availability")
check_is_test_service_available()
LOG.info("Running conformance on {} version".format(version))
log_name = "k8s_conformance_{}.log".format(version)
k8s_deployed.run_conformance(log_out=log_name, raise_on_err=False)