summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSimon McVittie <simon.mcvittie@collabora.co.uk>2013-09-24 19:26:00 +0100
committerSimon McVittie <simon.mcvittie@collabora.co.uk>2013-09-24 19:26:00 +0100
commitf9963519c30820e1369705ddd36f9e5a004c215e (patch)
tree1ebe7b3bb3d75eac5a835eb97e834b14f4e5ad1f
parent7cc1f0b1d03fd5ea7619322b89da62c429375c09 (diff)
downloadtelepathy-haze-f9963519c30820e1369705ddd36f9e5a004c215e.tar.gz
Text tests: migrate to the unified Text interface in spec 0.99.1
-rw-r--r--tests/twisted/text/destroy.py37
-rw-r--r--tests/twisted/text/respawn.py50
-rw-r--r--tests/twisted/text/test-text-delayed.py9
-rw-r--r--tests/twisted/text/test-text.py41
4 files changed, 55 insertions, 82 deletions
diff --git a/tests/twisted/text/destroy.py b/tests/twisted/text/destroy.py
index bb31c8f..c6edcff 100644
--- a/tests/twisted/text/destroy.py
+++ b/tests/twisted/text/destroy.py
@@ -56,7 +56,10 @@ def test(q, bus, conn, stream):
assert channel_props['InitiatorID'] == 'test@localhost',\
channel_props['InitiatorID']
- text_iface.Send(0, 'hey')
+ text_iface.SendMessage([{}, {
+ 'content-type': 'text/plain',
+ 'content': 'hey',
+ }], 0)
event = q.expect('stream-message')
@@ -79,23 +82,21 @@ def test(q, bus, conn, stream):
m.addElement('body', content='hello')
stream.send(m)
- event = q.expect('dbus-signal', signal='Received')
-
- hello_message_id = event.args[0]
- hello_message_time = event.args[1]
- assert event.args[2] == foo_handle
- # message type: normal
- assert event.args[3] == 0
- # flags: none
- assert event.args[4] == 0
- # body
- assert event.args[5] == 'hello'
-
- messages = text_chan.ListPendingMessages(False,
- dbus_interface=cs.CHANNEL_TYPE_TEXT)
- assert messages == \
- [(hello_message_id, hello_message_time, foo_handle,
- 0, 0, 'hello')], messages
+ event = q.expect('dbus-signal', signal='MessageReceived')
+
+ message = event.args[0]
+ assertLength(2, message)
+ hello_message_id = message[0]['pending-message-id']
+ assertEquals(foo_handle, message[0]['message-sender'])
+ assertEquals('foo@bar.com', message[0]['message-sender-id'])
+ assertEquals(cs.MT_NORMAL,
+ message[0].get('message-type', cs.MT_NORMAL))
+ assertEquals('text/plain', message[1]['content-type'])
+ assertEquals('hello', message[1]['content'])
+
+ messages = text_chan.Get(cs.CHANNEL_TYPE_TEXT, 'PendingMessages',
+ dbus_interface=cs.PROPERTIES_IFACE)
+ assertEquals([message], messages)
# destroy the channel without acking the message; it does not come back
diff --git a/tests/twisted/text/respawn.py b/tests/twisted/text/respawn.py
index 170c331..cdc9105 100644
--- a/tests/twisted/text/respawn.py
+++ b/tests/twisted/text/respawn.py
@@ -54,7 +54,10 @@ def test(q, bus, conn, stream):
assert channel_props['InitiatorID'] == 'test@localhost',\
channel_props['InitiatorID']
- text_iface.Send(0, 'hey')
+ text_iface.SendMessage([{}, {
+ 'content-type': 'text/plain',
+ 'content': 'hey',
+ }], 0)
event = q.expect('stream-message')
@@ -77,23 +80,21 @@ def test(q, bus, conn, stream):
m.addElement('body', content='hello')
stream.send(m)
- event = q.expect('dbus-signal', signal='Received')
+ event = q.expect('dbus-signal', signal='MessageReceived')
- hello_message_id = event.args[0]
- hello_message_time = event.args[1]
- assert event.args[2] == foo_handle
- # message type: normal
- assert event.args[3] == 0
- # flags: none
- assert event.args[4] == 0
- # body
- assert event.args[5] == 'hello'
+ message = event.args[0]
+ assertLength(2, message)
+ hello_message_id = message[0]['pending-message-id']
+ assertEquals(foo_handle, message[0]['message-sender'])
+ assertEquals('foo@bar.com', message[0]['message-sender-id'])
+ assertEquals(cs.MT_NORMAL,
+ message[0].get('message-type', cs.MT_NORMAL))
+ assertEquals('text/plain', message[1]['content-type'])
+ assertEquals('hello', message[1]['content'])
- messages = text_chan.ListPendingMessages(False,
- dbus_interface=cs.CHANNEL_TYPE_TEXT)
- assert messages == \
- [(hello_message_id, hello_message_time, foo_handle,
- 0, 0, 'hello')], messages
+ messages = text_chan.Get(cs.CHANNEL_TYPE_TEXT, 'PendingMessages',
+ dbus_interface=cs.PROPERTIES_IFACE)
+ assertEquals([message], messages)
# close the channel without acking the message; it comes back
@@ -130,22 +131,21 @@ def test(q, bus, conn, stream):
assert channel_props['InitiatorID'] == 'foo@bar.com',\
channel_props['InitiatorID']
- # the message is still there
+ # the message is still there, but is marked as rescued now
+ message[0]['rescued'] = True
- messages = text_chan.ListPendingMessages(False,
- dbus_interface=cs.CHANNEL_TYPE_TEXT)
- assert messages == \
- [(hello_message_id, hello_message_time, foo_handle,
- 0, 8, 'hello')], messages
+ messages = text_chan.Get(cs.CHANNEL_TYPE_TEXT, 'PendingMessages',
+ dbus_interface=cs.PROPERTIES_IFACE)
+ assertEquals([message], messages)
# acknowledge it
text_chan.AcknowledgePendingMessages([hello_message_id],
dbus_interface=cs.CHANNEL_TYPE_TEXT)
- messages = text_chan.ListPendingMessages(False,
- dbus_interface=cs.CHANNEL_TYPE_TEXT)
- assert messages == []
+ messages = text_chan.Get(cs.CHANNEL_TYPE_TEXT, 'PendingMessages',
+ dbus_interface=cs.PROPERTIES_IFACE)
+ assertEquals([], messages)
# close the channel again
diff --git a/tests/twisted/text/test-text-delayed.py b/tests/twisted/text/test-text-delayed.py
index c7e5740..59e73d0 100644
--- a/tests/twisted/text/test-text-delayed.py
+++ b/tests/twisted/text/test-text-delayed.py
@@ -28,14 +28,7 @@ def test(q, bus, conn, stream):
assertEquals(cs.HT_CONTACT, event.args[0][0][1][cs.TARGET_HANDLE_TYPE])
assertEquals('foo@bar.com', event.args[0][0][1][cs.TARGET_ID])
- 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_received = q.expect('dbus-signal', signal='MessageReceived')
message = message_received.args[0]
header = message[0]
diff --git a/tests/twisted/text/test-text.py b/tests/twisted/text/test-text.py
index 91ebb6a..0a33755 100644
--- a/tests/twisted/text/test-text.py
+++ b/tests/twisted/text/test-text.py
@@ -38,8 +38,6 @@ def test(q, bus, conn, stream):
assertEquals(cs.CHANNEL_TYPE_TEXT, channel_props.get('ChannelType'))
assertContains(cs.CHANNEL_IFACE_CHAT_STATE,
channel_props.get('Interfaces', ()))
- assertContains(cs.CHANNEL_IFACE_MESSAGES,
- channel_props.get('Interfaces', ()))
assert channel_props['TargetID'] == jid,\
(channel_props['TargetID'], jid)
assert channel_props['Requested'] == False
@@ -47,21 +45,8 @@ def test(q, bus, conn, stream):
assert channel_props['InitiatorID'] == jid,\
(channel_props['InitiatorID'], jid)
- received, message_received = q.expect_many(
- EventPattern('dbus-signal', signal='Received'),
- EventPattern('dbus-signal', signal='MessageReceived'),
- )
-
- # Check that C.T.Text.Received looks right
- # message type: normal
- assert received.args[3] == 0
- # flags: none
- assert received.args[4] == 0
- # body
- assert received.args[5] == 'hello'
+ message_received = q.expect('dbus-signal', signal='MessageReceived')
-
- # Check that C.I.Messages.MessageReceived looks right.
message = message_received.args[0]
# message should have two parts: the header and one content part
@@ -92,19 +77,18 @@ def test(q, bus, conn, stream):
# Send an action using the Messages API
# In Gabble, this is a Notice, but we don't support those.
greeting = [
- dbus.Dictionary({ 'message-type': 1, # Action
+ dbus.Dictionary({ 'message-type': cs.MT_ACTION,
}, signature='sv'),
{ 'content-type': 'text/plain',
'content': u"waves",
}
]
- dbus.Interface(text_chan, cs.CHANNEL_IFACE_MESSAGES
+ dbus.Interface(text_chan, cs.CHANNEL_TYPE_TEXT
).SendMessage(greeting, dbus.UInt32(0))
- stream_message, sent, message_sent = q.expect_many(
+ stream_message, message_sent = q.expect_many(
EventPattern('stream-message'),
- EventPattern('dbus-signal', signal='Sent'),
EventPattern('dbus-signal', signal='MessageSent'),
)
@@ -128,16 +112,15 @@ def test(q, bus, conn, stream):
assert body['content-type'] == 'text/plain', body
assert body['content'] == u'waves', body
- assert sent.args[1] == 1, sent.args # Action
- assert sent.args[2] == u'waves', sent.args
-
-
# Send a message using Channel.Type.Text API
- dbus.Interface(text_chan, cs.CHANNEL_TYPE_TEXT).Send(0, 'goodbye')
+ dbus.Interface(text_chan, cs.CHANNEL_TYPE_TEXT
+ ).SendMessage([{}, {
+ 'content-type': 'text/plain',
+ 'content': 'goodbye',
+ }], 0)
- stream_message, sent, message_sent = q.expect_many(
+ stream_message, message_sent = q.expect_many(
EventPattern('stream-message'),
- EventPattern('dbus-signal', signal='Sent'),
EventPattern('dbus-signal', signal='MessageSent'),
)
@@ -163,10 +146,6 @@ def test(q, bus, conn, stream):
assert body['content-type'] == 'text/plain', body
assert body['content'] == u'goodbye', body
- assert sent.args[1] == 0, sent.args # message type normal
- assert sent.args[2] == u'goodbye', sent.args
-
-
conn.Disconnect()
q.expect('dbus-signal', signal='StatusChanged', args=[2, 1])