summaryrefslogtreecommitdiff
path: root/functional
diff options
context:
space:
mode:
authorRichard Theis <rtheis@us.ibm.com>2016-02-12 10:11:24 -0600
committerRichard Theis <rtheis@us.ibm.com>2016-03-04 08:12:01 -0600
commitbf2dbf3256aec882ad558b1f38dd568fa6f08ff1 (patch)
tree2ce0ff95faa73d05eb3c836e4250cea463c73cd9 /functional
parentd763acdf1c272b60a2ed30c1b93f1a02f1c19fab (diff)
downloadpython-openstackclient-bf2dbf3256aec882ad558b1f38dd568fa6f08ff1.tar.gz
Add subnet functional tests
Add functional tests for "os subnet" commands. Change-Id: Ie80763334f2fb4099b3e549256576d71cc213c07 Depends-On: Ia6120b8dccf2ee83dc89b3f496f7180d4dc5199a Related-Bug: #1523258 Related-Bug: #1542359 Related-Bug: #1542362 Related-Bug: #1542364 Related-Bug: #1542363 Partially-Implements: blueprint neutron-client
Diffstat (limited to 'functional')
-rw-r--r--functional/tests/network/v2/test_subnet.py62
1 files changed, 62 insertions, 0 deletions
diff --git a/functional/tests/network/v2/test_subnet.py b/functional/tests/network/v2/test_subnet.py
new file mode 100644
index 00000000..afecfab0
--- /dev/null
+++ b/functional/tests/network/v2/test_subnet.py
@@ -0,0 +1,62 @@
+# Licensed under the Apache License, Version 2.0 (the "License"); you may
+# not use this file except in compliance with the License. You may obtain
+# a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+# License for the specific language governing permissions and limitations
+# under the License.
+
+import uuid
+
+import testtools
+
+from functional.common import test
+
+
+class SubnetTests(test.TestCase):
+ """Functional tests for subnet. """
+ NAME = uuid.uuid4().hex
+ NETWORK_NAME = uuid.uuid4().hex
+ HEADERS = ['Name']
+ FIELDS = ['name']
+
+ @classmethod
+ def setUpClass(cls):
+ # Create a network for the subnet.
+ cls.openstack('network create ' + cls.NETWORK_NAME)
+ opts = cls.get_show_opts(cls.FIELDS)
+ raw_output = cls.openstack(
+ 'subnet create --network ' + cls.NETWORK_NAME +
+ ' --subnet-range 10.10.10.0/24 ' +
+ cls.NAME + opts
+ )
+ expected = cls.NAME + '\n'
+ cls.assertOutput(expected, raw_output)
+
+ @classmethod
+ def tearDownClass(cls):
+ raw_output = cls.openstack('subnet delete ' + cls.NAME)
+ cls.assertOutput('', raw_output)
+ raw_output = cls.openstack('network delete ' + cls.NETWORK_NAME)
+ cls.assertOutput('', raw_output)
+
+ def test_subnet_list(self):
+ opts = self.get_list_opts(self.HEADERS)
+ raw_output = self.openstack('subnet list' + opts)
+ self.assertIn(self.NAME, raw_output)
+
+ @testtools.skip('bug/1542363')
+ def test_subnet_set(self):
+ self.openstack('subnet set --no-dhcp ' + self.NAME)
+ opts = self.get_show_opts(['name', 'enable_dhcp'])
+ raw_output = self.openstack('subnet show ' + self.NAME + opts)
+ self.assertEqual("False\n" + self.NAME + "\n", raw_output)
+
+ def test_subnet_show(self):
+ opts = self.get_show_opts(self.FIELDS)
+ raw_output = self.openstack('subnet show ' + self.NAME + opts)
+ self.assertEqual(self.NAME + "\n", raw_output)