Client supports check action
Support stack check action. Change-Id: I652136fb20dfa06ac49b9addf85c4f226aa66107
This commit is contained in:
		| @@ -1622,6 +1622,34 @@ class ShellTestUserPass(ShellBase): | ||||
|         for r in required: | ||||
|             self.assertRegexpMatches(update_text, r) | ||||
|  | ||||
|     @httpretty.activate | ||||
|     def test_stack_check(self): | ||||
|         self.register_keystone_auth_fixture() | ||||
|         expected_data = {'check': None} | ||||
|         resp = fakes.FakeHTTPResponse( | ||||
|             202, | ||||
|             'Accepted', | ||||
|             {}, | ||||
|             'The request is accepted for processing.') | ||||
|         http.HTTPClient.json_request( | ||||
|             'POST', '/stacks/teststack2/actions', | ||||
|             data=expected_data | ||||
|         ).AndReturn((resp, None)) | ||||
|         fakes.script_heat_list() | ||||
|  | ||||
|         self.m.ReplayAll() | ||||
|  | ||||
|         check_text = self.shell('action-check teststack2') | ||||
|  | ||||
|         required = [ | ||||
|             'stack_name', | ||||
|             'id', | ||||
|             'teststack2', | ||||
|             '1' | ||||
|         ] | ||||
|         for r in required: | ||||
|             self.assertRegexpMatches(check_text, r) | ||||
|  | ||||
|     @httpretty.activate | ||||
|     def test_stack_delete(self): | ||||
|         self.register_keystone_auth_fixture() | ||||
|   | ||||
| @@ -44,7 +44,8 @@ class StackStatusActionTest(testtools.TestCase): | ||||
|         ('UPDATE', dict(action='UPDATE')), | ||||
|         ('ROLLBACK', dict(action='ROLLBACK')), | ||||
|         ('SUSPEND', dict(action='SUSPEND')), | ||||
|         ('RESUME', dict(action='RESUME')) | ||||
|         ('RESUME', dict(action='RESUME')), | ||||
|         ('CHECK', dict(action='CHECK')) | ||||
|     ], [ | ||||
|         ('IN_PROGRESS', dict(status='IN_PROGRESS')), | ||||
|         ('FAILED', dict(status='FAILED')), | ||||
|   | ||||
| @@ -53,3 +53,10 @@ class ActionManager(stacks.StackChildManager): | ||||
|         resp, body = self.client.json_request('POST', | ||||
|                                               '/stacks/%s/actions' % stack_id, | ||||
|                                               data=body) | ||||
|  | ||||
|     def check(self, stack_id): | ||||
|         """Check a stack.""" | ||||
|         body = {'check': None} | ||||
|         resp, body = self.client.json_request('POST', | ||||
|                                               '/stacks/%s/actions' % stack_id, | ||||
|                                               data=body) | ||||
|   | ||||
| @@ -306,6 +306,19 @@ def do_action_resume(hc, args): | ||||
|         do_stack_list(hc) | ||||
|  | ||||
|  | ||||
| @utils.arg('id', metavar='<NAME or ID>', | ||||
|            help='Name or ID of stack to check.') | ||||
| def do_action_check(hc, args): | ||||
|     '''Check that stack resources are in expected states.''' | ||||
|     fields = {'stack_id': args.id} | ||||
|     try: | ||||
|         hc.actions.check(**fields) | ||||
|     except exc.HTTPNotFound: | ||||
|         raise exc.CommandError('Stack not found: %s' % args.id) | ||||
|     else: | ||||
|         do_stack_list(hc) | ||||
|  | ||||
|  | ||||
| @utils.arg('id', metavar='<NAME or ID>', | ||||
|            help='Name or ID of stack to describe.') | ||||
| def do_describe(hc, args): | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 huangtianhua
					huangtianhua