chiark / gitweb /
disorder-udplog exits more reliably when parent dies
[disorder] / tests / play.py
... / ...
CommitLineData
1#! /usr/bin/env python
2#
3# This file is part of DisOrder.
4# Copyright (C) 2007 Richard Kettlewell
5#
6# This program is free software; you can redistribute it and/or modify
7# it under the terms of the GNU General Public License as published by
8# the Free Software Foundation; either version 2 of the License, or
9# (at your option) any later version.
10#
11# This program is distributed in the hope that it will be useful, but
12# WITHOUT ANY WARRANTY; without even the implied warranty of
13# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14# General Public License for more details.
15#
16# You should have received a copy of the GNU General Public License
17# along with this program; if not, write to the Free Software
18# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
19# USA
20#
21import dtest,time,disorder,re
22
23def test():
24 """Play some tracks"""
25 dtest.start_daemon()
26 c = disorder.client()
27 track = u"%s/Joe Bloggs/First Album/02:Second track.ogg" % dtest.tracks
28 print "adding track to queue"
29 c.play(track)
30 print " checking track turned up in queue"
31 q = c.queue()
32 ts = filter(lambda t: t['track'] == track and 'submitter' in t, q)
33 assert len(ts) == 1, "checking track appears exactly once in queue"
34 t = ts[0]
35 assert t['submitter'] == u'fred', "check queue submitter"
36 i = t['id']
37 print " waiting for track"
38 p = c.playing()
39 r = c.recent()
40 while not((p is not None and p['id'] == i)
41 or (len(filter(lambda t: t['track'] == track and 'submitter' in t, r)) > 0)):
42 time.sleep(1)
43 p = c.playing()
44 r = c.recent()
45 print " checking track turned up in recent list"
46 while (p is not None and p['id'] == i):
47 time.sleep(1)
48 p = c.playing()
49 r = c.recent()
50 ts = filter(lambda t: t['track'] == track and 'submitter' in t, r)
51 assert len(ts) == 1, "check track appears exactly once in recent"
52 t = ts[0]
53 assert t['submitter'] == u'fred', "check recent entry submitter"
54 print " disabling play"
55 c.disable()
56 print " scratching current track"
57 p = c.playing()
58 i = p['id']
59 c.scratch(i)
60 print " checking scratched track turned up in recent list"
61 while (p is not None and p['id'] == i):
62 time.sleep(1)
63 p = c.playing()
64 r = c.recent()
65 ts = filter(lambda t: t['id'] == i, r)
66 assert len(ts) == 1, "check scratched track appears exactly once in recent"
67 assert ts[0]['state'] == 'scratched', "checking track scratched"
68 print " waiting for scratch to complete"
69 while (p is not None and p['state'] == 'isscratch'):
70 time.sleep(1)
71 p = c.playing()
72 assert p is None, "checking nothing is playing"
73
74if __name__ == '__main__':
75 dtest.run()