Functional test for server group
Rework functional tests to remove resource create/delete from setupClass() and teardownClass() methods. Change-Id: Ia852e48d3bcf706eefa56b03ba1f02b3fd7605cd
This commit is contained in:
parent
083b115d09
commit
c8ab58bf61
@ -10,6 +10,7 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
|
import json
|
||||||
import uuid
|
import uuid
|
||||||
|
|
||||||
from openstackclient.tests.functional import base
|
from openstackclient.tests.functional import base
|
||||||
@ -18,29 +19,88 @@ from openstackclient.tests.functional import base
|
|||||||
class ServerGroupTests(base.TestCase):
|
class ServerGroupTests(base.TestCase):
|
||||||
"""Functional tests for servergroup."""
|
"""Functional tests for servergroup."""
|
||||||
|
|
||||||
NAME = uuid.uuid4().hex
|
def test_server_group_delete(self):
|
||||||
HEADERS = ['Name']
|
"""Test create, delete multiple"""
|
||||||
FIELDS = ['name']
|
name1 = uuid.uuid4().hex
|
||||||
|
name2 = uuid.uuid4().hex
|
||||||
|
cmd_output = json.loads(self.openstack(
|
||||||
|
'server group create -f json ' +
|
||||||
|
'--policy affinity ' +
|
||||||
|
name1
|
||||||
|
))
|
||||||
|
self.assertEqual(
|
||||||
|
name1,
|
||||||
|
cmd_output['name']
|
||||||
|
)
|
||||||
|
self.assertEqual(
|
||||||
|
'affinity',
|
||||||
|
cmd_output['policies']
|
||||||
|
)
|
||||||
|
|
||||||
@classmethod
|
cmd_output = json.loads(self.openstack(
|
||||||
def setUpClass(cls):
|
'server group create -f json ' +
|
||||||
opts = cls.get_opts(cls.FIELDS)
|
'--policy anti-affinity ' +
|
||||||
raw_output = cls.openstack('server group create --policy affinity ' +
|
name2
|
||||||
cls.NAME + opts)
|
))
|
||||||
expected = cls.NAME + '\n'
|
self.assertEqual(
|
||||||
cls.assertOutput(expected, raw_output)
|
name2,
|
||||||
|
cmd_output['name']
|
||||||
|
)
|
||||||
|
self.assertEqual(
|
||||||
|
'anti-affinity',
|
||||||
|
cmd_output['policies']
|
||||||
|
)
|
||||||
|
|
||||||
@classmethod
|
del_output = self.openstack(
|
||||||
def tearDownClass(cls):
|
'server group delete ' + name1 + ' ' + name2)
|
||||||
raw_output = cls.openstack('server group delete ' + cls.NAME)
|
self.assertOutput('', del_output)
|
||||||
cls.assertOutput('', raw_output)
|
|
||||||
|
|
||||||
def test_server_group_list(self):
|
def test_server_group_show_and_list(self):
|
||||||
opts = self.get_opts(self.HEADERS)
|
"""Test server group create, show, and list"""
|
||||||
raw_output = self.openstack('server group list' + opts)
|
name1 = uuid.uuid4().hex
|
||||||
self.assertIn(self.NAME, raw_output)
|
name2 = uuid.uuid4().hex
|
||||||
|
|
||||||
def test_server_group_show(self):
|
# test server gorup show
|
||||||
opts = self.get_opts(self.FIELDS)
|
cmd_output = json.loads(self.openstack(
|
||||||
raw_output = self.openstack('server group show ' + self.NAME + opts)
|
'server group create -f json ' +
|
||||||
self.assertEqual(self.NAME + "\n", raw_output)
|
'--policy affinity ' +
|
||||||
|
name1
|
||||||
|
))
|
||||||
|
self.addCleanup(self.openstack, 'server group delete ' + name1)
|
||||||
|
cmd_output = json.loads(self.openstack(
|
||||||
|
'server group show -f json ' + name1))
|
||||||
|
self.assertEqual(
|
||||||
|
name1,
|
||||||
|
cmd_output['name']
|
||||||
|
)
|
||||||
|
self.assertEqual(
|
||||||
|
'affinity',
|
||||||
|
cmd_output['policies']
|
||||||
|
)
|
||||||
|
|
||||||
|
cmd_output = json.loads(self.openstack(
|
||||||
|
'server group create -f json ' +
|
||||||
|
'--policy anti-affinity ' +
|
||||||
|
name2
|
||||||
|
))
|
||||||
|
self.addCleanup(self.openstack, 'server group delete ' + name2)
|
||||||
|
cmd_output = json.loads(self.openstack(
|
||||||
|
'server group show -f json ' + name2))
|
||||||
|
self.assertEqual(
|
||||||
|
name2,
|
||||||
|
cmd_output['name']
|
||||||
|
)
|
||||||
|
self.assertEqual(
|
||||||
|
'anti-affinity',
|
||||||
|
cmd_output['policies']
|
||||||
|
)
|
||||||
|
|
||||||
|
# test server group list
|
||||||
|
cmd_output = json.loads(self.openstack(
|
||||||
|
'server group list -f json'))
|
||||||
|
names = [x["Name"] for x in cmd_output]
|
||||||
|
self.assertIn(name1, names)
|
||||||
|
self.assertIn(name2, names)
|
||||||
|
policies = [x["Policies"] for x in cmd_output]
|
||||||
|
self.assertIn('affinity', policies)
|
||||||
|
self.assertIn('anti-affinity', policies)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user