From bf2dbf3256aec882ad558b1f38dd568fa6f08ff1 Mon Sep 17 00:00:00 2001
From: Richard Theis <rtheis@us.ibm.com>
Date: Fri, 12 Feb 2016 10:11:24 -0600
Subject: [PATCH] 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
---
 functional/tests/network/v2/test_subnet.py | 62 ++++++++++++++++++++++
 1 file changed, 62 insertions(+)
 create mode 100644 functional/tests/network/v2/test_subnet.py

diff --git a/functional/tests/network/v2/test_subnet.py b/functional/tests/network/v2/test_subnet.py
new file mode 100644
index 0000000000..afecfab07b
--- /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)