~unity-2d-team/unity-2d/Shell-MultiMonitor

« back to all changes in this revision

Viewing changes to grackle/tests/test_model.py

  • Committer: William Grant
  • Date: 2012-01-22 10:39:15 UTC
  • Revision ID: william.grant@canonical.com-20120122103915-lqjw4jsaw3ug1q2g
Merge grackle.server into grackle. Alter Makefile to run all the tests.

Show diffs side-by-side

added added

removed removed

Lines of Context:
17
17
__metaclass__ = type
18
18
 
19
19
import datetime
20
 
from email.utils import formatdate
21
20
import os
22
21
from tempfile import _RandomNameSequence
23
22
import time
27
26
    tzoffset,
28
27
    tzutc,
29
28
    )
 
29
import fixtures
30
30
from pycassa.util import convert_uuid_to_time
31
31
 
32
32
from grackle.model import (
35
35
    )
36
36
 
37
37
 
38
 
TEMPLATE_MESSAGE = """\
 
38
TEST_MESSAGE = """\
39
39
From: sysadmin@example.com
40
40
To: developer@example.com
41
41
Subject: Everything is broken
42
 
Date: {date}
43
 
Message-Id: {id}
 
42
Date: Sat, 1 Jan 2000 11:02:34 +1100
 
43
Message-Id: <aaaaaaaaaaaaa@example.com>
44
44
 
45
45
Help, everything has just broken.
46
46
"""
47
47
 
48
 
TEST_MESSAGE = TEMPLATE_MESSAGE.format(
49
 
    date='Sat, 1 Jan 2000 11:02:34 +1100',
50
 
    id='<aaaaaaaaaaaaa@example.com>')
51
 
 
52
48
 
53
49
class TestParseMessage(unittest.TestCase):
54
50
 
67
63
            date)
68
64
 
69
65
 
70
 
class TestAddMessage(unittest.TestCase):
 
66
class TestCassandra(fixtures.TestWithFixtures):
71
67
 
72
68
    def test_add_message(self):
73
69
        c = CassandraConnection(
74
70
            os.environ['GRACKLE_TEST_KEYSPACE'], ['localhost:9160'])
 
71
 
75
72
        archive = next(_RandomNameSequence())
76
73
 
77
74
        # Write the message out to Cassandra, and read it back in.
85
82
        self.assertEqual(key, archive_messages[0][1])
86
83
 
87
84
        # The key in archive_message is a TimeUUID for the Date field in
88
 
        # the message. There is no UTC equivalent of time.mktime, so we
89
 
        # must subtract the offset.
 
85
        # the message.
90
86
        utctime = time.mktime(datetime.datetime(
91
 
            2000, 1, 1, 0, 2, 34, tzinfo=tzutc()).timetuple()) - time.timezone
 
87
            2000, 1, 1, 0, 2, 34, tzinfo=tzutc()).timetuple())
92
88
        self.assertEqual(
93
89
            utctime,
94
90
            convert_uuid_to_time(archive_messages[0][0]))
99
95
        parsed_message = _parse_message(TEST_MESSAGE)[1]
100
96
        for key, value in parsed_message.iteritems():
101
97
            self.assertEqual(value, cmsg[key])
102
 
 
103
 
 
104
 
class TestGetMessages(unittest.TestCase):
105
 
 
106
 
    def assertMessages(self, expected_ids, messages):
107
 
        expected_msgids = [
108
 
            '<message%d@example.com>' % id for id in expected_ids]
109
 
        actual_msgids = [msg['message-id'] for msg in messages]
110
 
        self.assertEqual(expected_msgids, actual_msgids)
111
 
 
112
 
    def makeMessages(self, conn, archive, count):
113
 
        return [
114
 
            conn.add_message(
115
 
                archive,
116
 
                TEMPLATE_MESSAGE.format(
117
 
                    date=formatdate(i * 100),
118
 
                    id='<message%d@example.com>' % i))
119
 
            for i in range(count)]
120
 
 
121
 
    def makeArchive(self):
122
 
        conn = CassandraConnection(
123
 
            os.environ['GRACKLE_TEST_KEYSPACE'], ['localhost:9160'])
124
 
        archive = next(_RandomNameSequence())
125
 
        return conn, archive
126
 
 
127
 
    def test_single_message(self):
128
 
        conn, archive = self.makeArchive()
129
 
        self.makeMessages(conn, archive, 1)
130
 
        messages = conn.get_messages(archive, 'date', 1, '')[1]
131
 
        self.assertMessages([0], messages)
132
 
        cmsg = messages[0]
133
 
        expected_content = TEMPLATE_MESSAGE.format(
134
 
            date=formatdate(0), id='<message0@example.com>')
135
 
        self.assertEqual(expected_content, messages[0]['content'])
136
 
        pmsg = _parse_message(expected_content)[1]
137
 
        self.assertEqual(pmsg['date'], cmsg['date'])
138
 
        self.assertEqual(pmsg['from'], cmsg['from'])
139
 
        self.assertEqual(pmsg['subject'], cmsg['subject'])
140
 
        self.assertEqual(pmsg['message-id'], cmsg['message-id'])
141
 
 
142
 
    def test_limit(self):
143
 
        conn, archive = self.makeArchive()
144
 
        self.makeMessages(conn, archive, 4)
145
 
        self.assertMessages(
146
 
            [0, 1], conn.get_messages(archive, 'date', 2, '')[1])
147
 
 
148
 
    def test_order(self):
149
 
        conn, archive = self.makeArchive()
150
 
        self.makeMessages(conn, archive, 4)
151
 
        self.assertMessages(
152
 
            [3, 2], conn.get_messages(archive, '-date', 2, '')[1])
153
 
 
154
 
    def test_batching_forward(self):
155
 
        conn, archive = self.makeArchive()
156
 
        self.makeMessages(conn, archive, 5)
157
 
        prev, messages, next = conn.get_messages(archive, 'date', 2, '')
158
 
        self.assertMessages([0, 1], messages)
159
 
        prev, messages, next = conn.get_messages(archive, 'date', 2, next)
160
 
        self.assertMessages([2, 3], messages)
161
 
        prev, messages, next = conn.get_messages(archive, 'date', 2, next)
162
 
        self.assertMessages([4], messages)
163
 
        prev, messages, next = conn.get_messages(archive, 'date', 2, next)
164
 
        self.assertIs(None, prev)
165
 
        self.assertMessages([], messages)
166
 
        self.assertIs(None, next)
167
 
 
168
 
    def test_batching_backward(self):
169
 
        conn, archive = self.makeArchive()
170
 
        self.makeMessages(conn, archive, 5)
171
 
        prev, messages, next = conn.get_messages(archive, 'date', 2, '')
172
 
        self.assertMessages([0, 1], messages)
173
 
        prev, messages, next = conn.get_messages(archive, 'date', 2, next)
174
 
        self.assertMessages([2, 3], messages)
175
 
        prev, messages, next = conn.get_messages(
176
 
            archive, 'date', 2, prev, backward=True)
177
 
        self.assertMessages([0, 1], messages)
178
 
        prev, messages, next = conn.get_messages(
179
 
            archive, 'date', 2, prev, backward=True)
180
 
        self.assertIs(None, prev)
181
 
        self.assertMessages([], messages)
182
 
        self.assertIs(None, next)
183
 
 
184
 
    def test_date_filter(self):
185
 
        conn, archive = self.makeArchive()
186
 
        self.makeMessages(conn, archive, 10)
187
 
        start = datetime.datetime.utcfromtimestamp(250).replace(
188
 
            tzinfo=tzutc())
189
 
        finish = datetime.datetime.utcfromtimestamp(500).replace(
190
 
            tzinfo=tzutc())
191
 
        prev, messages, next = conn.get_messages(
192
 
            archive, 'date', 2, '', start_date=start, finish_date=finish)
193
 
        self.assertMessages([3, 4], messages)
194
 
        prev, messages, next = conn.get_messages(
195
 
            archive, 'date', 2, next, start_date=start, finish_date=finish)
196
 
        self.assertMessages([5], messages)