1 #! /usr/bin/env python -u
3 # This file is part of DisOrder.
4 # Copyright (C) 2007, 2008 Richard Kettlewell
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.
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.
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
21 import dtest,time,disorder,re
24 """Play some tracks"""
27 dtest.rescan() # ensure all files are scanned
30 assert c.random_enabled() == False
31 track = u"%s/Joe Bloggs/First Album/02:Second track.ogg" % dtest.tracks
32 print " adding track to queue"
34 assert c.enabled() == False
36 print " checking track turned up in queue"
38 ts = filter(lambda t: t['track'] == track and 'submitter' in t, q)
39 assert len(ts) == 1, "checking track appears exactly once in queue"
41 assert t['submitter'] == u'fred', "check queue submitter"
43 print " waiting for track"
45 assert c.enabled() == True
49 while not((p is not None and p['id'] == i)
50 or (len(filter(lambda t: t['track'] == track
51 and 'submitter' in t, r)) > 0)) and limit > 0:
56 assert limit > 0, "check track did complete in a reasonable time"
57 print " checking track turned up in recent list"
58 while (p is not None and p['id'] == i):
62 ts = filter(lambda t: t['track'] == track and 'submitter' in t, r)
63 assert len(ts) == 1, "check track appears exactly once in recent"
65 assert t['submitter'] == u'fred', "check recent entry submitter"
67 print " testing scratches"
71 print " starting a track"
76 print " track played too quickly, trying again..."
78 print " scratching track"
81 print " waiting for track to finish"
84 while (p is not None and p['id'] == i) and limit > 0:
88 assert limit > 0, "check track finishes in a reasonable period"
89 print " checking scratched track turned up in recent list"
91 ts = filter(lambda t: t['id'] == i, r)
92 assert len(ts) == 1, "check scratched track appears exactly once in recent"
93 if ts[0]['state'] == 'ok':
94 print " track played too quickly, trying again..."
96 assert ts[0]['state'] == 'scratched', "checking track scratched"
98 print " waiting for scratch to complete"
103 assert p is None, "checking nothing is playing"
104 assert c.enabled() == True
106 assert c.random_enabled() == True
108 if __name__ == '__main__':