X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~mdw/git/disorder/blobdiff_plain/71b70599a2cd81c13cc4326499a5d0c45358cd7d..dbeb3844d762fabcf63bf7c9c0cc512f505f890d:/tests/dtest.py diff --git a/tests/dtest.py b/tests/dtest.py index cd87c50..982f4d4 100644 --- a/tests/dtest.py +++ b/tests/dtest.py @@ -166,21 +166,8 @@ def bindable(p): except: return False -def common_setup(): - remove_dir(testroot) - os.mkdir(testroot) - # Choose a port - global port - port = random.randint(49152, 65535) - while not bindable(port + 1): - print "port %d is not bindable, trying another" % (port + 1) - port = random.randint(49152, 65535) - # Log anything sent to that port - packetlog = "%s/packetlog" % testroot - subprocess.Popen(["disorder-udplog", - "--output", packetlog, - "127.0.0.1", "%d" % port]) - # disorder-udplog will quit when its parent process terminates +def default_config(): + """Write the default config""" open("%s/config" % testroot, "w").write( """home %s collection fs UTF-8 %s/tracks @@ -193,8 +180,6 @@ stopword 21 22 23 24 25 26 27 28 29 30 stopword the a an and to too in on of we i am as im for is username fred password fredpass -allow fred fredpass -trust fred plugins plugins %s/plugins plugins %s/plugins/.libs @@ -206,13 +191,31 @@ tracklength *.mp3 disorder-tracklength tracklength *.ogg disorder-tracklength tracklength *.wav disorder-tracklength tracklength *.flac disorder-tracklength -speaker_backend network +api network broadcast 127.0.0.1 %d broadcast_from 127.0.0.1 %d +mail_sender no.such.user.sorry@greenend.org.uk """ % (testroot, testroot, testroot, top_builddir, top_builddir, port, port + 1)) + +def common_setup(): + remove_dir(testroot) + os.mkdir(testroot) + # Choose a port + global port + port = random.randint(49152, 65535) + while not bindable(port + 1): + print "port %d is not bindable, trying another" % (port + 1) + port = random.randint(49152, 65535) + # Log anything sent to that port + packetlog = "%s/packetlog" % testroot + subprocess.Popen(["disorder-udplog", + "--output", packetlog, + "127.0.0.1", "%d" % port]) + # disorder-udplog will quit when its parent process terminates copyfile("%s/sounds/scratch.ogg" % top_srcdir, "%s/scratch.ogg" % testroot) + default_config() def start_daemon(): """start_daemon() @@ -253,6 +256,19 @@ Start the daemon.""" if waited > 0: print " took about %ds for socket to appear" % waited +def create_user(username="fred", password="fredpass"): + """create_user(USERNAME, PASSWORD) + + Create a user, abusing direct database access to do so. Gives the + user rights 'all', allowing them to do anything.""" + print " creating user %s" % username + command(["disorder", + "--config", disorder._configfile, "--no-per-user-config", + "--user", "root", "adduser", username, password]) + command(["disorder", + "--config", disorder._configfile, "--no-per-user-config", + "--user", "root", "edituser", username, "rights", "all"]) + def stop_daemon(): """stop_daemon() @@ -291,7 +307,12 @@ def run(module=None, report=True): name = module.__name__ # Open the error log global errs - errs = open("%s.log" % name, "w") + logfile = "%s.log" % name + try: + os.remove(logfile) + except: + pass + errs = open(logfile, "a") # Ensure that disorder.py uses the test installation disorder._configfile = "%s/config" % testroot disorder._userconf = False @@ -300,12 +321,7 @@ def run(module=None, report=True): # Create some standard tracks stdtracks() try: - try: - module.test() - except AssertionError, e: - global failures - failures += 1 - print "assertion failed: %s" % e.message + module.test() finally: stop_daemon() if report: