44
39
Return None if the program had a 0 return code.
45
40
Return the string stderr if the program failed.
47
kwargs['stderr'] = subprocess.PIPE
49
proc = subprocess.Popen(*popenargs, **kwargs)
42
proc = subprocess.Popen(*popenargs, stderr=subprocess.PIPE, **kwargs)
50
43
_, stderr = proc.communicate()
51
44
if proc.returncode == 0:
106
99
# Unmount all the jails
107
100
logging.info("Unmounting all users.")
108
subprocess.check_call(["ivle-mountallusers", "-u"])
101
subprocess.check_call(["bin/ivle-mountallusers", "-u"])
111
104
logging.info("Dropping database \"%s\"." % dbconfig["name"])
128
121
# Populate with database schema
129
122
logging.info("Populating database with schema.")
130
ivleconn = psycopg2.connect(
131
host='localhost', database=dbconfig['name'], user=dbconfig['username'],
132
password=dbconfig['password'])
133
ivlecursor = ivleconn.cursor()
134
logging.info("Populating database with schema.")
135
schemafile = open("userdb/users.sql")
136
ivlecursor.execute(schemafile.read())
123
file = open("userdb/users.sql")
124
proc = subprocess.Popen(["psql", "-h", "localhost", "-W", dbconfig["name"],
125
dbconfig["username"]], stdin=file)
139
131
# Build or rebuild all of the users' filesystems and subversion repos
140
132
logging.info("Creating data directories.")
141
subprocess.check_call(["ivle-createdatadirs"])
133
subprocess.check_call(["bin/ivle-createdatadirs"])
143
135
# Move all of the users' filesystems and subversion repos out of the way
144
136
# (This will clean out the user dirs because there are no users in the DB.)
145
137
logging.info("Moving existing user filesystems and repos out of the way.")
146
subprocess.check_call(["ivle-refreshfilesystem"])
138
subprocess.check_call(["bin/ivle-refreshfilesystem"])
148
140
# Populate with sample data
149
141
logging.info("Populating database with sample data.")
158
150
# Build all of the users' filesystems and subversion repos
159
151
# (This will create fresh user dirs and repos because the jails were empty.)
160
152
logging.info("Building sample users' filesystems and repos.")
161
subprocess.check_call(["ivle-refreshfilesystem"])
164
dbconfig = config['database']
166
# Populate some of the users' Subversion repos
167
def temp_checkout(svnclient, username):
168
"""Checkout user `username`'s repo to a temporary directory.
169
@return: The temporary workspace directory.
171
# Do the checkout over HTTP, since we then use the user's own credentials
172
repourl = config['urls']['svn_addr'] + '/users/' + username
173
# Ignore warnings about the use of tempnam
174
warnings.simplefilter('ignore')
175
tempdir = os.tempnam()
176
warnings.resetwarnings()
177
svnclient.checkout(repourl, tempdir)
180
logging.info("Populating student repositories")
181
def svnload(dumpfile, repo):
182
"""Run svnadmin load.
183
@param dumpfile: Dump file to load from, relative to examples/userrepos.
184
@param repo: Repo to write to, relative to /var/lib/ivle/svn/repositories.
186
f = open(os.path.join("examples/userrepos", dumpfile), "rb")
187
repo = os.path.join(config['paths']['svn']['repo_path'], repo)
188
errmsg = runprog_stderr(["sudo", "-u", "www-data", "svnadmin", "load",
190
if errmsg is not None:
191
logging.error(errmsg)
194
# Load the known SVN dump files
195
svnload("studenta.dump", "users/studenta")
196
svnload("group1.dump", "groups/ivle-102_2009_2_group1")
153
subprocess.check_call(["bin/ivle-refreshfilesystem"])