# # Copyright (c) 2001 Richard Jones, richard@bofh.asn.au. # This module is free software, and you may redistribute it and/or modify # under the same terms as Python, so long as this copyright message and # disclaimer are retained in their original form. # # This module is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # # $Id: test_mailgw.py,v 1.1.2.1 2002-02-06 04:05:55 richard Exp $ import unittest, cStringIO, tempfile, os, shutil, errno, imp, sys from roundup.mailgw import MailGW from roundup import init, instance class MailgwTestCase(unittest.TestCase): count = 0 schema = 'classic' def setUp(self): MailgwTestCase.count = MailgwTestCase.count + 1 self.dirname = '_test_%s'%self.count try: shutil.rmtree(self.dirname) except OSError, error: if error.errno not in (errno.ENOENT, errno.ESRCH): raise # create the instance init.init(self.dirname, self.schema, 'anydbm', 'sekrit') # check we can load the package self.instance = instance.open(self.dirname) # and open the database self.db = self.instance.open('sekrit') self.db.user.create(username='Chef', address='chef@bork.bork.bork') self.db.user.create(username='richard', address='richard@test') self.db.user.create(username='mary', address='mary@test') self.db.user.create(username='john', address='john@test') def tearDown(self): if os.path.exists(os.environ['SENDMAILDEBUG']): os.remove(os.environ['SENDMAILDEBUG']) try: shutil.rmtree(self.dirname) except OSError, error: if error.errno not in (errno.ENOENT, errno.ESRCH): raise def testNewIssue(self): message = cStringIO.StringIO('''Content-Type: text/plain; charset="iso-8859-1" From: Chef Subject: [issue] Testing... This is a test submission of a new issue. ''') handler = self.instance.MailGW(self.instance, self.db) handler.main(message) if os.path.exists(os.environ['SENDMAILDEBUG']): error = open(os.environ['SENDMAILDEBUG']).read() self.assertEqual('no error', error) def testNewIssueAuthMsg(self): message = cStringIO.StringIO('''Content-Type: text/plain; charset="iso-8859-1" From: Chef Subject: [issue] Testing... [nosy=mary; assignedto=richard] This is a test submission of a new issue. ''') handler = self.instance.MailGW(self.instance, self.db) # TODO: fix the damn config - this is apalling self.db.config.MESSAGES_TO_AUTHOR = 'yes' handler.main(message) self.assertEqual(open(os.environ['SENDMAILDEBUG']).read(), '''FROM: roundup-admin@fill.me.in. TO: chef@bork.bork.bork, mary@test, richard@test Content-Type: text/plain Subject: [issue1] Testing... To: chef@bork.bork.bork, mary@test, richard@test From: Chef Reply-To: Roundup issue tracker MIME-Version: 1.0 Message-Id: New submission from Chef : This is a test submission of a new issue. ---------- assignedto: richard messages: 1 nosy: mary, Chef, richard status: unread title: Testing... ___________________________________________________ "Roundup issue tracker" http://some.useful.url/issue1 ___________________________________________________ ''') def testFollowup(self): self.testNewIssue() message = cStringIO.StringIO('''Content-Type: text/plain; charset="iso-8859-1" From: richard To: issue_tracker@fill.me.in. Message-Id: In-Reply-To: Subject: [issue1] Testing... [assignedto=mary; nosy=john] This is a followup ''') handler = self.instance.MailGW(self.instance, self.db) handler.main(message) self.assertEqual(open(os.environ['SENDMAILDEBUG']).read(), '''FROM: roundup-admin@fill.me.in. TO: chef@bork.bork.bork, mary@test, john@test Content-Type: text/plain Subject: [issue1] Testing... To: chef@bork.bork.bork, mary@test, john@test From: richard Reply-To: Roundup issue tracker MIME-Version: 1.0 Message-Id: In-Reply-To: richard added the comment: This is a followup ---------- assignedto: -> mary nosy: +mary, john status: unread -> chatting ___________________________________________________ "Roundup issue tracker" http://some.useful.url/issue1 ___________________________________________________ ''', 'Generated message not correct') def testFollowup2(self): self.testNewIssue() message = cStringIO.StringIO('''Content-Type: text/plain; charset="iso-8859-1" From: mary To: issue_tracker@fill.me.in. Message-Id: In-Reply-To: Subject: [issue1] Testing... This is a second followup ''') handler = self.instance.MailGW(self.instance, self.db) handler.main(message) self.assertEqual(open(os.environ['SENDMAILDEBUG']).read(), '''FROM: roundup-admin@fill.me.in. TO: chef@bork.bork.bork, richard@test Content-Type: text/plain Subject: [issue1] Testing... To: chef@bork.bork.bork, richard@test From: mary Reply-To: Roundup issue tracker MIME-Version: 1.0 Message-Id: In-Reply-To: mary added the comment: This is a second followup ---------- status: unread -> chatting ___________________________________________________ "Roundup issue tracker" http://some.useful.url/issue1 ___________________________________________________ ''', 'Generated message not correct') def testEnc01(self): self.testNewIssue() message = cStringIO.StringIO('''Content-Type: text/plain; charset="iso-8859-1" From: mary To: issue_tracker@fill.me.in. Message-Id: In-Reply-To: Subject: [issue1] Testing... Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable A message with encoding (encoded oe =F6) ''') handler = self.instance.MailGW(self.instance, self.db) handler.main(message) message_data = open(os.environ['SENDMAILDEBUG']).read() self.assertEqual(message_data, '''FROM: roundup-admin@fill.me.in. TO: chef@bork.bork.bork, richard@test Content-Type: text/plain Subject: [issue1] Testing... To: chef@bork.bork.bork, richard@test From: mary Reply-To: Roundup issue tracker MIME-Version: 1.0 Message-Id: In-Reply-To: mary added the comment: A message with encoding (encoded oe ö) ---------- status: unread -> chatting ___________________________________________________ "Roundup issue tracker" http://some.useful.url/issue1 ___________________________________________________ ''', 'Generated message not correct') def testMultipartEnc01(self): self.testNewIssue() message = cStringIO.StringIO('''Content-Type: text/plain; charset="iso-8859-1" From: mary To: issue_tracker@fill.me.in. Message-Id: In-Reply-To: Subject: [issue1] Testing... Content-Type: multipart/mixed; boundary="----_=_NextPart_000_01" This message is in MIME format. Since your mail reader does not understand this format, some or all of this message may not be legible. ------_=_NextPart_000_01 Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable A message with first part encoded (encoded oe =F6) ''') handler = self.instance.MailGW(self.instance, self.db) handler.main(message) message_data = open(os.environ['SENDMAILDEBUG']).read() self.assertEqual(message_data, '''FROM: roundup-admin@fill.me.in. TO: chef@bork.bork.bork, richard@test Content-Type: text/plain Subject: [issue1] Testing... To: chef@bork.bork.bork, richard@test From: mary Reply-To: Roundup issue tracker MIME-Version: 1.0 Message-Id: In-Reply-To: mary added the comment: A message with first part encoded (encoded oe ö) ---------- status: unread -> chatting ___________________________________________________ "Roundup issue tracker" http://some.useful.url/issue1 ___________________________________________________ ''', 'Generated message not correct') class ExtMailgwTestCase(MailgwTestCase): schema = 'extended' def suite(): l = [unittest.makeSuite(MailgwTestCase, 'test'), unittest.makeSuite(ExtMailgwTestCase, 'test') ] return unittest.TestSuite(l) # # $Log: not supported by cvs2svn $ # Revision 1.9 2002/02/05 14:15:29 grubert # . respect encodings in non multipart messages. # # Revision 1.8 2002/02/04 09:40:21 grubert # . add test for multipart messages with first part being encoded. # # Revision 1.7 2002/01/22 11:54:45 rochecompaan # Fixed status change in mail gateway. # # Revision 1.6 2002/01/21 10:05:48 rochecompaan # Feature: # . the mail gateway now responds with an error message when invalid # values for arguments are specified for link or multilink properties # . modified unit test to check nosy and assignedto when specified as # arguments # # Fixed: # . fixed setting nosy as argument in subject line # # Revision 1.5 2002/01/15 00:12:40 richard # #503340 ] creating issue with [asignedto=p.ohly] # # Revision 1.4 2002/01/14 07:12:15 richard # removed file writing from tests... # # Revision 1.3 2002/01/14 02:20:15 richard # . changed all config accesses so they access either the instance or the # config attriubute on the db. This means that all config is obtained from # instance_config instead of the mish-mash of classes. This will make # switching to a ConfigParser setup easier too, I hope. # # At a minimum, this makes migration a _little_ easier (a lot easier in the # 0.5.0 switch, I hope!) # # Revision 1.2 2002/01/11 23:22:29 richard # . #502437 ] rogue reactor and unittest # in short, the nosy reactor was modifying the nosy list. That code had # been there for a long time, and I suspsect it was there because we # weren't generating the nosy list correctly in other places of the code. # We're now doing that, so the nosy-modifying code can go away from the # nosy reactor. # # Revision 1.1 2002/01/02 02:31:38 richard # Sorry for the huge checkin message - I was only intending to implement #496356 # but I found a number of places where things had been broken by transactions: # . modified ROUNDUPDBSENDMAILDEBUG to be SENDMAILDEBUG and hold a filename # for _all_ roundup-generated smtp messages to be sent to. # . the transaction cache had broken the roundupdb.Class set() reactors # . newly-created author users in the mailgw weren't being committed to the db # # Stuff that made it into CHANGES.txt (ie. the stuff I was actually working # on when I found that stuff :): # . #496356 ] Use threading in messages # . detectors were being registered multiple times # . added tests for mailgw # . much better attaching of erroneous messages in the mail gateway # # # # # vim: set filetype=python ts=4 sw=4 et si