Do not reprovision if conf is already available
authorSimo Sorce <simo@redhat.com>
Mon, 8 Sep 2014 21:36:02 +0000 (17:36 -0400)
committerPatrick Uiterwijk <puiterwijk@redhat.com>
Wed, 24 Sep 2014 18:29:06 +0000 (20:29 +0200)
Also use a more meaningful directory name by default

Signed-off-by: Simo Sorce <simo@redhat.com>
Reviewed-by: Patrick Uiterwijk <puiterwijk@redhat.com>
quickrun.py

index caa9627..5ec6e53 100755 (executable)
@@ -29,7 +29,7 @@ logger = None
 def parse_args():
     parser = argparse.ArgumentParser(description=\
         'Run a test Ipsilon instance from the checkout directory')
-    parser.add_argument('--workdir', default=os.path.join(os.getcwd(), 'tmp'),
+    parser.add_argument('--workdir', default=os.path.join(os.getcwd(), 'qrun'),
                         help="Directory in which db/session files are stored")
     return vars(parser.parse_args())
 
@@ -60,39 +60,44 @@ CREATE TABLE users(name TEXT, option TEXT, value TEXT);
 INSERT INTO users VALUES('admin', 'is_admin', '1');
 '''
 
-if __name__ == '__main__':
-
-    args = parse_args()
-
-    penv = dict()
-    penv.update(os.environ)
-    penv['PYTHONPATH'] = './'
-
-    if not os.path.exists(args['workdir']):
-        os.makedirs(args['workdir'])
-        os.makedirs(os.path.join(args['workdir'], 'sessions'))
+def config(workdir):
+    os.makedirs(workdir)
+    os.makedirs(os.path.join(workdir, 'sessions'))
 
-    admin_db = os.path.join(args['workdir'], 'adminconfig.sqlite')
-    sql = os.path.join(args['workdir'], 'admin.sql')
+    admin_db = os.path.join(workdir, 'adminconfig.sqlite')
+    sql = os.path.join(workdir, 'admin.sql')
     with open(sql, 'w+') as f:
         f.write(ADMIN_TEMPLATE)
     subprocess.call(['sqlite3', '-init', sql, admin_db, '.quit'])
 
-    users_db = os.path.join(args['workdir'], 'users.sqlite')
-    sql = os.path.join(args['workdir'], 'users.sql')
+    users_db = os.path.join(workdir, 'users.sqlite')
+    sql = os.path.join(workdir, 'users.sql')
     with open(sql, 'w+') as f:
         f.write(USERS_TEMPLATE)
     subprocess.call(['sqlite3', '-init', sql, users_db, '.quit'])
 
     t = Template(CONF_TEMPLATE)
     text = t.substitute({'BASEDIR': os.getcwd(),
-                         'WORKDIR': args['workdir'],
+                         'WORKDIR': workdir,
                          'ADMINDB': admin_db,
                          'USERSDB': users_db})
-    conf = os.path.join(args['workdir'], 'ipsilon.conf')
+    conf = os.path.join(workdir, 'ipsilon.conf')
     with open(conf, 'w+') as f:
         f.write(text)
+    return conf
 
+if __name__ == '__main__':
+
+    args = parse_args()
+
+    penv = dict()
+    penv.update(os.environ)
+    penv['PYTHONPATH'] = './'
+
+    if not os.path.exists(args['workdir']):
+        conf = config(args['workdir'])
+    else:
+        conf = os.path.join(args['workdir'], 'ipsilon.conf')
 
     p = subprocess.Popen(['./ipsilon/ipsilon', conf], env=penv)
     p.wait()