Commit | Line | Data |
---|---|---|
3ece470d | 1 | #! /usr/bin/env python -u |
fbcfb257 RK |
2 | # |
3 | # This file is part of DisOrder. | |
d8055dc4 | 4 | # Copyright (C) 2007, 2008 Richard Kettlewell |
fbcfb257 RK |
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 | # | |
121e3654 RK |
21 | import dtest,time,disorder,sys |
22 | ||
23 | def test(): | |
1c8f3db8 RK |
24 | """Check that the file listing comes out right""" |
25 | dtest.start_daemon() | |
f0feb22e | 26 | dtest.create_user() |
d8055dc4 | 27 | dtest.rescan() |
213b4064 | 28 | assert dtest.check_files() == 0, "dtest.check_files" |
be603af9 RK |
29 | print " checking regexp file listing" |
30 | c = disorder.client() | |
31 | f = c.files("%s/Joe Bloggs/First Album" % dtest.tracks, | |
32 | "second") | |
33 | assert len(f) == 1, "checking for one match" | |
34 | assert f[0] == "%s/Joe Bloggs/First Album/02:Second track.ogg" % dtest.tracks | |
af371dd1 RK |
35 | print " and again to exercise cache" |
36 | f = c.files("%s/Joe Bloggs/First Album" % dtest.tracks, | |
37 | "second") | |
38 | assert len(f) == 1, "checking for one match" | |
39 | assert f[0] == "%s/Joe Bloggs/First Album/02:Second track.ogg" % dtest.tracks | |
be603af9 RK |
40 | print " checking unicode regexp file listing" |
41 | f = c.files("%s/Joe Bloggs/First Album" % dtest.tracks, | |
42 | "first") | |
43 | assert len(f) == 0, "checking for 0 matches" | |
af371dd1 RK |
44 | print " and again to exercise cache" |
45 | f = c.files("%s/Joe Bloggs/First Album" % dtest.tracks, | |
46 | "first") | |
47 | assert len(f) == 0, "checking for 0 matches" | |
be603af9 RK |
48 | # This is rather unsatisfactory but it is the current behavior. We could |
49 | # for instance go to NFD for regexp matching but we'd have to do the same | |
50 | # to the regexp, including replacing single characters with (possibly | |
51 | # bracketed) decomposed forms. Really the answer has to be a more | |
52 | # Unicode-aware regexp library. | |
53 | f = c.files("%s/Joe Bloggs/First Album" % dtest.tracks, | |
54 | "fi\\p{Mn}*rst") | |
55 | assert len(f) == 0, "checking for 0 matches" | |
121e3654 RK |
56 | |
57 | if __name__ == '__main__': | |
0db97c0d | 58 | dtest.run() |