From d32efc4e171993bbbc2c8b9d29f9cef243c93015 Mon Sep 17 00:00:00 2001 From: Joseph Schorr Date: Thu, 12 Jul 2018 15:24:49 +0300 Subject: [PATCH] Move anon checked test to pytest --- endpoints/test/test_anon_checked.py | 27 +++++++++++++++++++++++++ test/test_anon_checked.py | 31 ----------------------------- 2 files changed, 27 insertions(+), 31 deletions(-) create mode 100644 endpoints/test/test_anon_checked.py delete mode 100644 test/test_anon_checked.py diff --git a/endpoints/test/test_anon_checked.py b/endpoints/test/test_anon_checked.py new file mode 100644 index 000000000..94cc9b9aa --- /dev/null +++ b/endpoints/test/test_anon_checked.py @@ -0,0 +1,27 @@ +import pytest + +from app import app +from endpoints.v1 import v1_bp +from endpoints.v2 import v2_bp +from endpoints.verbs import verbs + +@pytest.mark.parametrize('blueprint', [ + v2_bp, + v1_bp, + verbs, +]) +def test_verify_blueprint(blueprint): + class Checker(object): + def __init__(self): + self.first_registration = True + self.app = app + + def add_url_rule(self, rule, endpoint, view_function, methods=None): + result = ('__anon_protected' in dir(view_function) or + '__anon_allowed' in dir(view_function)) + error_message = ('Missing anonymous access protection decorator on function ' + + '%s under blueprint %s' % (endpoint, blueprint.name)) + assert result, error_message + + for deferred_function in blueprint.deferred_functions: + deferred_function(Checker()) diff --git a/test/test_anon_checked.py b/test/test_anon_checked.py deleted file mode 100644 index db8f36d52..000000000 --- a/test/test_anon_checked.py +++ /dev/null @@ -1,31 +0,0 @@ -import unittest - -from endpoints.v1 import v1_bp -from endpoints.verbs import verbs -from app import app - -class TestAnonymousAccessChecked(unittest.TestCase): - def verifyBlueprint(self, blueprint): - class Checker(object): - def __init__(self, test_case): - self.test_case = test_case - self.first_registration = True - self.app = app - - def add_url_rule(self, rule, endpoint, view_function, methods=None): - if (not '__anon_protected' in dir(view_function) and - not '__anon_allowed' in dir(view_function)): - error_message = ('Missing anonymous access protection decorator on function ' + - '%s under blueprint %s' % (endpoint, blueprint.name)) - self.test_case.fail(error_message) - - for deferred_function in blueprint.deferred_functions: - deferred_function(Checker(self)) - - def test_anonymous_access_checked(self): - self.verifyBlueprint(v1_bp) - self.verifyBlueprint(verbs) - -if __name__ == '__main__': - unittest.main() -