Merge "Added missing ceilometer CLI tests"
This commit is contained in:
@@ -11,6 +11,7 @@
|
|||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from ceilometerclient.tests.functional import base
|
from ceilometerclient.tests.functional import base
|
||||||
|
import re
|
||||||
|
|
||||||
|
|
||||||
class SimpleReadOnlyCeilometerClientTest(base.ClientTestBase):
|
class SimpleReadOnlyCeilometerClientTest(base.ClientTestBase):
|
||||||
@@ -22,13 +23,49 @@ class SimpleReadOnlyCeilometerClientTest(base.ClientTestBase):
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
def test_ceilometer_meter_list(self):
|
def test_ceilometer_meter_list(self):
|
||||||
self.ceilometer('meter-list')
|
result = self.ceilometer('meter-list')
|
||||||
|
meters = self.parser.listing(result)
|
||||||
|
self.assertTableStruct(meters, ['Name', 'Type', 'Unit',
|
||||||
|
'Resource ID', 'Project ID'])
|
||||||
|
|
||||||
def test_ceilometer_resource_list(self):
|
def test_ceilometer_resource_list(self):
|
||||||
self.ceilometer('resource-list')
|
result = self.ceilometer('resource-list')
|
||||||
|
resources = self.parser.listing(result)
|
||||||
|
self.assertTableStruct(resources, ['Resource ID', 'Source',
|
||||||
|
'User ID', 'Project ID'])
|
||||||
|
|
||||||
def test_ceilometermeter_alarm_list(self):
|
def test_ceilometer_alarm_list(self):
|
||||||
self.ceilometer('alarm-list')
|
result = self.ceilometer('alarm-list')
|
||||||
|
alarm = self.parser.listing(result)
|
||||||
|
self.assertTableStruct(alarm, ['Alarm ID', 'Name', 'State',
|
||||||
|
'Enabled', 'Continuous'])
|
||||||
|
|
||||||
|
def test_admin_help(self):
|
||||||
|
help_text = self.ceilometer('help')
|
||||||
|
lines = help_text.split('\n')
|
||||||
|
self.assertFirstLineStartsWith(lines, 'usage: ceilometer')
|
||||||
|
|
||||||
|
commands = []
|
||||||
|
cmds_start = lines.index('Positional arguments:')
|
||||||
|
cmds_end = lines.index('Optional arguments:')
|
||||||
|
command_pattern = re.compile('^ {4}([a-z0-9\-\_]+)')
|
||||||
|
for line in lines[cmds_start:cmds_end]:
|
||||||
|
match = command_pattern.match(line)
|
||||||
|
if match:
|
||||||
|
commands.append(match.group(1))
|
||||||
|
commands = set(commands)
|
||||||
|
wanted_commands = set(('alarm-combination-create', 'alarm-create',
|
||||||
|
'help', 'alarm-delete', 'event-list'))
|
||||||
|
self.assertFalse(wanted_commands - commands)
|
||||||
|
|
||||||
|
def test_ceilometer_bash_completion(self):
|
||||||
|
self.ceilometer('bash-completion')
|
||||||
|
|
||||||
|
# Optional arguments
|
||||||
|
|
||||||
def test_ceilometer_version(self):
|
def test_ceilometer_version(self):
|
||||||
self.ceilometer('', flags='--version')
|
version = self.ceilometer('', flags='--version', merge_stderr=True)
|
||||||
|
self.assertTrue(re.search('^[0-9.]+', version))
|
||||||
|
|
||||||
|
def test_ceilometer_debug_list(self):
|
||||||
|
self.ceilometer('meter-list', flags='--debug')
|
||||||
|
Reference in New Issue
Block a user