Я пытаюсь добавить тесты в основное приложение. Доступ ко всем требует входа в систему.(unittest) Тестирование Flask-Security: не удается пройти страницу входа
Вот мой тест класс:
class MyAppTestCase(FlaskTestCaseMixin):
def _create_app(self):
raise NotImplementedError
def _create_fixtures(self):
self.user = EmployeeFactory()
def setUp(self):
super(MyAppTestCase, self).setUp()
self.app = self._create_app()
self.client = self.app.test_client()
self.app_context = self.app.app_context()
self.app_context.push()
db.create_all()
self._create_fixtures()
self._create_csrf_token()
def tearDown(self):
super(MyAppTestCase, self).tearDown()
db.drop_all()
self.app_context.pop()
def _post(self, route, data=None, content_type=None, follow_redirects=True, headers=None):
content_type = content_type or 'application/x-www-form-urlencoded'
return self.client.post(route, data=data, follow_redirects=follow_redirects, content_type=content_type, headers=headers)
def _login(self, email=None, password=None):
email = email or self.user.email
password = password or 'password'
data = {
'email': email,
'password': password,
'remember': 'y'
}
return self._post('/login', data=data)
class MyFrontendTestCase(MyAppTestCase):
def _create_app(self):
return create_app(settings)
def setUp(self):
super(MyFrontendTestCase, self).setUp()
self._login()
Я бегу мои тесты используют nosetests в Терминале так: source my_env/bin/activate && nosetests --exe
Основные тесты, как они не в состоянии:
class CoolTestCase(MyFrontendTestCase):
def test_logged_in(self):
r = self._login()
self.assertIn('MyAppName', r.data)
def test_authenticated_access(self):
r = self.get('/myroute/')
self.assertIn('MyAppName', r.data)
С выхода , Я вижу, что r.data
- это всего лишь HTML-адрес страницы входа без ошибок (например, неправильное имя пользователя или пароль) или предупреждения («Пожалуйста, войдите, чтобы получить доступ к этому страница ").
Я входе в течение setUp
процесса, так test_authenticated_access
должны позволить мне либо доступ /myroute/
или перенаправить меня на страницу входа в систему с мелькнуло сообщение «Пожалуйста, войдите, чтобы получить доступ к этой странице». Но это не так.
Я не могу понять, что случилось. Я основано мое испытание прочь те, которые я нашел в Колба документации и this app boilerplate
Я вижу, что вы используете CSRF токены - вы пробовали отключить их и увидеть, если это получает вас дальше? Я знаю, что они укусили меня в тестах больше времени, чем я помню. –
Если вы используете (или можете использовать) Flask 0.10, я настоятельно рекомендую просто использовать новый поддельный контекстный материал: http://flask.pocoo.org/docs/testing/#faking-resources-and-context Мы в настоящее время делает что-то очень похожее на то, что вы делаете для наших тестов, и как только мы сможем обновиться, я все это разорву в пользу этого. –
@RachelSanders - у меня уже есть 'WTF_CSRF_ENABLED', установленный на' False' –