iro/tests/offer_integrated.py
author Sandro Knauß <knauss@netzguerilla.net>
Fri, 23 Mar 2012 16:16:56 +0100
branchdevel
changeset 241 546316b0b09c
parent 236 63662db5ff25
child 245 4526747a42ca
permissions -rw-r--r--
moving DummyObserver and DummyPool -> iro.test_helpers.utils DBTestCase now using DummyObserver out of the box
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
216
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
     1
from twisted.internet.defer import inlineCallbacks
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
     2
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
     3
from datetime import datetime
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
     4
from decimal import Decimal 
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
     5
from mock import patch, Mock
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
     6
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
     7
from iro.model.job import exJobs
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
     8
from iro.model.pool import data
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
     9
from iro.model.schema import User, Offer as DBOffer, Userright
218
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
    10
from iro.model.message import SMS, Mail
216
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    11
from iro.model import offer
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    12
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    13
from iro.controller.task import Task, taskPool
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    14
from iro.telnumber import Telnumber
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    15
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    16
from iro.offer import Smstrade, SMTP, Offer
218
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
    17
from iro.offer.smstrade import SmstradeException, StatusCode
216
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    18
231
3929338fd17f moving tests -> iro.tests
Sandro Knauß <knauss@netzguerilla.net>
parents: 218
diff changeset
    19
from ..test_helpers.dbtestcase import DBTestCase
241
546316b0b09c moving DummyObserver and DummyPool -> iro.test_helpers.utils
Sandro Knauß <knauss@netzguerilla.net>
parents: 236
diff changeset
    20
from ..test_helpers.utils import DummyPool
216
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    21
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    22
def run( f,*a,**k):
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    23
    return f(*a,**k)
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    24
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    25
class IntegratedOfferTests(DBTestCase):
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    26
    def setUp(self):
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    27
        DBTestCase.setUp(self)
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    28
        self.pool = data.pool
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    29
        data.pool = DummyPool()
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    30
        
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    31
        self.taskPool = taskPool.run
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    32
        taskPool.run = run 
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    33
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    34
    def tearDown(self):
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    35
        exJobs.clear()
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    36
        data.pool = self.pool
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    37
        self.pool = None
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    38
        taskPool.run = self.taskPool
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    39
        self.taskPool = None
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    40
        DBTestCase.tearDown(self)
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    41
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    42
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    43
    @patch("iro.model.job.datetime")
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    44
    @patch("urllib.urlopen")
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    45
    @inlineCallbacks
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    46
    def testSmstrade(self, p_u, p_dt):
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    47
        f = Mock()
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    48
        f.readlines.return_value = ["100","12345678","0.055","1"]
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    49
        p_u.return_value = f
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    50
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    51
        p_dt.today.return_value = datetime(2000, 1, 2, 3, 4, 5)
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    52
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    53
        with self.session() as session:
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    54
            u = User(name='test',apikey='abcdef123456789')
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    55
            session.add(u)
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    56
            o=DBOffer(name="s", provider="bla", route="basic", typ="sms")
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    57
            u.rights.append(Userright(o))
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    58
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    59
        
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    60
        offer.providers["bla"] = Smstrade("bla")
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    61
        offer.providers["bla"].key = "XXXXXX"
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    62
        offer.offers["s"] = Offer("s",offer.providers["bla"],"basic","sms")
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    63
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    64
        j = yield exJobs.create(u,[Telnumber("0123456789")],SMS("bla"),['s'],'tesched')
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    65
        t = Task(Telnumber("0123456789"),j)
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    66
        yield t.start()
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    67
218
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
    68
        self.assertEqual(self.log.e[0]['message'], ("Job(%s) to '0049123456789' ended sucecessfully via bla:basic."%j.dbjob,))
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
    69
        
216
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    70
        with self.session() as session:
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    71
            u = session.merge(u)
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    72
            o = session.merge(o)
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    73
            job = u.job(j.dbjob)
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    74
            self.assertEqual(job.status,"sended")
218
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
    75
            self.assertEqual(job.info,"tesched")
216
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    76
            self.assertEqual(len(job.messages),1)
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    77
            
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    78
            msg = job.messages[0]
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    79
            self.assertEqual(msg.price,Decimal('0.0550'))
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    80
            self.assertEqual(msg.isBilled,False)
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    81
            self.assertEqual(msg.recipient,str(Telnumber('123456789')))
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    82
            self.assertEqual(msg.date,datetime(2000, 1, 2, 3, 4, 5))
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    83
            self.assertEqual(msg.offer,o)
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    84
            self.assertEqual(msg.exID,"12345678")
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    85
            self.assertEqual(msg.count,1)
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    86
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    87
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    88
    @patch("urllib.urlopen")
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    89
    @inlineCallbacks
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    90
    def testSmstradeException(self, mock_urlopen):
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    91
        f = Mock()
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    92
        f.readlines.return_value = ["703"]
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    93
        mock_urlopen.return_value = f
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    94
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    95
        with self.session() as session:
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    96
            u = User(name='test',apikey='abcdef123456789')
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    97
            session.add(u)
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    98
            o=DBOffer(name="s", provider="bla", route="basic", typ="sms")
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
    99
            u.rights.append(Userright(o)) 
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
   100
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
   101
        offer.providers["bla"] = Smstrade("bla")
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
   102
        offer.providers["bla"].key = "XXXXXX"
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
   103
        offer.offers["s"] = Offer("s",offer.providers["bla"],"basic","sms")
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
   104
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
   105
        j = yield exJobs.create(u,[Telnumber("0123456789")],SMS("bla"),['s'],'tesched')
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
   106
        t = Task(Telnumber("0123456789"),j)
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
   107
        yield t.start()
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
   108
218
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   109
        errors = self.flushLoggedErrors(SmstradeException)
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   110
        self.assertEqual(len(errors), 1)
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   111
        self.assertEqual(self.log.e[0]['why'], "Error: Job(%s) to '0049123456789' failed."%j.dbjob)
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   112
        
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   113
        self.assertEqual(t.error, True)
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   114
        self.assertEqual(str(t.status.value),str(SmstradeException(StatusCode(703))))
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   115
        
216
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
   116
        with self.session() as session:
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
   117
            u = session.merge(u)
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
   118
            o = session.merge(o)
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
   119
            job = u.job(j.dbjob)
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
   120
            self.assertEqual(job.status,"error")
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
   121
            self.assertEqual(len(job.messages),0)
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
   122
218
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   123
    @patch("smtplib.SMTP")
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   124
    @inlineCallbacks
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   125
    def testSmtp(self, p_s ):
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   126
        with self.session() as session:
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   127
            u = User(name='test',apikey='abcdef123456789')
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   128
            session.add(u)
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   129
            o=DBOffer(name="s", provider="bla", route=None, typ="mail")
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   130
            u.rights.append(Userright(o)) 
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   131
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   132
        offer.providers["bla"] = SMTP("bla")
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   133
        offer.providers["bla"].SSL = False
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   134
        offer.providers["bla"].TLS = False
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   135
        offer.providers["bla"].host = "localhost"
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   136
        offer.providers["bla"].port = 12345
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   137
        offer.providers["bla"].user = ""
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   138
        offer.providers["bla"].send_from = "frm@test.de"
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   139
        offer.offers["s"] = Offer("s",offer.providers["bla"],None,"mail")
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   140
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   141
        j = yield exJobs.create(u,["t@test.de"],Mail("bla",'msg',None),['s'],'tesched')
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   142
        t = Task("t@test.de",j)
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   143
        yield t.start()
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   144
        
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   145
        self.assertEqual(self.log.e[0]['message'], ("Job(%s) to 't@test.de' ended sucecessfully via bla:None."%j.dbjob,))
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   146
        
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   147
        with self.session() as session:
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   148
            u = session.merge(u)
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   149
            o = session.merge(o)
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   150
            job = u.job(j.dbjob)
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   151
            self.assertEqual(job.status,"sended")
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   152
            self.assertEqual(job.info,"tesched")
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   153
            self.assertEqual(len(job.messages),0)
216
ab8e2f26718e tests for Task.start -> ExJob->setError/setStatus
Sandro Knauß <knauss@netzguerilla.net>
parents:
diff changeset
   154
    
218
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   155
    @patch("smtplib.SMTP")
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   156
    @inlineCallbacks
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   157
    def testSmtpException(self, p_s):
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   158
        p_s.side_effect = IOError(111,"Connection refused")
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   159
        with self.session() as session:
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   160
            u = User(name='test',apikey='abcdef123456789')
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   161
            session.add(u)
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   162
            o=DBOffer(name="s", provider="bla", route=None, typ="mail")
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   163
            u.rights.append(Userright(o)) 
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   164
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   165
        offer.providers["bla"] = SMTP("bla")
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   166
        offer.providers["bla"].SSL = False
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   167
        offer.providers["bla"].TLS = False
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   168
        offer.providers["bla"].host = "localhost"
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   169
        offer.providers["bla"].port = 12345
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   170
        offer.providers["bla"].user = ""
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   171
        offer.providers["bla"].send_from = "frm@test.de"
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   172
        offer.offers["s"] = Offer("s",offer.providers["bla"],None,"mail")
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   173
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   174
        j = yield exJobs.create(u,["t@test.de"],Mail("bla",'msg',None),['s'],'tesched')
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   175
        t = Task("t@test.de",j)
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   176
        yield t.start()
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   177
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   178
        errors = self.flushLoggedErrors(IOError)
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   179
        self.assertEqual(len(errors), 1)
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   180
        self.assertEqual(self.log.e[0]['why'], "Error: Job(%s) to 't@test.de' failed."%j.dbjob
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   181
)
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   182
        self.assertEqual(t.error, True)
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   183
        self.assertEqual(str(t.status.value),str(IOError(111,"Connection refused")))
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   184
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   185
        with self.session() as session:
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   186
            u = session.merge(u)
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   187
            o = session.merge(o)
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   188
            job = u.job(j.dbjob)
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   189
            self.assertEqual(job.status,"error")
91f87ad13540 integration tests for smtp
Sandro Knauß <knauss@netzguerilla.net>
parents: 216
diff changeset
   190
            self.assertEqual(len(job.messages),0)
236
63662db5ff25 tests for utf-8 have to be created
Sandro Knauß <knauss@netzguerilla.net>
parents: 231
diff changeset
   191
       
63662db5ff25 tests for utf-8 have to be created
Sandro Knauß <knauss@netzguerilla.net>
parents: 231
diff changeset
   192
    def testUnicode(self):
63662db5ff25 tests for utf-8 have to be created
Sandro Knauß <knauss@netzguerilla.net>
parents: 231
diff changeset
   193
        '''tests unicode spefiica'''
63662db5ff25 tests for utf-8 have to be created
Sandro Knauß <knauss@netzguerilla.net>
parents: 231
diff changeset
   194
        pass
63662db5ff25 tests for utf-8 have to be created
Sandro Knauß <knauss@netzguerilla.net>
parents: 231
diff changeset
   195
    testUnicode.todo="to implement"