Tim Kuhlman 63126bc8e8 Turn off proxy for the smoke test.
Change-Id: Ice1c3c3033934ade9880256f2b8d792cab6c5948
2014-07-25 14:44:50 -06:00

121 lines
3.5 KiB
Python

from __future__ import print_function
import sys
import time
import os
import json
import subprocess
import cli_wrapper
from monclient import client
"""
Utility methods for testing
"""
def check_alarm_history(alarm_id, states):
transitions = len(states) - 1
print('Checking Alarm History')
# May take some time for Alarm history to flow all the way through
for _ in range(0, 10):
result_json = cli_wrapper.run_mon_cli(['alarm-history', alarm_id])
if len(result_json) >= transitions:
break
time.sleep(4)
result = True
if transitions != len(result_json):
print('Wrong number of history entries, expected %d but was %d' %
(transitions, len(result_json)), file=sys.stderr)
return False
# Alarm history is reverse sorted by date
index = transitions - 1
for i in range(0, transitions):
old_state = states[i]
new_state = states[i+1]
alarm_json = result_json[index]
if not check_expected(old_state, alarm_json['old_state'], 'old_state',
i):
result = False
if not check_expected(new_state, alarm_json['new_state'], 'new_state',
i):
result = False
if not check_expected(alarm_id, alarm_json['alarm_id'], 'alarm_id',
i):
result = False
index = index - 1
if result:
print('Alarm History is OK')
return result
def check_expected(expected, actual, what, index):
if (expected == actual):
return True
print('Wrong %s for alarm history expected %s but was %s transition %d' %
(what, expected, actual, index+1), file=sys.stderr)
return False
def check_alarm_state(alarm_id, expected):
state = cli_wrapper.get_alarm_state(alarm_id)
if state != expected:
print('Wrong initial alarm state, expected %s but is %s' %
(expected, state))
return False
return True
def get_api_host():
# Determine if we are running on multiple VMs or just the one
if os.path.isfile('/etc/mon/mon-api-config.yml'):
return 'localhost'
else:
return '192.168.10.4'
def setup_cli():
api_host = get_api_host()
# These need to be set because we are invoking the CLI as a process
os.environ['OS_USERNAME'] = 'mini-mon'
os.environ['OS_PASSWORD'] = 'password'
os.environ['OS_TENANT_NAME'] = 'mini-mon'
os.environ['OS_AUTH_URL'] = 'http://192.168.10.5:35357/v2.0/'
os.environ['MON_API_URL'] = 'http://' + api_host + ':8080/v2.0/'
os.environ['http_proxy'] = ''
os.environ['https_proxy'] = ''
os.environ['HTTP_PROXY'] = ''
os.environ['HTTPS_PROXY'] = ''
def create_mon_client():
api_host = get_api_host()
api_version = '2_0'
endpoint = 'http://' + api_host + ':8080/v2.0'
kwargs = {'token': '82510970543135'}
return client.Client(api_version, endpoint, **kwargs)
def ensure_has_notification_engine():
if not os.path.isfile('/etc/monasca/notification.yaml'):
print('Must be run on a VM with Notification Engine installed',
file=sys.stderr)
return False
return True
def find_notifications(alarm_id, user):
args = ['sudo', 'cat', '/var/mail/' + user]
result = []
try:
stdout = subprocess.check_output(args)
except subprocess.CalledProcessError as e:
print(e, file=sys.stderr)
sys.exit(1)
for line in stdout.splitlines():
if alarm_id in line:
result.append(json.loads(line)['state'])
return result