~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.
98
95
        parsed_message = _parse_message(TEST_MESSAGE)[1]
99
96
        for key, value in parsed_message.iteritems():
100
97
            self.assertEqual(value, cmsg[key])
101
 
 
102
 
 
103
 
class TestGetMessages(unittest.TestCase):
104
 
 
105
 
    def assertMessages(self, expected_ids, messages):
106
 
        expected_msgids = [
107
 
            '<message%d@example.com>' % id for id in expected_ids]
108
 
        actual_msgids = [msg['message-id'] for msg in messages]
109
 
        self.assertEqual(expected_msgids, actual_msgids)
110
 
 
111
 
    def makeMessages(self, conn, archive, count):
112
 
        return [
113
 
            conn.add_message(
114
 
                archive,
115
 
                TEMPLATE_MESSAGE.format(
116
 
                    date=formatdate(i * 100),
117
 
                    id='<message%d@example.com>' % i))
118
 
            for i in range(count)]
119
 
 
120
 
    def makeArchive(self):
121
 
        conn = CassandraConnection(
122
 
            os.environ['GRACKLE_TEST_KEYSPACE'], ['localhost:9160'])
123
 
        archive = next(_RandomNameSequence())
124
 
        return conn, archive
125
 
 
126
 
    def test_single_message(self):
127
 
        conn, archive = self.makeArchive()
128
 
        self.makeMessages(conn, archive, 1)
129
 
        self.assertMessages(
130
 
            [0], conn.get_messages(archive, 'date', 1, '')[1])
131
 
 
132
 
    def test_limit(self):
133
 
        conn, archive = self.makeArchive()
134
 
        self.makeMessages(conn, archive, 4)
135
 
        self.assertMessages(
136
 
            [0, 1], conn.get_messages(archive, 'date', 2, '')[1])
137
 
 
138
 
    def test_order(self):
139
 
        conn, archive = self.makeArchive()
140
 
        self.makeMessages(conn, archive, 4)
141
 
        self.assertMessages(
142
 
            [3, 2], conn.get_messages(archive, '-date', 2, '')[1])
143
 
 
144
 
    def test_batching_forward(self):
145
 
        conn, archive = self.makeArchive()
146
 
        self.makeMessages(conn, archive, 5)
147
 
        prev, messages, next = conn.get_messages(archive, 'date', 2, '')
148
 
        self.assertMessages([0, 1], messages)
149
 
        prev, messages, next = conn.get_messages(archive, 'date', 2, next)
150
 
        self.assertMessages([2, 3], messages)
151
 
        prev, messages, next = conn.get_messages(archive, 'date', 2, next)
152
 
        self.assertMessages([4], messages)
153
 
        prev, messages, next = conn.get_messages(archive, 'date', 2, next)
154
 
        self.assertIs(None, prev)
155
 
        self.assertMessages([], messages)
156
 
        self.assertIs(None, next)
157
 
 
158
 
    def test_batching_backward(self):
159
 
        conn, archive = self.makeArchive()
160
 
        self.makeMessages(conn, archive, 5)
161
 
        prev, messages, next = conn.get_messages(archive, 'date', 2, '')
162
 
        self.assertMessages([0, 1], messages)
163
 
        prev, messages, next = conn.get_messages(archive, 'date', 2, next)
164
 
        self.assertMessages([2, 3], messages)
165
 
        prev, messages, next = conn.get_messages(
166
 
            archive, 'date', 2, prev, backward=True)
167
 
        self.assertMessages([0, 1], messages)
168
 
        prev, messages, next = conn.get_messages(
169
 
            archive, 'date', 2, prev, backward=True)
170
 
        self.assertIs(None, prev)
171
 
        self.assertMessages([], messages)
172
 
        self.assertIs(None, next)