Functional tests - port
* Rework functional tests to remove resource create/delete from setupClass() and teardownClass() methods. * Add tests for more command options Change-Id: Ic77df94fe5980e60c6a67cbf061b9a9dc601518f
This commit is contained in:
parent
e6e3cd295c
commit
e0813cc54e
@ -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 re
|
||||||
import uuid
|
import uuid
|
||||||
|
|
||||||
from openstackclient.tests.functional import base
|
from openstackclient.tests.functional import base
|
||||||
@ -24,35 +25,152 @@ class PortTests(base.TestCase):
|
|||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def setUpClass(cls):
|
def setUpClass(cls):
|
||||||
# Create a network for the subnet.
|
# Set up some regex for matching below
|
||||||
cls.openstack('network create ' + cls.NETWORK_NAME)
|
cls.re_id = re.compile("\s+id\s+\|\s+(\S+)")
|
||||||
opts = cls.get_opts(cls.FIELDS)
|
cls.re_name = re.compile("\s+name\s+\|\s+([^|]+?)\s+\|")
|
||||||
raw_output = cls.openstack(
|
cls.re_description = re.compile("\s+description\s+\|\s+([^|]+?)\s+\|")
|
||||||
'port create --network ' + cls.NETWORK_NAME + ' ' +
|
cls.re_mac_address = re.compile("\s+mac_address\s+\|\s+([^|]+?)\s+\|")
|
||||||
cls.NAME + opts
|
cls.re_state = re.compile("\s+admin_state_up\s+\|\s+([^|]+?)\s+\|")
|
||||||
)
|
|
||||||
expected = cls.NAME + '\n'
|
# Create a network for the port
|
||||||
cls.assertOutput(expected, raw_output)
|
raw_output = cls.openstack('network create ' + cls.NETWORK_NAME)
|
||||||
|
cls.network_id = re.search(cls.re_id, raw_output).group(1)
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def tearDownClass(cls):
|
def tearDownClass(cls):
|
||||||
raw_output = cls.openstack('port delete ' + cls.NAME)
|
|
||||||
cls.assertOutput('', raw_output)
|
|
||||||
raw_output = cls.openstack('network delete ' + cls.NETWORK_NAME)
|
raw_output = cls.openstack('network delete ' + cls.NETWORK_NAME)
|
||||||
cls.assertOutput('', raw_output)
|
cls.assertOutput('', raw_output)
|
||||||
|
|
||||||
|
def test_port_delete(self):
|
||||||
|
"""Test create, delete multiple"""
|
||||||
|
raw_output = self.openstack(
|
||||||
|
'port create --network ' + self.NETWORK_NAME + ' ' + self.NAME
|
||||||
|
)
|
||||||
|
re_id1 = re.search(self.re_id, raw_output)
|
||||||
|
self.assertIsNotNone(re_id1)
|
||||||
|
id1 = re_id1.group(1)
|
||||||
|
self.assertIsNotNone(
|
||||||
|
re.search(self.re_mac_address, raw_output).group(1),
|
||||||
|
)
|
||||||
|
self.assertEqual(
|
||||||
|
self.NAME,
|
||||||
|
re.search(self.re_name, raw_output).group(1),
|
||||||
|
)
|
||||||
|
|
||||||
|
raw_output = self.openstack(
|
||||||
|
'port create ' +
|
||||||
|
'--network ' + self.NETWORK_NAME + ' ' +
|
||||||
|
self.NAME + 'x'
|
||||||
|
)
|
||||||
|
id2 = re.search(self.re_id, raw_output).group(1)
|
||||||
|
self.assertIsNotNone(
|
||||||
|
re.search(self.re_mac_address, raw_output).group(1),
|
||||||
|
)
|
||||||
|
self.assertEqual(
|
||||||
|
self.NAME + 'x',
|
||||||
|
re.search(self.re_name, raw_output).group(1),
|
||||||
|
)
|
||||||
|
|
||||||
|
# Clean up after ourselves
|
||||||
|
raw_output = self.openstack('port delete ' + id1 + ' ' + id2)
|
||||||
|
self.assertOutput('', raw_output)
|
||||||
|
|
||||||
def test_port_list(self):
|
def test_port_list(self):
|
||||||
opts = self.get_opts(self.HEADERS)
|
"""Test create defaults, list, delete"""
|
||||||
raw_output = self.openstack('port list' + opts)
|
raw_output = self.openstack(
|
||||||
self.assertIn(self.NAME, raw_output)
|
'port create --network ' + self.NETWORK_NAME + ' ' + self.NAME
|
||||||
|
)
|
||||||
|
re_id1 = re.search(self.re_id, raw_output)
|
||||||
|
self.assertIsNotNone(re_id1)
|
||||||
|
id1 = re_id1.group(1)
|
||||||
|
mac1 = re.search(self.re_mac_address, raw_output).group(1)
|
||||||
|
self.addCleanup(self.openstack, 'port delete ' + id1)
|
||||||
|
self.assertEqual(
|
||||||
|
self.NAME,
|
||||||
|
re.search(self.re_name, raw_output).group(1),
|
||||||
|
)
|
||||||
|
|
||||||
|
raw_output = self.openstack(
|
||||||
|
'port create ' +
|
||||||
|
'--network ' + self.NETWORK_NAME + ' ' +
|
||||||
|
self.NAME + 'x'
|
||||||
|
)
|
||||||
|
id2 = re.search(self.re_id, raw_output).group(1)
|
||||||
|
mac2 = re.search(self.re_mac_address, raw_output).group(1)
|
||||||
|
self.addCleanup(self.openstack, 'port delete ' + id2)
|
||||||
|
self.assertEqual(
|
||||||
|
self.NAME + 'x',
|
||||||
|
re.search(self.re_name, raw_output).group(1),
|
||||||
|
)
|
||||||
|
|
||||||
|
# Test list
|
||||||
|
raw_output = self.openstack('port list')
|
||||||
|
self.assertIsNotNone(re.search("\|\s+" + id1 + "\s+\|", raw_output))
|
||||||
|
self.assertIsNotNone(re.search("\|\s+" + id2 + "\s+\|", raw_output))
|
||||||
|
self.assertIsNotNone(re.search("\|\s+" + mac1 + "\s+\|", raw_output))
|
||||||
|
self.assertIsNotNone(re.search("\|\s+" + mac2 + "\s+\|", raw_output))
|
||||||
|
|
||||||
|
# Test list --long
|
||||||
|
raw_output = self.openstack('port list --long')
|
||||||
|
self.assertIsNotNone(re.search("\|\s+" + id1 + "\s+\|", raw_output))
|
||||||
|
self.assertIsNotNone(re.search("\|\s+" + id2 + "\s+\|", raw_output))
|
||||||
|
|
||||||
|
# Test list --mac-address
|
||||||
|
raw_output = self.openstack('port list --mac-address ' + mac2)
|
||||||
|
self.assertIsNone(re.search("\|\s+" + id1 + "\s+\|", raw_output))
|
||||||
|
self.assertIsNotNone(re.search("\|\s+" + id2 + "\s+\|", raw_output))
|
||||||
|
self.assertIsNone(re.search("\|\s+" + mac1 + "\s+\|", raw_output))
|
||||||
|
self.assertIsNotNone(re.search("\|\s+" + mac2 + "\s+\|", raw_output))
|
||||||
|
|
||||||
def test_port_set(self):
|
def test_port_set(self):
|
||||||
self.openstack('port set --disable ' + self.NAME)
|
"""Test create, set, show, delete"""
|
||||||
opts = self.get_opts(['name', 'admin_state_up'])
|
raw_output = self.openstack(
|
||||||
raw_output = self.openstack('port show ' + self.NAME + opts)
|
'port create ' +
|
||||||
self.assertEqual("DOWN\n" + self.NAME + "\n", raw_output)
|
'--network ' + self.NETWORK_NAME + ' ' +
|
||||||
|
'--description xyzpdq '
|
||||||
|
'--disable ' +
|
||||||
|
self.NAME
|
||||||
|
)
|
||||||
|
re_id = re.search(self.re_id, raw_output)
|
||||||
|
self.assertIsNotNone(re_id)
|
||||||
|
id = re_id.group(1)
|
||||||
|
self.addCleanup(self.openstack, 'port delete ' + id)
|
||||||
|
self.assertEqual(
|
||||||
|
self.NAME,
|
||||||
|
re.search(self.re_name, raw_output).group(1),
|
||||||
|
)
|
||||||
|
self.assertEqual(
|
||||||
|
'xyzpdq',
|
||||||
|
re.search(self.re_description, raw_output).group(1),
|
||||||
|
)
|
||||||
|
self.assertEqual(
|
||||||
|
'DOWN',
|
||||||
|
re.search(self.re_state, raw_output).group(1),
|
||||||
|
)
|
||||||
|
|
||||||
def test_port_show(self):
|
raw_output = self.openstack(
|
||||||
opts = self.get_opts(self.FIELDS)
|
'port set ' +
|
||||||
raw_output = self.openstack('port show ' + self.NAME + opts)
|
'--enable ' +
|
||||||
self.assertEqual(self.NAME + "\n", raw_output)
|
self.NAME
|
||||||
|
)
|
||||||
|
self.assertOutput('', raw_output)
|
||||||
|
|
||||||
|
raw_output = self.openstack(
|
||||||
|
'port show ' +
|
||||||
|
self.NAME
|
||||||
|
)
|
||||||
|
self.assertEqual(
|
||||||
|
self.NAME,
|
||||||
|
re.search(self.re_name, raw_output).group(1),
|
||||||
|
)
|
||||||
|
self.assertEqual(
|
||||||
|
'xyzpdq',
|
||||||
|
re.search(self.re_description, raw_output).group(1),
|
||||||
|
)
|
||||||
|
self.assertEqual(
|
||||||
|
'UP',
|
||||||
|
re.search(self.re_state, raw_output).group(1),
|
||||||
|
)
|
||||||
|
self.assertIsNotNone(
|
||||||
|
re.search(self.re_mac_address, raw_output).group(1),
|
||||||
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user