Merge "Remove use of contextlib.nested"

This commit is contained in:
Jenkins 2015-03-26 10:44:42 +00:00 committed by Gerrit Code Review
commit 835a1b87c4
4 changed files with 33 additions and 19 deletions

View File

@ -21,4 +21,5 @@ glance Specific Commandments
- [G323] Validate that LOG.exception messages use _LE. - [G323] Validate that LOG.exception messages use _LE.
- [G324] Validate that LOG.error messages use _LE. - [G324] Validate that LOG.error messages use _LE.
- [G325] Validate that LOG.critical messages use _LC. - [G325] Validate that LOG.critical messages use _LC.
- [G326] Validate that LOG.warning messages use _LW. - [G326] Validate that LOG.warning messages use _LW.
- [G327] Prevent use of deprecated contextlib.nested

View File

@ -139,6 +139,15 @@ def validate_log_translations(logical_line, physical_line, filename):
yield (0, msg) yield (0, msg)
def check_no_contextlib_nested(logical_line):
msg = ("G327: contextlib.nested is deprecated since Python 2.7. See "
"https://docs.python.org/2/library/contextlib.html#contextlib."
"nested for more information.")
if ("with contextlib.nested(" in logical_line or
"with nested(" in logical_line):
yield(0, msg)
def factory(register): def factory(register):
register(assert_true_instance) register(assert_true_instance)
register(assert_equal_type) register(assert_equal_type)
@ -146,3 +155,4 @@ def factory(register):
register(no_translate_debug_logs) register(no_translate_debug_logs)
register(no_direct_use_of_unicode_function) register(no_direct_use_of_unicode_function)
register(validate_log_translations) register(validate_log_translations)
register(check_no_contextlib_nested)

View File

@ -62,3 +62,13 @@ class HackingTestCase(utils.BaseTestCase):
"six.text_type('party over')")))) "six.text_type('party over')"))))
self.assertEqual(0, len(list(checks.no_direct_use_of_unicode_function( self.assertEqual(0, len(list(checks.no_direct_use_of_unicode_function(
"not_actually_unicode('something completely different')")))) "not_actually_unicode('something completely different')"))))
def test_no_contextlib_nested(self):
self.assertEqual(1, len(list(checks.check_no_contextlib_nested(
"with contextlib.nested("))))
self.assertEqual(1, len(list(checks.check_no_contextlib_nested(
"with nested("))))
self.assertEqual(0, len(list(checks.check_no_contextlib_nested(
"with foo as bar"))))

View File

@ -15,7 +15,6 @@
# 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 contextlib
import copy import copy
import datetime import datetime
import hashlib import hashlib
@ -394,7 +393,10 @@ class TestGlanceAPI(base.IsolatedUnitTest):
self.assertEqual(400, res.status_int) self.assertEqual(400, res.status_int)
self.assertIn('Required store bad is invalid', res.body) self.assertIn('Required store bad is invalid', res.body)
def test_create_with_location_get_store_or_400_raises_exception(self): @mock.patch.object(glance.api.v1.images.Controller, '_external_source')
@mock.patch.object(store, 'get_store_from_location')
def test_create_with_location_get_store_or_400_raises_exception(
self, mock_get_store_from_location, mock_external_source):
location = 'bad+scheme://localhost:0/image.qcow2' location = 'bad+scheme://localhost:0/image.qcow2'
scheme = 'bad+scheme' scheme = 'bad+scheme'
fixture_headers = { fixture_headers = {
@ -409,23 +411,14 @@ class TestGlanceAPI(base.IsolatedUnitTest):
for k, v in six.iteritems(fixture_headers): for k, v in six.iteritems(fixture_headers):
req.headers[k] = v req.headers[k] = v
ctlr = glance.api.v1.images.Controller mock_external_source.return_value = location
mock_get_store_from_location.return_value = scheme
with contextlib.nested( res = req.get_response(self.api)
mock.patch.object(ctlr, '_external_source', self.assertEqual(400, res.status_int)
return_value=location), self.assertEqual(1, mock_external_source.call_count)
mock.patch.object(store, self.assertEqual(1, mock_get_store_from_location.call_count)
'get_store_from_location', self.assertIn('Store for scheme %s not found' % scheme, res.body)
return_value=scheme)
) as (
mock_external_source,
mock_get_store_from_location
):
res = req.get_response(self.api)
self.assertEqual(400, res.status_int)
self.assertEqual(1, mock_external_source.call_count)
self.assertEqual(1, mock_get_store_from_location.call_count)
self.assertIn('Store for scheme %s not found' % scheme, res.body)
def test_create_with_location_unknown_scheme(self): def test_create_with_location_unknown_scheme(self):
fixture_headers = { fixture_headers = {