[Telepathy-commits] [telepathy-gabble/master] Added a test to make sure aliases are saved to the roster on updating.

Jonny Lamb jonny.lamb at collabora.co.uk
Fri Sep 19 08:25:05 PDT 2008


Signed-off-by: Jonny Lamb <jonny.lamb at collabora.co.uk>
---
 tests/twisted/Makefile.am                         |    1 +
 tests/twisted/roster/test-save-alias-to-roster.py |   76 +++++++++++++++++++++
 2 files changed, 77 insertions(+), 0 deletions(-)
 create mode 100644 tests/twisted/roster/test-save-alias-to-roster.py

diff --git a/tests/twisted/Makefile.am b/tests/twisted/Makefile.am
index 5bdffe6..f65cf0b 100644
--- a/tests/twisted/Makefile.am
+++ b/tests/twisted/Makefile.am
@@ -15,6 +15,7 @@ TWISTED_TESTS = \
 	roster/test-google-roster.py \
 	roster/test-roster.py \
 	roster/test-roster-subscribe.py \
+	roster/test-save-alias-to-roster.py \
 	text/initiate.py \
 	text/initiate-requestotron.py \
 	text/respawn.py \
diff --git a/tests/twisted/roster/test-save-alias-to-roster.py b/tests/twisted/roster/test-save-alias-to-roster.py
new file mode 100644
index 0000000..34e0c85
--- /dev/null
+++ b/tests/twisted/roster/test-save-alias-to-roster.py
@@ -0,0 +1,76 @@
+
+"""
+Test that updating an alias saves it to the roster.
+"""
+
+import dbus
+
+from servicetest import EventPattern, call_async
+from gabbletest import acknowledge_iq, exec_test, make_result_iq
+
+def test(q, bus, conn, stream):
+    conn.Connect()
+    _, event, event2 = q.expect_many(
+        EventPattern('dbus-signal', signal='StatusChanged', args=[0, 1]),
+        EventPattern('stream-iq', to=None, query_ns='vcard-temp',
+            query_name='vCard'),
+        EventPattern('stream-iq', query_ns='jabber:iq:roster'))
+
+    acknowledge_iq(stream, event.stanza)
+    acknowledge_iq(stream, event2.stanza)
+
+    while True:
+        event = q.expect('dbus-signal', signal='NewChannel')
+        path, type, handle_type, handle, suppress_handler = event.args
+
+        if type != u'org.freedesktop.Telepathy.Channel.Type.ContactList':
+            continue
+
+        chan_name = conn.InspectHandles(handle_type, [handle])[0]
+
+        if chan_name == 'subscribe':
+            break
+
+    # request subscription
+    chan = bus.get_object(conn.bus_name, path)
+    group_iface = dbus.Interface(chan,
+        u'org.freedesktop.Telepathy.Channel.Interface.Group')
+    assert group_iface.GetMembers() == []
+    handle = conn.RequestHandles(1, ['bob at foo.com'])[0]
+    group_iface.AddMembers([handle], '')
+
+    event = q.expect('stream-iq', iq_type='set', query_ns='jabber:iq:roster')
+    item = event.query.firstChildElement()
+
+    acknowledge_iq(stream, event.stanza)
+
+    call_async(q, conn.Aliasing, 'RequestAliases', [handle])
+
+    event = q.expect('stream-iq', iq_type='get',
+        query_ns='http://jabber.org/protocol/pubsub',
+        to='bob at foo.com')
+
+    result = make_result_iq(stream, event.stanza)
+    pubsub = result.firstChildElement()
+    items = pubsub.addElement('items')
+    items['node'] = 'http://jabber.org/protocol/nick'
+    item = items.addElement('item')
+    item.addElement('nick', 'http://jabber.org/protocol/nick',
+        content='Bobby')
+    stream.send(result)
+
+    event = q.expect('stream-iq', iq_type='set', query_ns='jabber:iq:roster')
+    item = event.query.firstChildElement()
+    assert item['jid'] == 'bob at foo.com'
+    assert item['name'] == 'Bobby'
+
+    q.expect('dbus-return', method='RequestAliases',
+        value=(['Bobby'],))
+
+    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