ospath = os.environ["PATH"].split(os.pathsep)
ospath.insert(0, os.path.join(top_builddir, "server"))
ospath.insert(0, os.path.join(top_builddir, "clients"))
+ospath.insert(0, os.path.join(top_builddir, "tests"))
os.environ["PATH"] = os.pathsep.join(ospath)
# Parse the makefile in the current directory to identify the source directory
except:
return False
-def common_setup():
- remove_dir(testroot)
- os.mkdir(testroot)
- global port
- port = random.randint(49152, 65535)
- while not bindable(port):
- print "port %d is not bindable, trying another" % port
- port = random.randint(49152, 65535)
+def default_config():
+ """Write the default config"""
open("%s/config" % testroot, "w").write(
"""home %s
collection fs UTF-8 %s/tracks
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
+trust fred root
plugins
plugins %s/plugins
plugins %s/plugins/.libs
broadcast_from 127.0.0.1 %d
""" % (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()
Start the daemon."""
global daemon, errs, port
assert daemon == None, "no daemon running"
- if not bindable(port):
- print "waiting for speaker socket to become bindable again..."
+ if not bindable(port + 1):
+ print "waiting for port %d to become bindable again..." % (port + 1)
time.sleep(1)
- while not bindable(port):
+ while not bindable(port + 1):
time.sleep(1)
print " starting daemon"
# remove the socket if it exists
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."""
+ print " creating user %s" % username
+ command(["disorder",
+ "--config", disorder._configfile, "--no-per-user-config",
+ "--user", "root", "adduser", username, password])
+
def stop_daemon():
"""stop_daemon()
# 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: