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
105
106
107
108
109
110
111
112
113
114
115
|
##############################################################################
# Copyright (c) 2017 ZTE Corporation and others.
#
# 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 os
from os.path import isfile, join
import sys
from alarm import Alarm
import config
from consumer import get_consumer
from image import Image
from instance import Instance
from inspector import get_inspector
from installer import get_installer
import logger as doctor_log
from user import User
from network import Network
from monitor import get_monitor
LOG = doctor_log.Logger('doctor').getLogger()
class DoctorTest(object):
def __init__(self, conf):
self.conf = conf
self.image = Image(self.conf, LOG)
self.user = User(self.conf, LOG)
self.network = Network(self.conf, LOG)
self.instance = Instance(self.conf, LOG)
self.alarm = Alarm(self.conf, LOG)
self.inspector = get_inspector(self.conf, LOG)
self.monitor = get_monitor(self.conf,
self.inspector.get_inspector_url(),
LOG)
self.consumer = get_consumer(self.conf, LOG)
self.installer = get_installer(self.conf, LOG)
def setup(self):
# prepare the cloud env
self.installer.setup()
# preparing VM image...
self.image.create()
# creating test user...
self.user.create()
self.user.update_quota()
# creating VM...
self.network.create()
self.instance.create()
self.instance.wait_for_vm_launch()
# creating alarm...
self.alarm.create()
# starting doctor sample components...
self.inspector.start()
self.monitor.start()
self.consumer.start()
def run(self):
"""run doctor test"""
try:
LOG.info('doctor test starting.......')
self.setup()
# injecting host failure...
# NOTE (umar) add INTERFACE_NAME logic to host injection
# verify the test results
# NOTE (umar) copy remote monitor.log file when monitor=collectd
except Exception as e:
LOG.error('doctor test failed, Exception=%s' % e)
sys.exit(1)
finally:
self.cleanup()
def cleanup(self):
self.alarm.delete()
self.instance.delete()
self.network.delete()
self.image.delete()
self.user.delete()
self.inspector.stop()
self.monitor.stop()
self.consumer.stop()
self.installer.cleanup()
def main():
"""doctor main"""
doctor_root_dir = os.path.dirname(sys.path[0])
config_file_dir = '{0}/{1}'.format(doctor_root_dir, 'etc/')
config_files = [join(config_file_dir, f) for f in os.listdir(config_file_dir)
if isfile(join(config_file_dir, f))]
conf = config.prepare_conf(args=sys.argv[1:],
config_files=config_files)
doctor = DoctorTest(conf)
doctor.run()
if __name__ == '__main__':
sys.exit(main())
|