summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJenkins <jenkins@review.openstack.org>2016-05-19 10:34:43 +0000
committerGerrit Code Review <review@openstack.org>2016-05-19 10:34:43 +0000
commit66ec268c142567f65f1578a96e38cb40e6f53b9c (patch)
tree8aed79ee84dc315432d12c94c858e9ef67055351
parent5ed9b7b9f66cc592c78595516acdeae8b6e9516e (diff)
parent1c8f833fc8e7d49066ed5fad23590aa5b1aed69d (diff)
downloadpython-neutronclient-66ec268c142567f65f1578a96e38cb40e6f53b9c.tar.gz
Merge "Do not print 'Created' message when using non-table formatter" into stable/liberty
-rw-r--r--neutronclient/neutron/v2_0/__init__.py5
-rw-r--r--neutronclient/tests/functional/core/test_cli_formatter.py59
2 files changed, 62 insertions, 2 deletions
diff --git a/neutronclient/neutron/v2_0/__init__.py b/neutronclient/neutron/v2_0/__init__.py
index ad2f6e7..68775fd 100644
--- a/neutronclient/neutron/v2_0/__init__.py
+++ b/neutronclient/neutron/v2_0/__init__.py
@@ -501,8 +501,9 @@ class CreateCommand(NeutronCommand, show.ShowOne):
self.format_output_data(data)
info = self.resource in data and data[self.resource] or None
if info:
- print(_('Created a new %s:') % self.resource,
- file=self.app.stdout)
+ if parsed_args.formatter == 'table':
+ print(_('Created a new %s:') % self.resource,
+ file=self.app.stdout)
else:
info = {'': ''}
return zip(*sorted(six.iteritems(info)))
diff --git a/neutronclient/tests/functional/core/test_cli_formatter.py b/neutronclient/tests/functional/core/test_cli_formatter.py
new file mode 100644
index 0000000..cd133de
--- /dev/null
+++ b/neutronclient/tests/functional/core/test_cli_formatter.py
@@ -0,0 +1,59 @@
+# Copyright 2016 NEC Corporation
+#
+# 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.
+
+from oslo_serialization import jsonutils
+from oslo_utils import uuidutils
+import yaml
+
+from neutronclient.tests.functional import base
+
+
+class TestCLIFormatter(base.ClientTestBase):
+
+ def setUp(self):
+ super(TestCLIFormatter, self).setUp()
+ self.net_name = 'net-%s' % uuidutils.generate_uuid()
+ self.addCleanup(self.neutron, 'net-delete %s' % self.net_name)
+
+ def _create_net(self, fmt, col_attrs):
+ params = ['-c %s' % attr for attr in col_attrs]
+ params.append('-f %s' % fmt)
+ params.append(self.net_name)
+ param_string = ' '.join(params)
+ return self.neutron('net-create', params=param_string)
+
+ def test_net_create_with_json_formatter(self):
+ result = self._create_net('json', ['name', 'admin_state_up'])
+ self.assertDictEqual({'name': self.net_name,
+ 'admin_state_up': True},
+ jsonutils.loads(result))
+
+ def test_net_create_with_yaml_formatter(self):
+ result = self._create_net('yaml', ['name', 'admin_state_up'])
+ self.assertDictEqual({'name': self.net_name,
+ 'admin_state_up': True},
+ yaml.load(result))
+
+ def test_net_create_with_value_formatter(self):
+ # NOTE(amotoki): In 'value' formatter, there is no guarantee
+ # in the order of attribute, so we use one attribute in this test.
+ result = self._create_net('value', ['name'])
+ self.assertEqual(self.net_name, result.strip())
+
+ def test_net_create_with_shell_formatter(self):
+ result = self._create_net('shell', ['name', 'admin_state_up'])
+ result_lines = set(result.strip().split('\n'))
+ self.assertSetEqual(set(['name="%s"' % self.net_name,
+ 'admin_state_up="True"']),
+ result_lines)