summaryrefslogtreecommitdiff
path: root/src/mailman/queue/docs/runner.txt
blob: 8438f2576c670b2abb786599e83e719958596722 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
=============
Queue runners
=============

The queue runners (qrunner) are the processes that move messages around the
Mailman system.  Each qrunner is responsible for a slice of the hash space in
a queue directory.  It processes all the files in its slice, sleeps a little
while, then wakes up and runs through its queue files again.


Basic architecture
==================

The basic architecture of qrunner is implemented in the base class that all
runners inherit from.  This base class implements a .run() method that runs
continuously in a loop until the .stop() method is called.

    >>> mlist = create_list('_xtest@example.com')

Here is a very simple derived qrunner class.  Queue runners use a
configuration section in the configuration files to determine run
characteristics, such as the queue directory to use.  Here we push a
configuration section for the test runner.

    >>> config.push('test-runner', """
    ... [qrunner.test]
    ... max_restarts: 1
    ... """)

    >>> from mailman.queue import Runner
    >>> class TestableRunner(Runner):
    ...     def _dispose(self, mlist, msg, msgdata):
    ...         self.msg = msg
    ...         self.msgdata = msgdata
    ...         return False
    ...
    ...     def _do_periodic(self):
    ...         self.stop()
    ...
    ...     def _snooze(self, filecnt):
    ...         return

    >>> runner = TestableRunner('test')

This qrunner doesn't do much except run once, storing the message and metadata
on instance variables.

    >>> msg = message_from_string("""\
    ... From: aperson@example.com
    ... To: _xtest@example.com
    ...
    ... A test message.
    ... """)
    >>> switchboard = config.switchboards['test']
    >>> filebase = switchboard.enqueue(msg, listname=mlist.fqdn_listname,
    ...                                foo='yes', bar='no')
    >>> runner.run()
    >>> print runner.msg.as_string()
    From: aperson@example.com
    To: _xtest@example.com
    <BLANKLINE>
    A test message.
    <BLANKLINE>
    >>> dump_msgdata(runner.msgdata)
    _parsemsg: False
    bar      : no
    foo      : yes
    lang     : en
    listname : _xtest@example.com
    version  : 3

XXX More of the Runner API should be tested.