File: test_instance_usage_audit_log.py

package info (click to toggle)
python-novaclient 2%3A18.11.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 2,852 kB
  • sloc: python: 24,301; makefile: 24; sh: 13
file content (87 lines) | stat: -rw-r--r-- 2,968 bytes parent folder | download | duplicates (2)
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
#    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 datetime

from oslo_utils import timeutils

from novaclient.tests.functional import base


class TestInstanceUsageAuditLogCLI(base.ClientTestBase):
    COMPUTE_API_VERSION = '2.1'

    # NOTE(takashin): By default, 'instance_usage_audit' is False in nova.
    # So the instance usage audit log is not recorded.
    # Therefore an empty result can be got.
    # But it is tested here to call APIs and get responses normally.

    @staticmethod
    def _get_begin_end_time():
        current = timeutils.utcnow()

        end = datetime.datetime(day=1, month=current.month, year=current.year)
        year = end.year

        if current.month == 1:
            year -= 1
            month = 12
        else:
            month = current.month - 1

        begin = datetime.datetime(day=1, month=month, year=year)

        return (begin, end)

    def test_get_os_instance_usage_audit_log(self):
        (begin, end) = self._get_begin_end_time()
        expected = {
            'hosts_not_run': '[]',
            'log': '{}',
            'num_hosts': '0',
            'num_hosts_done': '0',
            'num_hosts_not_run': '0',
            'num_hosts_running': '0',
            'overall_status': 'ALL hosts done. 0 errors.',
            'total_errors': '0',
            'total_instances': '0',
            'period_beginning': str(begin),
            'period_ending': str(end)
        }

        output = self.nova('instance-usage-audit-log')

        for key in expected.keys():
            self.assertEqual(expected[key],
                             self._get_value_from_the_table(output, key))

    def test_get_os_instance_usage_audit_log_with_before(self):
        expected = {
            'hosts_not_run': '[]',
            'log': '{}',
            'num_hosts': '0',
            'num_hosts_done': '0',
            'num_hosts_not_run': '0',
            'num_hosts_running': '0',
            'overall_status': 'ALL hosts done. 0 errors.',
            'total_errors': '0',
            'total_instances': '0',
            'period_beginning': '2016-11-01 00:00:00',
            'period_ending': '2016-12-01 00:00:00'
        }

        output = self.nova(
            'instance-usage-audit-log --before "2016-12-10 13:59:59.999999"')

        for key in expected.keys():
            self.assertEqual(expected[key],
                             self._get_value_from_the_table(output, key))