Commit | Line | Data |
---|---|---|
abf54aca | 1 | #! /usr/bin/env python |
f5eb2aff RK |
2 | # |
3 | # This file is part of DisOrder. | |
2b2a5fed | 4 | # Copyright (C) 2007, 2008 Richard Kettlewell |
f5eb2aff | 5 | # |
e7eb3a27 | 6 | # This program is free software: you can redistribute it and/or modify |
f5eb2aff | 7 | # it under the terms of the GNU General Public License as published by |
e7eb3a27 | 8 | # the Free Software Foundation, either version 3 of the License, or |
f5eb2aff RK |
9 | # (at your option) any later version. |
10 | # | |
e7eb3a27 RK |
11 | # This program is distributed in the hope that it will be useful, |
12 | # but WITHOUT ANY WARRANTY; without even the implied warranty of | |
13 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
14 | # GNU General Public License for more details. | |
15 | # | |
f5eb2aff | 16 | # You should have received a copy of the GNU General Public License |
e7eb3a27 | 17 | # along with this program. If not, see <http://www.gnu.org/licenses/>. |
f5eb2aff | 18 | # |
05438e89 | 19 | import dtest,time,disorder,re,sys |
f5eb2aff RK |
20 | |
21 | def test(): | |
22 | """Play some tracks""" | |
23 | dtest.start_daemon() | |
f0feb22e | 24 | dtest.create_user() |
56613a97 | 25 | dtest.rescan() # ensure all files are scanned |
f5eb2aff | 26 | c = disorder.client() |
2b2a5fed RK |
27 | c.random_disable() |
28 | assert c.random_enabled() == False | |
f5eb2aff | 29 | track = u"%s/Joe Bloggs/First Album/02:Second track.ogg" % dtest.tracks |
7a853280 RK |
30 | track2 = u"%s/Joe Bloggs/First Album/04:Fourth track.ogg" % dtest.tracks |
31 | track3 = u"%s/Joe Bloggs/First Album/05:Fifth track.ogg" % dtest.tracks | |
f0feb22e | 32 | print " adding track to queue" |
db86b8ed | 33 | c.disable() |
2b2a5fed | 34 | assert c.enabled() == False |
f5eb2aff | 35 | c.play(track) |
81e440ce | 36 | print " checking track turned up in queue" |
f5eb2aff RK |
37 | q = c.queue() |
38 | ts = filter(lambda t: t['track'] == track and 'submitter' in t, q) | |
6ce6b5a9 | 39 | assert len(ts) == 1, "checking track appears exactly once in queue" |
f5eb2aff RK |
40 | t = ts[0] |
41 | assert t['submitter'] == u'fred', "check queue submitter" | |
42 | i = t['id'] | |
81e440ce | 43 | print " waiting for track" |
db86b8ed | 44 | c.enable() |
2b2a5fed | 45 | assert c.enabled() == True |
f5eb2aff | 46 | p = c.playing() |
546c7978 | 47 | r = c.recent() |
bf219db9 | 48 | limit = 60 |
546c7978 | 49 | while not((p is not None and p['id'] == i) |
bf219db9 | 50 | or (len(filter(lambda t: t['track'] == track |
51 | and 'submitter' in t, r)) > 0)) and limit > 0: | |
f5eb2aff RK |
52 | time.sleep(1) |
53 | p = c.playing() | |
546c7978 | 54 | r = c.recent() |
bf219db9 | 55 | limit -= 1 |
56 | assert limit > 0, "check track did complete in a reasonable time" | |
81e440ce | 57 | print " checking track turned up in recent list" |
6ce6b5a9 RK |
58 | while (p is not None and p['id'] == i): |
59 | time.sleep(1) | |
60 | p = c.playing() | |
61 | r = c.recent() | |
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" | |
f5eb2aff RK |
64 | t = ts[0] |
65 | assert t['submitter'] == u'fred', "check recent entry submitter" | |
2b2a5fed | 66 | |
7a853280 RK |
67 | print " ensuring queue is clear" |
68 | c.disable() | |
69 | while c.playing() is not None: | |
70 | time.sleep(1) | |
71 | q = c.queue() | |
72 | for qe in q: | |
73 | c.remove(qe["id"]) | |
74 | ||
75 | print " testing playafter" | |
76 | print " adding to empty queue" | |
77 | c.playafter(None, [track]) | |
78 | q = c.queue() | |
79 | print '\n'.join(map(lambda n: "%d: %s" % (n, q[n]["track"]), | |
80 | range(0, len(q)))) | |
81 | assert len(q) == 1 | |
82 | assert q[0]['track'] == track | |
83 | print " insert at start of queue" | |
84 | c.playafter(None, [track2]) | |
85 | q = c.queue() | |
86 | print '\n'.join(map(lambda n: "%d: %s" % (n, q[n]["track"]), | |
87 | range(0, len(q)))) | |
88 | assert len(q) == 2 | |
89 | assert q[0]['track'] == track2 | |
90 | assert q[1]['track'] == track | |
91 | print " insert in middle of queue" | |
92 | c.playafter(q[0]['id'], [track3]) | |
93 | q = c.queue() | |
94 | print '\n'.join(map(lambda n: "%d: %s" % (n, q[n]["track"]), | |
95 | range(0, len(q)))) | |
96 | assert len(q) == 3 | |
97 | assert q[0]['track'] == track2 | |
98 | assert q[1]['track'] == track3 | |
99 | assert q[2]['track'] == track | |
100 | print " insert multiple tracks at end of queue" | |
101 | c.playafter(q[2]['id'], [track2, track]) | |
102 | q = c.queue() | |
103 | print '\n'.join(map(lambda n: "%d: %s" % (n, q[n]["track"]), | |
104 | range(0, len(q)))) | |
105 | assert len(q) == 5 | |
106 | assert q[0]['track'] == track2 | |
107 | assert q[1]['track'] == track3 | |
108 | assert q[2]['track'] == track | |
109 | assert q[3]['track'] == track2 | |
110 | assert q[4]['track'] == track | |
111 | ||
112 | print " clearing queue" | |
113 | for qe in q: | |
114 | c.remove(qe["id"]) | |
115 | ||
2b2a5fed RK |
116 | print " testing scratches" |
117 | retry = False | |
05438e89 RK |
118 | scratchlimit = 5 |
119 | while scratchlimit > 0: | |
120 | scratchlimit -= 1 | |
2b2a5fed RK |
121 | c.disable() |
122 | print " starting a track" | |
123 | c.play(track) | |
124 | c.enable() | |
81e440ce | 125 | p = c.playing() |
2b2a5fed RK |
126 | if p is None: |
127 | print " track played too quickly, trying again..." | |
128 | continue | |
129 | print " scratching track" | |
130 | i = p['id'] | |
131 | c.scratch(i) | |
132 | print " waiting for track to finish" | |
133 | p = c.playing() | |
bf219db9 | 134 | limit = 60 |
135 | while (p is not None and p['id'] == i) and limit > 0: | |
2b2a5fed RK |
136 | time.sleep(1) |
137 | p = c.playing() | |
bf219db9 | 138 | limit -= 1 |
139 | assert limit > 0, "check track finishes in a reasonable period" | |
2b2a5fed RK |
140 | print " checking scratched track turned up in recent list" |
141 | r = c.recent() | |
142 | ts = filter(lambda t: t['id'] == i, r) | |
143 | assert len(ts) == 1, "check scratched track appears exactly once in recent" | |
144 | if ts[0]['state'] == 'ok': | |
145 | print " track played too quickly, trying again..." | |
146 | continue | |
147 | assert ts[0]['state'] == 'scratched', "checking track scratched" | |
148 | break | |
05438e89 RK |
149 | if scratchlimit == 0: |
150 | # TODO this is really not a great approach! | |
151 | print " didn't complete in a reasonable time" | |
152 | sys.exit(77) | |
be603af9 | 153 | print " waiting for scratch to complete" |
2b2a5fed RK |
154 | p = c.recent() |
155 | while p is not None: | |
be603af9 RK |
156 | time.sleep(1) |
157 | p = c.playing() | |
158 | assert p is None, "checking nothing is playing" | |
af371dd1 | 159 | assert c.enabled() == True |
af371dd1 RK |
160 | c.random_enable() |
161 | assert c.random_enabled() == True | |
f5eb2aff RK |
162 | |
163 | if __name__ == '__main__': | |
164 | dtest.run() |