diff options
author | Simon McVittie <simon.mcvittie@collabora.co.uk> | 2013-09-24 19:26:00 +0100 |
---|---|---|
committer | Simon McVittie <simon.mcvittie@collabora.co.uk> | 2013-09-24 19:26:00 +0100 |
commit | f9963519c30820e1369705ddd36f9e5a004c215e (patch) | |
tree | 1ebe7b3bb3d75eac5a835eb97e834b14f4e5ad1f | |
parent | 7cc1f0b1d03fd5ea7619322b89da62c429375c09 (diff) | |
download | telepathy-haze-f9963519c30820e1369705ddd36f9e5a004c215e.tar.gz |
Text tests: migrate to the unified Text interface in spec 0.99.1
-rw-r--r-- | tests/twisted/text/destroy.py | 37 | ||||
-rw-r--r-- | tests/twisted/text/respawn.py | 50 | ||||
-rw-r--r-- | tests/twisted/text/test-text-delayed.py | 9 | ||||
-rw-r--r-- | tests/twisted/text/test-text.py | 41 |
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]) |