From e8d17bdacfe438bb99405df03991189f01221e89 Mon Sep 17 00:00:00 2001 From: Pierre-Yves Chibon Date: Mar 10 2015 16:39:22 +0000 Subject: Add unit-tests for the progit_ticket_hook plugin --- diff --git a/tests/test_progit_flask_ui_plugins_progit_ticket_hook.py b/tests/test_progit_flask_ui_plugins_progit_ticket_hook.py new file mode 100644 index 0000000..eb1b8b1 --- /dev/null +++ b/tests/test_progit_flask_ui_plugins_progit_ticket_hook.py @@ -0,0 +1,143 @@ +# -*- coding: utf-8 -*- + +""" + (c) 2015 - Copyright Red Hat Inc + + Authors: + Pierre-Yves Chibon + +""" + +__requires__ = ['SQLAlchemy >= 0.8'] +import pkg_resources + +import json +import unittest +import shutil +import sys +import os + +import pygit2 +from mock import patch + +sys.path.insert(0, os.path.join(os.path.dirname( + os.path.abspath(__file__)), '..')) + +import progit.lib +import tests + + +class ProgitFlaskPluginProgitTicketHooktests(tests.Modeltests): + """ Tests for progit_hook plugin of progit """ + + def setUp(self): + """ Set up the environnment, ran before every tests. """ + super(ProgitFlaskPluginProgitTicketHooktests, self).setUp() + + progit.APP.config['TESTING'] = True + progit.SESSION = self.session + progit.ui.SESSION = self.session + progit.ui.app.SESSION = self.session + progit.ui.plugins.SESSION = self.session + progit.hooks.progit_ticket_hook.SESSION = self.session + + progit.APP.config['GIT_FOLDER'] = tests.HERE + progit.APP.config['FORK_FOLDER'] = os.path.join( + tests.HERE, 'forks') + progit.APP.config['TICKETS_FOLDER'] = os.path.join( + tests.HERE, 'tickets') + progit.APP.config['DOCS_FOLDER'] = os.path.join( + tests.HERE, 'docs') + self.app = progit.APP.test_client() + + def test_plugin_mail(self): + """ Test the mail plugin on/off endpoint. """ + + tests.create_projects(self.session) + + user = tests.FakeUser(username='pingou') + with tests.user_set(progit.APP, user): + output = self.app.get('/test/settings/progit tickets') + self.assertEqual(output.status_code, 200) + self.assertTrue('

test project #1

' in output.data) + self.assertTrue('

progit tickets

' in output.data) + self.assertTrue( + '' + in output.data) + + csrf_token = output.data.split( + 'name="csrf_token" type="hidden" value="')[1].split('">')[0] + + data = {} + + output = self.app.post('/test/settings/progit tickets', data=data) + self.assertEqual(output.status_code, 200) + self.assertTrue('

test project #1

' in output.data) + self.assertTrue('

progit tickets

' in output.data) + self.assertTrue( + '' + in output.data) + + data['csrf_token'] = csrf_token + # No git found + output = self.app.post('/test/settings/progit tickets', data=data) + self.assertEqual(output.status_code, 404) + + # Create both the tickets repo + tests.create_projects_git(os.path.join(tests.HERE, 'tickets')) + + # With the git repo + output = self.app.post('/test/settings/progit tickets', data=data) + self.assertEqual(output.status_code, 200) + self.assertTrue('

test project #1

' in output.data) + self.assertTrue('

progit tickets

' in output.data) + self.assertTrue( + '
  • Hook inactived
  • ' in output.data) + self.assertTrue( + '' + in output.data) + + self.assertFalse(os.path.exists(os.path.join( + tests.HERE, 'tickets', 'test.git', 'hooks', + 'post-receive.progit_tickets'))) + + # Activate hook + data = { + 'csrf_token': csrf_token, + 'active': 'y', + } + + output = self.app.post('/test/settings/progit tickets', data=data) + self.assertEqual(output.status_code, 200) + self.assertTrue('

    test project #1

    ' in output.data) + self.assertTrue('

    progit tickets

    ' in output.data) + self.assertTrue( + '
  • Hook activated
  • ' in output.data) + self.assertTrue( + '' in output.data) + + self.assertTrue(os.path.exists(os.path.join( + tests.HERE, 'tickets', 'test.git', 'hooks', + 'post-receive.progit_tickets'))) + + # De-Activate hook + data = {'csrf_token': csrf_token} + output = self.app.post('/test/settings/progit tickets', data=data) + self.assertTrue('

    test project #1

    ' in output.data) + self.assertTrue('

    progit tickets

    ' in output.data) + self.assertTrue( + '
  • Hook inactived
  • ' in output.data) + self.assertTrue( + '' in output.data) + + self.assertFalse(os.path.exists(os.path.join( + tests.HERE, 'tickets', 'test.git', 'hooks', + 'post-receive.progit_tickets'))) + + +if __name__ == '__main__': + SUITE = unittest.TestLoader().loadTestsFromTestCase( + ProgitFlaskPluginProgitTicketHooktests) + unittest.TextTestRunner(verbosity=2).run(SUITE)