Merge "Add backend subrequest tests for staticweb"

This commit is contained in:
Jenkins 2015-10-22 10:40:11 +00:00 committed by Gerrit Code Review
commit 76c83cd501

View File

@ -15,6 +15,7 @@
import json import json
import unittest import unittest
import mock
from swift.common.swob import Request, Response from swift.common.swob import Request, Response
from swift.common.middleware import staticweb from swift.common.middleware import staticweb
@ -722,5 +723,31 @@ class TestStaticWeb(unittest.TestCase):
resp = Request.blank('/v1/a/c3').get_response(self.test_staticweb) resp = Request.blank('/v1/a/c3').get_response(self.test_staticweb)
self.assertEqual(resp.status_int, 200) self.assertEqual(resp.status_int, 200)
def test_subrequest_not_override_auth(self):
app_call = \
'swift.common.middleware.staticweb._StaticWebContext._app_call'
orig_app_call = staticweb._StaticWebContext._app_call
_fail = self.fail
def hook_app_call(self, env):
if 'swift.authorize_override' in env:
_fail('staticweb must not create authorize info by itself')
return orig_app_call(self, env)
with mock.patch(app_call, hook_app_call):
# testing for _listing container
resp = Request.blank('/v1/a/c4/').get_response(self.test_staticweb)
self.assertEqual(resp.status_int, 200) # sanity
# testing for _listing object subdir
resp = Request.blank(
'/v1/a/c4/unknown').get_response(self.test_staticweb)
self.assertEqual(resp.status_int, 404)
# testing for _error_response
resp = Request.blank('/v1/a/c5/').get_response(self.test_staticweb)
self.assertEqual(resp.status_int, 503) # sanity
if __name__ == '__main__': if __name__ == '__main__':
unittest.main() unittest.main()