# -*- coding: utf-8 -*- """ (c) 2015-2018 - Copyright Red Hat Inc Authors: Pierre-Yves Chibon """ from __future__ import unicode_literals __requires__ = ['SQLAlchemy >= 0.8'] import unittest import sys import os sys.path.insert(0, os.path.join(os.path.dirname( os.path.abspath(__file__)), '..')) import pagure.lib import tests class PagureFlaskPluginMailtests(tests.SimplePagureTest): """ Tests for flask plugins controller of pagure """ def test_plugin_mail(self): """ Test the mail plugin on/off endpoint. """ tests.create_projects(self.session) tests.create_projects_git(os.path.join(self.path, 'repos')) user = tests.FakeUser(username='pingou') with tests.user_set(self.app.application, user): output = self.app.get('/test/settings/Mail') self.assertEqual(output.status_code, 200) output_text = output.get_data(as_text=True) self.assertIn( 'Settings Mail - test - Pagure', output_text) self.assertIn( '', output_text) self.assertIn( '', output_text) csrf_token = output_text.split( 'name="csrf_token" type="hidden" value="')[1].split('">')[0] data = {} output = self.app.post('/test/settings/Mail', data=data) self.assertEqual(output.status_code, 200) output_text = output.get_data(as_text=True) self.assertIn( 'Settings Mail - test - Pagure', output_text) self.assertIn( '', output_text) self.assertIn( '', output_text) data['csrf_token'] = csrf_token # With the git repo output = self.app.post( '/test/settings/Mail', data=data, follow_redirects=True) self.assertEqual(output.status_code, 200) output_text = output.get_data(as_text=True) self.assertIn( '
' 'Project Settings
\n', output_text) self.assertIn( 'Hook Mail deactivated', output_text) output = self.app.get('/test/settings/Mail') self.assertEqual(output.status_code, 200) output_text = output.get_data(as_text=True) self.assertIn( 'Settings Mail - test - Pagure', output_text) self.assertIn( '', output_text) self.assertIn( '', output_text) # Missing the required mail_to data = {'csrf_token': csrf_token, 'active': 'y'} output = self.app.post( '/test/settings/Mail', data=data, follow_redirects=True) self.assertEqual(output.status_code, 200) output_text = output.get_data(as_text=True) self.assertIn( 'Settings Mail - test - Pagure', output_text) self.assertNotIn( 'Hook activated', output_text) if self.get_wtforms_version() >= (2, 2): self.assertIn( '
\n ' '\n
\n \n ' '
This field is required.
', output_text) else: self.assertIn( '
\n ' '\n
\n \n ' '
This field is required.
', output_text) self.assertIn( '', output_text) # Activate hook data = { 'csrf_token': csrf_token, 'active': 'y', 'mail_to': 'foo@bar' } output = self.app.post( '/test/settings/Mail', data=data, follow_redirects=True) self.assertEqual(output.status_code, 200) output_text = output.get_data(as_text=True) self.assertIn( '
' 'Project Settings
\n', output_text) self.assertIn( 'Hook Mail activated', output_text) output = self.app.get('/test/settings/Mail') output_text = output.get_data(as_text=True) self.assertIn( 'Settings Mail - test - Pagure', output_text) self.assertIn( '', output_text) self.assertIn( '', output_text) # De-Activate hook data = {'csrf_token': csrf_token} output = self.app.post( '/test/settings/Mail', data=data, follow_redirects=True) self.assertEqual(output.status_code, 200) output_text = output.get_data(as_text=True) self.assertIn( '
' 'Project Settings
\n', output_text) self.assertIn( 'Hook Mail deactivated', output_text) output = self.app.get('/test/settings/Mail') output_text = output.get_data(as_text=True) self.assertIn( 'Settings Mail - test - Pagure', output_text) self.assertIn( '', output_text) self.assertIn( '', output_text) if __name__ == '__main__': unittest.main(verbosity=2)