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
	 Jenkins
					Jenkins