Merge pull request #1006 from r0fls/routing-fix
check if method is added in strict slash logic
This commit is contained in:
		| @@ -130,8 +130,15 @@ class Router: | ||||
|             return | ||||
|  | ||||
|         # Add versions with and without trailing / | ||||
|         slashed_methods = self.routes_all.get(uri + '/', frozenset({})) | ||||
|         if isinstance(methods, Iterable): | ||||
|             _slash_is_missing = all(method in slashed_methods for | ||||
|                                     method in methods) | ||||
|         else: | ||||
|             _slash_is_missing = methods in slashed_methods | ||||
|  | ||||
|         slash_is_missing = ( | ||||
|             not uri[-1] == '/' and not self.routes_all.get(uri + '/', False) | ||||
|             not uri[-1] == '/' and not _slash_is_missing | ||||
|         ) | ||||
|         without_slash_is_missing = ( | ||||
|             uri[-1] == '/' and not | ||||
|   | ||||
| @@ -44,6 +44,24 @@ def test_shorthand_routes_get(): | ||||
|     request, response = app.test_client.post('/get') | ||||
|     assert response.status == 405 | ||||
|  | ||||
| def test_shorthand_routes_multiple(): | ||||
|     app = Sanic('test_shorthand_routes_multiple') | ||||
|  | ||||
|     @app.get('/get') | ||||
|     def get_handler(request): | ||||
|         return text('OK') | ||||
|  | ||||
|     @app.options('/get') | ||||
|     def options_handler(request): | ||||
|         return text('') | ||||
|  | ||||
|     request, response = app.test_client.get('/get/') | ||||
|     assert response.status == 200 | ||||
|     assert response.text == 'OK' | ||||
|  | ||||
|     request, response = app.test_client.options('/get/') | ||||
|     assert response.status == 200 | ||||
|  | ||||
| def test_route_strict_slash(): | ||||
|     app = Sanic('test_route_strict_slash') | ||||
|  | ||||
| @@ -431,7 +449,7 @@ def test_websocket_route_with_subprotocols(): | ||||
|         'Sec-WebSocket-Key': 'dGhlIHNhbXBsZSBub25jZQ==', | ||||
|         'Sec-WebSocket-Version': '13'}) | ||||
|     assert response.status == 101 | ||||
|      | ||||
|  | ||||
|     assert results == ['bar', 'bar', None, None] | ||||
|  | ||||
|  | ||||
| @@ -754,6 +772,7 @@ def test_remove_route_without_clean_cache(): | ||||
|     assert response.status == 200 | ||||
|  | ||||
|     app.remove_route('/test', clean_cache=True) | ||||
|     app.remove_route('/test/', clean_cache=True) | ||||
|  | ||||
|     request, response = app.test_client.get('/test') | ||||
|     assert response.status == 404 | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Raphael Deem
					Raphael Deem