blob: eb1beb1f1ec501a994d53d1315fb60fd6ca12679 [file] [log] [blame]
Mauro S. M. Rodriguesc5da4f42013-03-04 23:57:10 -05001# Copyright 2013 IBM Corp
2# All Rights Reserved.
3#
4# Licensed under the Apache License, Version 2.0 (the "License"); you may
5# not use this file except in compliance with the License. You may obtain
6# a copy of the License at
7#
8# http://www.apache.org/licenses/LICENSE-2.0
9#
10# Unless required by applicable law or agreed to in writing, software
11# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
12# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13# License for the specific language governing permissions and limitations
14# under the License.
15
Sean Dague1937d092013-05-17 16:36:38 -040016from tempest.api.compute import base
Fei Long Wangd39431f2015-05-14 11:30:48 +120017from tempest.common.utils import data_utils
Hoisaleshwara Madan V S65e53032013-12-26 12:55:44 +053018from tempest import test
Mauro S. M. Rodriguesc5da4f42013-03-04 23:57:10 -050019
20
ivan-zhuf2b00502013-10-18 10:06:52 +080021class MultipleCreateTestJSON(base.BaseV2ComputeTest):
Mauro S. M. Rodriguesc5da4f42013-03-04 23:57:10 -050022 _name = 'multiple-create-test'
23
Mauro S. M. Rodriguesc5da4f42013-03-04 23:57:10 -050024 def _generate_name(self):
Masayuki Igawa259c1132013-10-31 17:48:44 +090025 return data_utils.rand_name(self._name)
Mauro S. M. Rodriguesc5da4f42013-03-04 23:57:10 -050026
27 def _create_multiple_servers(self, name=None, wait_until=None, **kwargs):
Ken'ichi Ohmichi88363cb2015-11-19 08:00:54 +000028 # NOTE: This is the right way to create_multiple servers and manage to
29 # get the created servers into the servers list to be cleaned up after
30 # all.
ahmade6edb4b2015-05-24 13:28:11 +053031 kwargs['name'] = name if name else self._generate_name()
32 if wait_until:
33 kwargs['wait_until'] = wait_until
David Kranz0fb14292015-02-11 15:55:20 -050034 body = self.create_test_server(**kwargs)
Mauro S. M. Rodriguesc5da4f42013-03-04 23:57:10 -050035
David Kranz0fb14292015-02-11 15:55:20 -050036 return body
Mauro S. M. Rodriguesc5da4f42013-03-04 23:57:10 -050037
Chris Hoge7579c1a2015-02-26 14:12:15 -080038 @test.idempotent_id('61e03386-89c3-449c-9bb1-a06f423fd9d1')
Mauro S. M. Rodriguesc5da4f42013-03-04 23:57:10 -050039 def test_multiple_create(self):
David Kranz0fb14292015-02-11 15:55:20 -050040 body = self._create_multiple_servers(wait_until='ACTIVE',
41 min_count=1,
42 max_count=2)
Mauro S. M. Rodriguesc5da4f42013-03-04 23:57:10 -050043 # NOTE(maurosr): do status response check and also make sure that
44 # reservation_id is not in the response body when the request send
45 # contains return_reservation_id=False
Attila Fazekase191cb12013-07-29 06:41:52 +020046 self.assertNotIn('reservation_id', body)
Mauro S. M. Rodriguesc5da4f42013-03-04 23:57:10 -050047
Chris Hoge7579c1a2015-02-26 14:12:15 -080048 @test.idempotent_id('864777fb-2f1e-44e3-b5b9-3eb6fa84f2f7')
Mauro S. M. Rodriguesc5da4f42013-03-04 23:57:10 -050049 def test_multiple_create_with_reservation_return(self):
David Kranz0fb14292015-02-11 15:55:20 -050050 body = self._create_multiple_servers(wait_until='ACTIVE',
51 min_count=1,
52 max_count=2,
53 return_reservation_id=True)
Mauro S. M. Rodriguesc5da4f42013-03-04 23:57:10 -050054 self.assertIn('reservation_id', body)