[Telepathy-commits] [telepathy-haze/master] Steal test-text-delayed.py from Gabble.

Will Thompson will.thompson at collabora.co.uk
Mon Mar 23 04:08:04 PDT 2009


---
 tests/twisted/Makefile.am               |    1 +
 tests/twisted/text/test-text-delayed.py |   60 +++++++++++++++++++++++++++++++
 2 files changed, 61 insertions(+), 0 deletions(-)
 create mode 100644 tests/twisted/text/test-text-delayed.py

diff --git a/tests/twisted/Makefile.am b/tests/twisted/Makefile.am
index 4d85717..21719d8 100644
--- a/tests/twisted/Makefile.am
+++ b/tests/twisted/Makefile.am
@@ -7,6 +7,7 @@ TWISTED_TESTS = \
 	text/initiate-requestotron.py \
 	text/initiate.py \
 	text/respawn.py \
+	text/test-text-delayed.py \
 	text/test-text-no-body.py \
 	text/test-text.py
 
diff --git a/tests/twisted/text/test-text-delayed.py b/tests/twisted/text/test-text-delayed.py
new file mode 100644
index 0000000..f2c1a94
--- /dev/null
+++ b/tests/twisted/text/test-text-delayed.py
@@ -0,0 +1,60 @@
+
+"""
+Test receiving delayed (offline) messages on a text channel.
+"""
+
+import datetime
+
+from twisted.words.xish import domish
+
+from hazetest import exec_test
+from servicetest import EventPattern
+
+def test(q, bus, conn, stream):
+    conn.Connect()
+    q.expect('dbus-signal', signal='StatusChanged', args=[0, 1])
+
+    m = domish.Element((None, 'message'))
+    m['from'] = 'foo at bar.com'
+    m['type'] = 'chat'
+    m.addElement('body', content='hello')
+
+    # add timestamp information
+    x = m.addElement(('jabber:x:delay', 'x'))
+    x['stamp'] = '20070517T16:15:01'
+
+    stream.send(m)
+
+    event = q.expect('dbus-signal', signal='NewChannel')
+    assert event.args[1] == u'org.freedesktop.Telepathy.Channel.Type.Text'
+    # check that handle type == contact handle
+    assert event.args[2] == 1
+    jid = conn.InspectHandles(1, [event.args[3]])[0]
+    assert jid == 'foo at bar.com'
+
+    received, message_received = q.expect_many(
+        EventPattern('dbus-signal', signal='Received'),
+        EventPattern('dbus-signal', signal='MessageReceived'),
+        )
+
+    old_signal_time = str(datetime.datetime.utcfromtimestamp(received.args[1]))
+    assert old_signal_time == '2007-05-17 16:15:01', old_signal_time
+    assert received.args[5] == 'hello'
+
+    message = message_received.args[0]
+    header = message[0]
+    message_sent_timestamp = header['message-sent']
+    new_signal_time = str(datetime.datetime.utcfromtimestamp(message_sent_timestamp))
+    assert new_signal_time == '2007-05-17 16:15:01', (headers, new_signal_time)
+    message_received_timestamp = header['message-received']
+    assert message_received_timestamp > message_sent_timestamp, headers
+
+    assert message[1]['content'] == 'hello', message
+
+
+    conn.Disconnect()
+    q.expect('dbus-signal', signal='StatusChanged', args=[2, 1])
+
+if __name__ == '__main__':
+    exec_test(test)
+
-- 
1.5.6.5



More information about the telepathy-commits mailing list