Skip to content
Snippets Groups Projects
Select Git revision
  • cbbd3485ddd807a6e130d97587b62d08bb64bc2a
  • develop default protected
  • ical-export
  • feature/audit_log
  • fix/index
  • badge-redeem-404
  • 720-schedule_source
  • room-docu
  • chore/event-views
  • 511-schedule-foo-fixed
  • 607-schedule-versions
  • deploy/curl-verbose
  • fix/public-badge-access-rights
  • 445-schedule-redirects
  • 623-wiki-im-baustellenmodus-sollte-mal-als-wiki-admin-trotzdem-seiten-anlegen-bearbeiten-konnen
  • fix/registration_mail_subject
  • feature/conference-query-set
  • feature/568-habitatmanagement
  • feat/unit-integration-tests
  • camp23-prod
  • production
  • prod-2024-12-27_20-15
  • prod-2024-12-27_16-37
  • prod-2024-12-27_16-01
  • prod-2024-12-27_13-29
  • prod-2024-12-27_00-34
  • prod-2024-12-26_21-45
  • prod-2024-12-26_13-12
  • prod-2024-12-26_00-21
  • prod-2024-12-25_21-04
  • prod-2024-12-25_15-54
  • prod-2024-12-25_01-29
  • prod-2024-12-24_14-48
  • prod-2024-12-23_23-39
  • prod-2024-12-22_21-12
  • prod-2024-12-22_17-25
  • prod-2024-12-22_01-34
  • prod-2024-12-22_00-55
  • prod-2024-12-21_13-42
  • prod-2024-12-21_10-44
  • prod-2024-12-20_12-25
41 results

.gitattributes

Blame
  • Forked from hub / hub
    Source project has a limited visibility.
    test_mail.py 3.66 KiB
    import datetime
    import time
    import unittest
    
    from flask import url_for, session
    
    # These imports are required, because otherwise we get circular imports?!
    from uffd.ldap import ldap
    from uffd import user
    
    from uffd.mail.models import Mail
    from uffd import create_app, db
    
    from utils import dump, UffdTestCase
    
    def get_mail():
    	return Mail.ldap_get('uid=test,ou=postfix,dc=example,dc=com')
    
    class TestMailViews(UffdTestCase):
    	def setUp(self):
    		super().setUp()
    		self.client.post(path=url_for('session.login'),
    			data={'loginname': 'testadmin', 'password': 'adminpassword'}, follow_redirects=True)
    
    	def test_index(self):
    		r = self.client.get(path=url_for('mail.index'), follow_redirects=True)
    		dump('mail_index', r)
    		self.assertEqual(r.status_code, 200)
    
    	def test_index_empty(self):
    		ldap.session.delete(get_mail())
    		ldap.session.commit()
    		self.assertIsNone(get_mail())
    		r = self.client.get(path=url_for('mail.index'), follow_redirects=True)
    		dump('mail_index_empty', r)
    		self.assertEqual(r.status_code, 200)
    
    	def test_show(self):
    		r = self.client.get(path=url_for('mail.show', uid=get_mail().uid), follow_redirects=True)
    		dump('mail_show', r)
    		self.assertEqual(r.status_code, 200)
    
    	def test_new(self):
    		r = self.client.get(path=url_for('mail.show'), follow_redirects=True)
    		dump('mail_new', r)
    		self.assertEqual(r.status_code, 200)
    
    	def test_update(self):
    		m = get_mail()
    		self.assertIsNotNone(m)
    		self.assertEqual(m.uid, 'test')
    		self.assertEqual(sorted(m.receivers), ['test1@example.com', 'test2@example.com'])
    		self.assertEqual(sorted(m.destinations), ['testuser@mail.example.com'])
    		r = self.client.post(path=url_for('mail.update', uid=m.uid),
    			data={'mail-uid': 'test1', 'mail-receivers': 'foo@bar.com\ntest@bar.com',
    			'mail-destinations': 'testuser@mail.example.com\ntestadmin@mail.example.com'}, follow_redirects=True)
    		dump('mail_update', r)
    		self.assertEqual(r.status_code, 200)
    		m = get_mail()
    		self.assertIsNotNone(m)
    		self.assertEqual(m.uid, 'test')
    		self.assertEqual(sorted(m.receivers), ['foo@bar.com', 'test@bar.com'])
    		self.assertEqual(sorted(m.destinations), ['testadmin@mail.example.com', 'testuser@mail.example.com'])
    
    	def test_create(self):
    		r = self.client.post(path=url_for('mail.update'),
    			data={'mail-uid': 'test1', 'mail-receivers': 'foo@bar.com\ntest@bar.com',
    			'mail-destinations': 'testuser@mail.example.com\ntestadmin@mail.example.com'}, follow_redirects=True)
    		dump('mail_create', r)
    		self.assertEqual(r.status_code, 200)
    		m = Mail.ldap_get('uid=test1,ou=postfix,dc=example,dc=com')
    		self.assertEqual(m.uid, 'test1')
    		self.assertEqual(sorted(m.receivers), ['foo@bar.com', 'test@bar.com'])
    		self.assertEqual(sorted(m.destinations), ['testadmin@mail.example.com', 'testuser@mail.example.com'])
    
    	@unittest.skip('We do not catch LDAP errors at the moment!') # TODO: Not sure if necessary
    	def test_create_error(self):
    		r = self.client.post(path=url_for('mail.update'),
    			data={'mail-uid': 'test', 'mail-receivers': 'foo@bar.com\ntest@bar.com',
    			'mail-destinations': 'testuser@mail.example.com\ntestadmin@mail.example.com'}, follow_redirects=True)
    		dump('mail_create_error', r)
    		self.assertEqual(r.status_code, 200)
    		m = get_mail()
    		self.assertIsNotNone(m)
    		self.assertEqual(m.uid, 'test')
    		self.assertEqual(sorted(m.receivers), ['test1@example.com', 'test2@example.com'])
    		self.assertEqual(sorted(m.destinations), ['testuser@mail.example.com'])
    
    	def test_delete(self):
    		self.assertIsNotNone(get_mail())
    		r = self.client.get(path=url_for('mail.delete', uid=get_mail().uid), follow_redirects=True)
    		dump('mail_delete', r)
    		self.assertEqual(r.status_code, 200)
    		self.assertIsNone(get_mail())
    
    class TestMailViewsOL(TestMailViews):
    	use_openldap = True