summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJenkins <jenkins@review.openstack.org>2016-02-22 01:24:26 +0000
committerGerrit Code Review <review@openstack.org>2016-02-22 01:24:26 +0000
commita121361bacf4c65162ba7dd23718a80bbf858d8a (patch)
tree28cce4bfd26de7224a9fab899bd3cd17df3a5c0d
parentb503734de0824b347fa6fc53971ab394372d8d42 (diff)
parent86cae7e170c8432223c122f617bcb757a101f179 (diff)
downloadpython-openstackclient-a121361bacf4c65162ba7dd23718a80bbf858d8a.tar.gz
Merge "Add functional tests for "image" command v2"
-rw-r--r--functional/tests/image/v2/__init__.py0
-rw-r--r--functional/tests/image/v2/test_image.py67
2 files changed, 67 insertions, 0 deletions
diff --git a/functional/tests/image/v2/__init__.py b/functional/tests/image/v2/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/functional/tests/image/v2/__init__.py
diff --git a/functional/tests/image/v2/test_image.py b/functional/tests/image/v2/test_image.py
new file mode 100644
index 00000000..f0ebc116
--- /dev/null
+++ b/functional/tests/image/v2/test_image.py
@@ -0,0 +1,67 @@
+# 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 os
+import uuid
+
+from functional.common import test
+
+
+class ImageTests(test.TestCase):
+ """Functional tests for image. """
+
+ NAME = uuid.uuid4().hex
+ OTHER_NAME = uuid.uuid4().hex
+ HEADERS = ['Name']
+ FIELDS = ['name']
+
+ @classmethod
+ def setUpClass(cls):
+ os.environ['OS_IMAGE_API_VERSION'] = '2'
+ opts = cls.get_show_opts(cls.FIELDS)
+ raw_output = cls.openstack('image create ' + cls.NAME + opts)
+ expected = cls.NAME + '\n'
+ cls.assertOutput(expected, raw_output)
+
+ @classmethod
+ def tearDownClass(cls):
+ # Rename test
+ raw_output = cls.openstack('image set --name ' + cls.OTHER_NAME + ' '
+ + cls.NAME)
+ cls.assertOutput('', raw_output)
+ # Delete test
+ raw_output = cls.openstack('image delete ' + cls.OTHER_NAME)
+ cls.assertOutput('', raw_output)
+
+ def test_image_list(self):
+ opts = self.get_list_opts(self.HEADERS)
+ raw_output = self.openstack('image list' + opts)
+ self.assertIn(self.NAME, raw_output)
+
+ def test_image_show(self):
+ opts = self.get_show_opts(self.FIELDS)
+ raw_output = self.openstack('image show ' + self.NAME + opts)
+ self.assertEqual(self.NAME + "\n", raw_output)
+
+ def test_image_set(self):
+ opts = self.get_show_opts([
+ "disk_format", "visibility", "min_disk", "min_ram", "name"])
+ self.openstack('image set --min-disk 4 --min-ram 5 ' +
+ '--public ' + self.NAME)
+ raw_output = self.openstack('image show ' + self.NAME + opts)
+ self.assertEqual("raw\n4\n5\n" + self.NAME + '\npublic\n', raw_output)
+
+ def test_image_metadata(self):
+ opts = self.get_show_opts(["name", "properties"])
+ self.openstack('image set --property a=b --property c=d ' + self.NAME)
+ raw_output = self.openstack('image show ' + self.NAME + opts)
+ self.assertEqual(self.NAME + "\na='b', c='d'\n", raw_output)