aboutsummaryrefslogtreecommitdiffstats
path: root/functest/tests/unit/cli/commands/test_cli_tier.py
blob: a76d12049852b4a340a0589de70e49371d0ec8ee (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
#!/usr/bin/env python

# All rights reserved. This program and the accompanying materials
# are made available under the terms of the Apache License, Version 2.0
# which accompanies this distribution, and is available at
# http://www.apache.org/licenses/LICENSE-2.0


import logging
import unittest

import mock

from functest.cli.commands import cli_tier


class CliTierTesting(unittest.TestCase):

    def setUp(self):
        self.tiername = 'tiername'
        self.testnames = 'testnames'
        with mock.patch('functest.cli.commands.cli_tier.tb'):
            self.cli_tier = cli_tier.CliTier()

    @mock.patch('functest.cli.commands.cli_tier.click.echo')
    def test_list(self, mock_click_echo):
        with mock.patch.object(self.cli_tier.tiers, 'get_tiers',
                               return_value=[]):
            self.cli_tier.list()
            mock_click_echo.assert_called_with("")

    @mock.patch('functest.cli.commands.cli_tier.click.echo')
    def test_show_default(self, mock_click_echo):
        with mock.patch.object(self.cli_tier.tiers, 'get_tier',
                               return_value=self.tiername):
            self.cli_tier.show(self.tiername)
            mock_click_echo.assert_called_with(self.tiername)

    @mock.patch('functest.cli.commands.cli_tier.click.echo')
    def test_show_missing_tier(self, mock_click_echo):
        with mock.patch.object(self.cli_tier.tiers, 'get_tier',
                               return_value=None), \
            mock.patch.object(self.cli_tier.tiers, 'get_tier_names',
                              return_value='tiernames'):
            self.cli_tier.show(self.tiername)
            mock_click_echo.assert_called_with("The tier with name '%s' does "
                                               "not exist. Available tiers are"
                                               ":\n  %s\n" % (self.tiername,
                                                              'tiernames'))

    @mock.patch('functest.cli.commands.cli_tier.click.echo')
    def test_gettests_default(self, mock_click_echo):
        mock_obj = mock.Mock()
        attrs = {'get_test_names.return_value': self.testnames}
        mock_obj.configure_mock(**attrs)

        with mock.patch.object(self.cli_tier.tiers, 'get_tier',
                               return_value=mock_obj):
            self.cli_tier.gettests(self.tiername)
            mock_click_echo.assert_called_with("Test cases in tier "
                                               "'%s':\n %s\n" % (self.tiername,
                                                                 self.testnames
                                                                 ))

    @mock.patch('functest.cli.commands.cli_tier.click.echo')
    def test_gettests_missing_tier(self, mock_click_echo):
        with mock.patch.object(self.cli_tier.tiers, 'get_tier',
                               return_value=None), \
            mock.patch.object(self.cli_tier.tiers, 'get_tier_names',
                              return_value='tiernames'):
            self.cli_tier.gettests(self.tiername)
            mock_click_echo.assert_called_with("The tier with name '%s' does "
                                               "not exist. Available tiers are"
                                               ":\n  %s\n" % (self.tiername,
                                                              'tiernames'))

    @mock.patch('functest.cli.commands.cli_tier.ft_utils.execute_command')
    def test_run_default(self, mock_ft_utils):
        cmd = "run_tests -n -r -t {}".format(self.tiername)
        self.cli_tier.run(self.tiername, noclean=True, report=True)
        mock_ft_utils.assert_called_with(cmd)

    @mock.patch('functest.cli.commands.cli_tier.ft_utils.execute_command')
    def test_run_report_missing_noclean(self, mock_ft_utils):
        cmd = "run_tests -r -t {}".format(self.tiername)
        self.cli_tier.run(self.tiername, noclean=False, report=True)
        mock_ft_utils.assert_called_with(cmd)

    @mock.patch('functest.cli.commands.cli_tier.ft_utils.execute_command')
    def test_run_noclean_missing_report(self, mock_ft_utils):
        cmd = "run_tests -n -t {}".format(self.tiername)
        self.cli_tier.run(self.tiername, noclean=True, report=False)
        mock_ft_utils.assert_called_with(cmd)

    @mock.patch('functest.cli.commands.cli_tier.ft_utils.execute_command')
    def test_run_missing_noclean_report(self, mock_ft_utils):
        cmd = "run_tests -t {}".format(self.tiername)
        self.cli_tier.run(self.tiername, noclean=False, report=False)
        mock_ft_utils.assert_called_with(cmd)


if __name__ == "__main__":
    logging.disable(logging.CRITICAL)
    unittest.main(verbosity=2)
="nt">NovaServers.boot_and_list_server: - args: detailed: true {{ vm_params(image_name, flavor_name) }} nics: - net-id: {{ netid }} context: {% call user_context(tenants_amount, users_amount, use_existing_users) %} network: networks_per_tenant: 1 start_cidr: "100.1.0.0/25" quotas: {{ unlimited_neutron() }} {{ unlimited_nova() }} {% endcall %} runner: {{ constant_runner(concurrency=concurrency, times=iterations, is_smoke=smoke) }} sla: {{ no_failures_sla() }} NovaServers.boot_and_rebuild_server: - args: {{ vm_params(flavor=flavor_name) }} from_image: name: {{ image_name }} to_image: name: {{ image_name }} nics: - net-id: {{ netid }} context: {% call user_context(tenants_amount, users_amount, use_existing_users) %} network: networks_per_tenant: 1 start_cidr: "100.1.0.0/25" quotas: {{ unlimited_neutron() }} {{ unlimited_nova() }} {% endcall %} runner: {{ constant_runner(concurrency=concurrency, times=iterations, is_smoke=smoke) }} sla: {{ no_failures_sla() }} NovaServers.boot_server_from_volume_and_delete: - args: {{ vm_params(image_name, flavor_name) }} volume_size: 5 nics: - net-id: {{ netid }} context: {% call user_context(tenants_amount, users_amount, use_existing_users) %} network: networks_per_tenant: 1 start_cidr: "100.1.0.0/25" quotas: {{ unlimited_volumes() }} {{ unlimited_neutron() }} {{ unlimited_nova() }} {% endcall %} runner: {{ constant_runner(concurrency=concurrency, times=iterations, is_smoke=smoke) }} sla: {{ no_failures_sla() }} NovaServers.pause_and_unpause_server: - args: {{ vm_params(image_name, flavor_name) }} force_delete: false nics: - net-id: {{ netid }} context: {% call user_context(tenants_amount, users_amount, use_existing_users) %} network: networks_per_tenant: 1 start_cidr: "100.1.0.0/25" quotas: {{ unlimited_neutron() }} {{ unlimited_nova() }} {% endcall %} runner: {{ constant_runner(concurrency=concurrency, times=iterations, is_smoke=smoke) }} sla: {{ no_failures_sla() }} NovaServers.snapshot_server: - args: {{ vm_params(image_name, flavor_name) }} nics: - net-id: {{ netid }} context: {% call user_context(tenants_amount, users_amount, use_existing_users) %} network: networks_per_tenant: 1 start_cidr: "100.1.0.0/25" quotas: {{ unlimited_neutron() }} {{ unlimited_nova() }} {% endcall %} runner: {{ constant_runner(concurrency=concurrency, times=iterations, is_smoke=smoke) }} sla: {{ no_failures_sla() }} NovaSecGroup.boot_and_delete_server_with_secgroups: - args: {{ vm_params(image_name, flavor_name) }} security_group_count: 10 rules_per_security_group: 10 nics: - net-id: {{ netid }} context: {% call user_context(tenants_amount, users_amount, use_existing_users) %} network: start_cidr: "100.1.0.0/25" quotas: {{ unlimited_nova() }} {{ unlimited_neutron(secgroups=true) }} {% endcall %} runner: {{ constant_runner(concurrency=concurrency, times=iterations, is_smoke=smoke) }} sla: {{ no_failures_sla() }} NovaServers.boot_and_live_migrate_server: - args: {{ vm_params(image_name, flavor_name) }} block_migration: false nics: - net-id: {{ netid }} context: {{ user_context(tenants_amount, users_amount, use_existing_users) }} runner: {{ constant_runner(concurrency=concurrency, times=iterations, is_smoke=smoke) }} sla: {{ no_failures_sla() }} NovaServers.boot_and_migrate_server: - args: {{ vm_params(image_name, flavor_name) }} nics: - net-id: {{ netid }} context: {{ user_context(tenants_amount, users_amount, use_existing_users) }} runner: {{ constant_runner(concurrency=concurrency, times=iterations, is_smoke=smoke) }} sla: {{ no_failures_sla() }} NovaServers.boot_server_from_volume: - args: {{ vm_params(image_name, flavor_name) }} volume_size: 10 nics: - net-id: {{ netid }} context: {{ user_context(tenants_amount, users_amount, use_existing_users) }} runner: {{ constant_runner(concurrency=concurrency, times=iterations, is_smoke=smoke) }} sla: {{ no_failures_sla() }} NovaServers.boot_server: - args: {{ vm_params(image_name, flavor_name) }} nics: - net-id: {{ netid }} context: {{ user_context(tenants_amount, users_amount, use_existing_users) }} runner: {{ constant_runner(concurrency=concurrency, times=iterations, is_smoke=smoke) }} sla: {{ no_failures_sla() }} NovaServers.boot_server_attach_created_volume_and_live_migrate: - args: {{ vm_params(image_name, flavor_name) }} size: 10 block_migration: false boot_server_kwargs: nics: - net-id: {{ netid }} context: {{ user_context(tenants_amount, users_amount, use_existing_users) }} runner: {{ constant_runner(concurrency=concurrency, times=iterations, is_smoke=smoke) }} sla: {{ no_failures_sla() }} NovaServers.boot_server_from_volume_and_live_migrate: - args: {{ vm_params(image_name, flavor_name) }} block_migration: false volume_size: 10 force_delete: false nics: - net-id: {{ netid }} context: {{ user_context(tenants_amount, users_amount, use_existing_users) }} runner: {{ constant_runner(concurrency=concurrency, times=iterations, is_smoke=smoke) }} sla: {{ no_failures_sla() }} NovaSecGroup.create_and_delete_secgroups: - args: security_group_count: 10 rules_per_security_group: 10 context: {% call user_context(tenants_amount, users_amount, use_existing_users) %} quotas: {{ unlimited_neutron(secgroups=true) }} {% endcall %} runner: {{ constant_runner(concurrency=concurrency, times=iterations, is_smoke=smoke) }} sla: {{ no_failures_sla() }} NovaSecGroup.create_and_list_secgroups: - args: security_group_count: 10 rules_per_security_group: 10 context: {% call user_context(tenants_amount, users_amount, use_existing_users) %} quotas: {{ unlimited_neutron(secgroups=true) }} {% endcall %} runner: {{ constant_runner(concurrency=concurrency, times=iterations, is_smoke=smoke) }} sla: {{ no_failures_sla() }} NovaServers.list_servers: - args: detailed: True context: {% call user_context(tenants_amount, users_amount, use_existing_users) %} servers: {{ vm_params(image_name,flavor_name,none)|indent(2,true) }} servers_per_tenant: 2 auto_assign_nic: true network: {} {% endcall %} runner: {{ constant_runner(concurrency=concurrency, times=iterations, is_smoke=smoke) }} sla: {{ no_failures_sla() }} NovaServers.resize_server: - args: {{ vm_params(image_name, flavor_name) }} to_flavor: name: "m1.small" confirm: true force_delete: false nics: - net-id: {{ netid }} context: {{ user_context(tenants_amount, users_amount, use_existing_users) }} runner: {{ constant_runner(concurrency=concurrency, times=iterations, is_smoke=smoke) }} sla: {{ no_failures_sla() }}