~azzar1/unity/add-show-desktop-key

« back to all changes in this revision

Viewing changes to examples/db/sample.sql

  • Committer: William Grant
  • Date: 2010-02-24 01:21:07 UTC
  • Revision ID: grantw@unimelb.edu.au-20100224012107-e02qr9ce1ftg05y5
Remove unused UserRESTView and associated infrastructure.

Show diffs side-by-side

added added

removed removed

Lines of Context:
2
2
-- PostgreSQL database dump
3
3
--
4
4
 
5
 
SET statement_timeout = 0;
6
5
SET client_encoding = 'UTF8';
7
6
SET standard_conforming_strings = off;
8
7
SET check_function_bodies = false;
15
14
-- Name: assessed_assessedid_seq; Type: SEQUENCE SET; Schema: public; Owner: -
16
15
--
17
16
 
18
 
SELECT pg_catalog.setval('assessed_assessedid_seq', 1, false);
 
17
SELECT pg_catalog.setval('assessed_assessedid_seq', 1, true);
19
18
 
20
19
 
21
20
--
92
91
-- Name: suite_variable_varid_seq; Type: SEQUENCE SET; Schema: public; Owner: -
93
92
--
94
93
 
95
 
SELECT pg_catalog.setval('suite_variable_varid_seq', 1, false);
 
94
SELECT pg_catalog.setval('suite_variable_varid_seq', 2, true);
96
95
 
97
96
 
98
97
--
99
98
-- Name: test_case_part_partid_seq; Type: SEQUENCE SET; Schema: public; Owner: -
100
99
--
101
100
 
102
 
SELECT pg_catalog.setval('test_case_part_partid_seq', 1, false);
 
101
SELECT pg_catalog.setval('test_case_part_partid_seq', 10, true);
103
102
 
104
103
 
105
104
--
106
105
-- Name: test_case_testid_seq; Type: SEQUENCE SET; Schema: public; Owner: -
107
106
--
108
107
 
109
 
SELECT pg_catalog.setval('test_case_testid_seq', 1, false);
 
108
SELECT pg_catalog.setval('test_case_testid_seq', 10, true);
110
109
 
111
110
 
112
111
--
113
112
-- Name: test_suite_suiteid_seq; Type: SEQUENCE SET; Schema: public; Owner: -
114
113
--
115
114
 
116
 
SELECT pg_catalog.setval('test_suite_suiteid_seq', 1, false);
 
115
SELECT pg_catalog.setval('test_suite_suiteid_seq', 5, true);
117
116
 
118
117
 
119
118
--
120
119
-- Name: worksheet_exercise_ws_ex_id_seq; Type: SEQUENCE SET; Schema: public; Owner: -
121
120
--
122
121
 
123
 
SELECT pg_catalog.setval('worksheet_exercise_ws_ex_id_seq', 1, false);
 
122
SELECT pg_catalog.setval('worksheet_exercise_ws_ex_id_seq', 2, true);
124
123
 
125
124
 
126
125
--
127
126
-- Name: worksheet_worksheetid_seq; Type: SEQUENCE SET; Schema: public; Owner: -
128
127
--
129
128
 
130
 
SELECT pg_catalog.setval('worksheet_worksheetid_seq', 1, false);
131
 
 
132
 
 
133
 
--
134
 
--
135
 
 
136
 
SET SESSION AUTHORIZATION DEFAULT;
137
 
 
138
 
ALTER TABLE login DISABLE TRIGGER ALL;
139
 
 
140
 
INSERT INTO login (loginid, login, passhash, state, admin, unixid, nick, pass_exp, acct_exp, last_login, svn_pass, email, fullname, studentid, settings) VALUES (1, 'admin', '5f4dcc3b5aa765d61d8327deb882cf99', 'enabled', true, 5000, 'Anne Admin', NULL, NULL, '2009-12-08 11:44:02.285862', 'password', NULL, 'Anne Admin', NULL, NULL);
141
 
INSERT INTO login (loginid, login, passhash, state, admin, unixid, nick, pass_exp, acct_exp, last_login, svn_pass, email, fullname, studentid, settings) VALUES (2, 'lecturer', '5f4dcc3b5aa765d61d8327deb882cf99', 'enabled', false, 5001, 'Larry Lecturer', NULL, NULL, '2009-12-08 12:12:16.375628', 'password', NULL, 'Larry Lecturer', NULL, NULL);
142
 
INSERT INTO login (loginid, login, passhash, state, admin, unixid, nick, pass_exp, acct_exp, last_login, svn_pass, email, fullname, studentid, settings) VALUES (3, 'tutor', '5f4dcc3b5aa765d61d8327deb882cf99', 'enabled', false, 5002, 'Terry Tutor', NULL, NULL, '2009-12-08 19:08:59.817505', 'password', NULL, 'Terry Tutor', NULL, NULL);
143
 
INSERT INTO login (loginid, login, passhash, state, admin, unixid, nick, pass_exp, acct_exp, last_login, svn_pass, email, fullname, studentid, settings) VALUES (4, 'studenta', '5f4dcc3b5aa765d61d8327deb882cf99', 'enabled', false, 5003, 'Alice Student', NULL, NULL, '2009-12-08 12:11:46.349133', 'password', NULL, 'Alice Student', NULL, NULL);
144
 
INSERT INTO login (loginid, login, passhash, state, admin, unixid, nick, pass_exp, acct_exp, last_login, svn_pass, email, fullname, studentid, settings) VALUES (5, 'studentb', '5f4dcc3b5aa765d61d8327deb882cf99', 'no_agreement', false, 5004, 'Bob Student', NULL, NULL, NULL, NULL, NULL, 'Bob Student', NULL, NULL);
145
 
 
146
 
 
147
 
ALTER TABLE login ENABLE TRIGGER ALL;
148
 
 
149
 
--
150
 
--
151
 
 
152
 
ALTER TABLE semester DISABLE TRIGGER ALL;
153
 
 
154
 
INSERT INTO semester (semesterid, year, semester, state) VALUES (1, '2009', '1', 'past');
155
 
INSERT INTO semester (semesterid, year, semester, state) VALUES (2, '2009', '2', 'current');
156
 
INSERT INTO semester (semesterid, year, semester, state) VALUES (3, '2010', '1', 'future');
157
 
INSERT INTO semester (semesterid, year, semester, state) VALUES (4, '2010', '2', 'future');
158
 
 
159
 
 
160
 
ALTER TABLE semester ENABLE TRIGGER ALL;
161
 
 
162
 
--
163
 
--
164
 
 
165
 
ALTER TABLE subject DISABLE TRIGGER ALL;
166
 
 
167
 
INSERT INTO subject (subjectid, subj_code, subj_name, subj_short_name, url) VALUES (1, '100101', 'Introduction to IVLE', 'ivle-101', 'http://www.ivle.org/example/101');
168
 
INSERT INTO subject (subjectid, subj_code, subj_name, subj_short_name, url) VALUES (2, '100102', 'Intermediate IVLE', 'ivle-102', 'http://www.ivle.org/example/102');
169
 
INSERT INTO subject (subjectid, subj_code, subj_name, subj_short_name, url) VALUES (3, '100201', 'Advanced IVLE', 'ivle-201', 'http://www.ivle.org/example/201');
170
 
INSERT INTO subject (subjectid, subj_code, subj_name, subj_short_name, url) VALUES (4, '100202', 'Mastering IVLE', 'ivle-202', 'http://www.ivle.org/example/202');
171
 
 
172
 
 
173
 
ALTER TABLE subject ENABLE TRIGGER ALL;
174
 
 
175
 
--
176
 
--
177
 
 
178
 
ALTER TABLE offering DISABLE TRIGGER ALL;
179
 
 
180
 
INSERT INTO offering (offeringid, subject, semesterid, groups_student_permissions) VALUES (1, 1, 1, 'none');
181
 
INSERT INTO offering (offeringid, subject, semesterid, groups_student_permissions) VALUES (2, 2, 2, 'none');
182
 
INSERT INTO offering (offeringid, subject, semesterid, groups_student_permissions) VALUES (3, 1, 3, 'none');
183
 
INSERT INTO offering (offeringid, subject, semesterid, groups_student_permissions) VALUES (4, 3, 3, 'none');
184
 
INSERT INTO offering (offeringid, subject, semesterid, groups_student_permissions) VALUES (5, 2, 4, 'none');
185
 
INSERT INTO offering (offeringid, subject, semesterid, groups_student_permissions) VALUES (6, 4, 4, 'none');
186
 
 
187
 
 
188
 
ALTER TABLE offering ENABLE TRIGGER ALL;
189
 
 
190
 
--
191
 
--
192
 
 
193
 
ALTER TABLE project_set DISABLE TRIGGER ALL;
194
 
 
195
 
INSERT INTO project_set (projectsetid, offeringid, max_students_per_group) VALUES (1, 2, NULL);
196
 
INSERT INTO project_set (projectsetid, offeringid, max_students_per_group) VALUES (2, 2, 3);
197
 
 
198
 
 
199
 
ALTER TABLE project_set ENABLE TRIGGER ALL;
200
 
 
201
 
--
202
 
--
203
 
 
204
 
ALTER TABLE project DISABLE TRIGGER ALL;
205
 
 
206
 
INSERT INTO project (projectid, short_name, name, synopsis, url, projectsetid, deadline) VALUES (1, 'phase1', 'Phase 1', 'This is the first project in Intermediate IVLE.', NULL, 1, '2009-08-21 18:00:00');
207
 
INSERT INTO project (projectid, short_name, name, synopsis, url, projectsetid, deadline) VALUES (2, 'phase2', 'Phase 2', 'This is the second project in Intermediate IVLE.
208
 
Get into groups of 3.', NULL, 2, '2009-09-11 18:00:00');
209
 
INSERT INTO project (projectid, short_name, name, synopsis, url, projectsetid, deadline) VALUES (3, 'phase3', 'Phase 3', 'This is the final project in Intermediate IVLE.
210
 
Complete this with the same group as Phase 2.', NULL, 2, '2009-09-25 18:00:00');
211
 
 
212
 
 
213
 
ALTER TABLE project ENABLE TRIGGER ALL;
214
 
 
215
 
--
216
 
--
217
 
 
218
 
ALTER TABLE project_group DISABLE TRIGGER ALL;
219
 
 
220
 
INSERT INTO project_group (groupnm, groupid, projectsetid, nick, createdby, epoch) VALUES ('group1', 1, 2, 'group1', 2, '2009-12-08 17:04:42.981005');
221
 
 
222
 
 
223
 
ALTER TABLE project_group ENABLE TRIGGER ALL;
 
129
SELECT pg_catalog.setval('worksheet_worksheetid_seq', 1, true);
 
130
 
224
131
 
225
132
--
226
133
-- Data for Name: assessed; Type: TABLE DATA; Schema: public; Owner: -
235
135
 
236
136
ALTER TABLE assessed DISABLE TRIGGER ALL;
237
137
 
 
138
INSERT INTO assessed (assessedid, loginid, groupid, projectid) VALUES (1, 2, NULL, 1);
238
139
 
239
140
 
240
141
ALTER TABLE assessed ENABLE TRIGGER ALL;
261
162
 
262
163
ALTER TABLE exercise DISABLE TRIGGER ALL;
263
164
 
 
165
INSERT INTO exercise (identifier, name, description, partial, solution, include, num_rows) VALUES ('factorial', 'Factorial', 'Write a function, `fac`, to compute the **factorial** of a number. e.g.::
 
166
 
 
167
    >>> fac(4)
 
168
    24
 
169
 
 
170
Then, write a function `main`, which reads a number from stdin, and writes its factorial to stdout. e.g.::
 
171
 
 
172
    >>> main()
 
173
    4
 
174
    24
 
175
', 'def fac(n):
 
176
    pass
 
177
 
 
178
def main():
 
179
    pass
 
180
', 'def fac(n):
 
181
    if n == 0:
 
182
        return 1
 
183
    else:
 
184
        return n * fac(n-1)
 
185
 
 
186
def main():
 
187
    f = int(raw_input())
 
188
    print fac(f)', '', 12);
 
189
INSERT INTO exercise (identifier, name, description, partial, solution, include, num_rows) VALUES ('hello', 'Hello world', 'Write a program which prints out "Hello, world!" when it is run.
 
190
 
 
191
Note that if you print anything with the words "Hello world", but with wrong punctuation and capitalization, you will get some positive feedback, but still fail overall. You need to print an exact match.', 'print "..."', 'print "Hello, world!"', 'import re', 4);
264
192
 
265
193
 
266
194
ALTER TABLE exercise ENABLE TRIGGER ALL;
267
195
 
268
196
--
269
 
--
270
 
 
271
 
ALTER TABLE worksheet DISABLE TRIGGER ALL;
272
 
 
273
 
 
274
 
 
275
 
ALTER TABLE worksheet ENABLE TRIGGER ALL;
276
 
 
277
 
--
278
 
--
279
 
 
280
 
ALTER TABLE worksheet_exercise DISABLE TRIGGER ALL;
281
 
 
282
 
 
283
 
 
284
 
ALTER TABLE worksheet_exercise ENABLE TRIGGER ALL;
285
 
 
286
 
--
287
197
-- Data for Name: exercise_attempt; Type: TABLE DATA; Schema: public; Owner: -
288
198
--
289
199
 
328
236
ALTER TABLE group_member ENABLE TRIGGER ALL;
329
237
 
330
238
--
 
239
-- Data for Name: login; Type: TABLE DATA; Schema: public; Owner: -
 
240
--
 
241
 
 
242
ALTER TABLE login DISABLE TRIGGER ALL;
 
243
 
 
244
INSERT INTO login (loginid, login, passhash, state, admin, unixid, nick, pass_exp, acct_exp, last_login, svn_pass, email, fullname, studentid, settings) VALUES (1, 'admin', '5f4dcc3b5aa765d61d8327deb882cf99', 'enabled', true, 5000, 'Anne Admin', NULL, NULL, '2009-12-08 11:44:02.285862', 'password', NULL, 'Anne Admin', NULL, NULL);
 
245
INSERT INTO login (loginid, login, passhash, state, admin, unixid, nick, pass_exp, acct_exp, last_login, svn_pass, email, fullname, studentid, settings) VALUES (2, 'lecturer', '5f4dcc3b5aa765d61d8327deb882cf99', 'enabled', false, 5001, 'Larry Lecturer', NULL, NULL, '2009-12-08 12:12:16.375628', 'password', NULL, 'Larry Lecturer', NULL, NULL);
 
246
INSERT INTO login (loginid, login, passhash, state, admin, unixid, nick, pass_exp, acct_exp, last_login, svn_pass, email, fullname, studentid, settings) VALUES (3, 'tutor', '5f4dcc3b5aa765d61d8327deb882cf99', 'enabled', false, 5002, 'Terry Tutor', NULL, NULL, '2009-12-08 19:08:59.817505', 'password', NULL, 'Terry Tutor', NULL, NULL);
 
247
INSERT INTO login (loginid, login, passhash, state, admin, unixid, nick, pass_exp, acct_exp, last_login, svn_pass, email, fullname, studentid, settings) VALUES (4, 'studenta', '5f4dcc3b5aa765d61d8327deb882cf99', 'enabled', false, 5003, 'Alice Student', NULL, NULL, '2009-12-08 12:11:46.349133', 'password', NULL, 'Alice Student', NULL, NULL);
 
248
INSERT INTO login (loginid, login, passhash, state, admin, unixid, nick, pass_exp, acct_exp, last_login, svn_pass, email, fullname, studentid, settings) VALUES (5, 'studentb', '5f4dcc3b5aa765d61d8327deb882cf99', 'no_agreement', false, 5004, 'Bob Student', NULL, NULL, NULL, NULL, NULL, 'Bob Student', NULL, NULL);
 
249
 
 
250
 
 
251
ALTER TABLE login ENABLE TRIGGER ALL;
 
252
 
 
253
--
 
254
-- Data for Name: offering; Type: TABLE DATA; Schema: public; Owner: -
 
255
--
 
256
 
 
257
ALTER TABLE offering DISABLE TRIGGER ALL;
 
258
 
 
259
INSERT INTO offering (offeringid, subject, semesterid, description, url, groups_student_permissions) VALUES (1, 1, 1, 'This subject will introduce you to the basics of IVLE.', 'http://www.ivle.org/example/101', 'none');
 
260
INSERT INTO offering (offeringid, subject, semesterid, description, url, groups_student_permissions) VALUES (2, 2, 2, 'Enhancing your understanding of IVLE''s usage and operation, this subject will consolidate and expand your general IVLE knowledge.', 'http://www.ivle.org/example/102', 'none');
 
261
INSERT INTO offering (offeringid, subject, semesterid, description, url, groups_student_permissions) VALUES (3, 1, 3, 'This subject will introduce you to the basics of IVLE, again.', 'http://www.ivle.org/example/101', 'none');
 
262
INSERT INTO offering (offeringid, subject, semesterid, description, url, groups_student_permissions) VALUES (4, 3, 3, 'This subject will provide you with a working knowledge of advanced IVLE concepts.', 'http://www.ivle.org/example/201', 'none');
 
263
INSERT INTO offering (offeringid, subject, semesterid, description, url, groups_student_permissions) VALUES (5, 2, 4, 'Enhancing your understanding of IVLE''s usage and operation, this subject will consolidate and expand your general IVLE knowledge, again.', 'http://www.ivle.org/example/102', 'none');
 
264
INSERT INTO offering (offeringid, subject, semesterid, description, url, groups_student_permissions) VALUES (6, 4, 4, 'After undertaking this subject, you should be a master of all things IVLEy.', 'http://www.ivle.org/example/202', 'none');
 
265
 
 
266
 
 
267
ALTER TABLE offering ENABLE TRIGGER ALL;
 
268
 
 
269
--
 
270
-- Data for Name: project; Type: TABLE DATA; Schema: public; Owner: -
 
271
--
 
272
 
 
273
ALTER TABLE project DISABLE TRIGGER ALL;
 
274
 
 
275
INSERT INTO project (projectid, short_name, name, synopsis, url, projectsetid, deadline) VALUES (1, 'phase1', 'Phase 1', 'This is the first project in Intermediate IVLE.', NULL, 1, '3009-08-21 18:00:00');
 
276
INSERT INTO project (projectid, short_name, name, synopsis, url, projectsetid, deadline) VALUES (2, 'phase2', 'Phase 2', 'This is the second project in Intermediate IVLE.
 
277
Get into groups of 3.', NULL, 2, '3009-09-11 18:00:00');
 
278
INSERT INTO project (projectid, short_name, name, synopsis, url, projectsetid, deadline) VALUES (3, 'phase3', 'Phase 3', 'This is the final project in Intermediate IVLE.
 
279
Complete this with the same group as Phase 2.', NULL, 2, '2009-09-25 18:00:00');
 
280
 
 
281
 
 
282
ALTER TABLE project ENABLE TRIGGER ALL;
 
283
 
 
284
--
331
285
-- Data for Name: project_extension; Type: TABLE DATA; Schema: public; Owner: -
332
286
--
333
287
 
338
292
ALTER TABLE project_extension ENABLE TRIGGER ALL;
339
293
 
340
294
--
 
295
-- Data for Name: project_group; Type: TABLE DATA; Schema: public; Owner: -
 
296
--
 
297
 
 
298
ALTER TABLE project_group DISABLE TRIGGER ALL;
 
299
 
 
300
INSERT INTO project_group (groupnm, groupid, projectsetid, nick, createdby, epoch) VALUES ('group1', 1, 2, 'group1', 2, '2009-12-08 17:04:42.981005');
 
301
 
 
302
 
 
303
ALTER TABLE project_group ENABLE TRIGGER ALL;
 
304
 
 
305
--
341
306
-- Data for Name: project_mark; Type: TABLE DATA; Schema: public; Owner: -
342
307
--
343
308
 
348
313
ALTER TABLE project_mark ENABLE TRIGGER ALL;
349
314
 
350
315
--
 
316
-- Data for Name: project_set; Type: TABLE DATA; Schema: public; Owner: -
 
317
--
 
318
 
 
319
ALTER TABLE project_set DISABLE TRIGGER ALL;
 
320
 
 
321
INSERT INTO project_set (projectsetid, offeringid, max_students_per_group) VALUES (1, 2, NULL);
 
322
INSERT INTO project_set (projectsetid, offeringid, max_students_per_group) VALUES (2, 2, 3);
 
323
 
 
324
 
 
325
ALTER TABLE project_set ENABLE TRIGGER ALL;
 
326
 
 
327
--
351
328
-- Data for Name: project_submission; Type: TABLE DATA; Schema: public; Owner: -
352
329
--
353
330
 
358
335
ALTER TABLE project_submission ENABLE TRIGGER ALL;
359
336
 
360
337
--
361
 
--
362
 
 
363
 
ALTER TABLE test_suite DISABLE TRIGGER ALL;
364
 
 
365
 
 
366
 
 
367
 
ALTER TABLE test_suite ENABLE TRIGGER ALL;
 
338
-- Data for Name: semester; Type: TABLE DATA; Schema: public; Owner: -
 
339
--
 
340
 
 
341
ALTER TABLE semester DISABLE TRIGGER ALL;
 
342
 
 
343
INSERT INTO semester (semesterid, year, semester, state) VALUES (1, '2009', '1', 'past');
 
344
INSERT INTO semester (semesterid, year, semester, state) VALUES (2, '2009', '2', 'current');
 
345
INSERT INTO semester (semesterid, year, semester, state) VALUES (3, '2010', '1', 'future');
 
346
INSERT INTO semester (semesterid, year, semester, state) VALUES (4, '2010', '2', 'future');
 
347
 
 
348
 
 
349
ALTER TABLE semester ENABLE TRIGGER ALL;
 
350
 
 
351
--
 
352
-- Data for Name: subject; Type: TABLE DATA; Schema: public; Owner: -
 
353
--
 
354
 
 
355
ALTER TABLE subject DISABLE TRIGGER ALL;
 
356
 
 
357
INSERT INTO subject (subjectid, subj_code, subj_name, subj_short_name) VALUES (1, '100101', 'Introduction to IVLE', 'ivle-101');
 
358
INSERT INTO subject (subjectid, subj_code, subj_name, subj_short_name) VALUES (2, '100102', 'Intermediate IVLE', 'ivle-102');
 
359
INSERT INTO subject (subjectid, subj_code, subj_name, subj_short_name) VALUES (3, '100201', 'Advanced IVLE', 'ivle-201');
 
360
INSERT INTO subject (subjectid, subj_code, subj_name, subj_short_name) VALUES (4, '100202', 'Mastering IVLE', 'ivle-202');
 
361
 
 
362
 
 
363
ALTER TABLE subject ENABLE TRIGGER ALL;
368
364
 
369
365
--
370
366
-- Data for Name: suite_variable; Type: TABLE DATA; Schema: public; Owner: -
373
368
 
374
369
ALTER TABLE suite_variable DISABLE TRIGGER ALL;
375
370
 
 
371
INSERT INTO suite_variable (varid, suiteid, var_name, var_value, var_type, arg_no) VALUES (1, 1, '', '4', 'arg', 0);
 
372
INSERT INTO suite_variable (varid, suiteid, var_name, var_value, var_type, arg_no) VALUES (2, 2, '', '5', 'arg', 0);
376
373
 
377
374
 
378
375
ALTER TABLE suite_variable ENABLE TRIGGER ALL;
383
380
 
384
381
ALTER TABLE test_case DISABLE TRIGGER ALL;
385
382
 
 
383
INSERT INTO test_case (testid, suiteid, passmsg, failmsg, test_default, seq_no) VALUES (1, 1, 'Calculates factorial correctly', 'Wrong answer', 'ignore', 0);
 
384
INSERT INTO test_case (testid, suiteid, passmsg, failmsg, test_default, seq_no) VALUES (2, 1, 'Doesn''t use functools', 'You used functools, you arrogant git', 'ignore', 1);
 
385
INSERT INTO test_case (testid, suiteid, passmsg, failmsg, test_default, seq_no) VALUES (3, 2, 'Calculates factorial correctly', 'Wrong answer', 'ignore', 0);
 
386
INSERT INTO test_case (testid, suiteid, passmsg, failmsg, test_default, seq_no) VALUES (5, 3, 'Main worked correctly', 'Main printed something else as well. You should only print out the answer.', 'ignore', 1);
 
387
INSERT INTO test_case (testid, suiteid, passmsg, failmsg, test_default, seq_no) VALUES (4, 3, 'Main printout included the correct answer', 'Main didn''t print out the correct answer', 'ignore', 0);
 
388
INSERT INTO test_case (testid, suiteid, passmsg, failmsg, test_default, seq_no) VALUES (6, 1, 'Doesn''t use __import__', 'You used __import__, you subversive git!', 'ignore', 2);
 
389
INSERT INTO test_case (testid, suiteid, passmsg, failmsg, test_default, seq_no) VALUES (7, 4, 'Prints the correct words', 'Didn''t print the words "Hello world" at all', 'ignore', 0);
 
390
INSERT INTO test_case (testid, suiteid, passmsg, failmsg, test_default, seq_no) VALUES (10, 4, 'Prints "Hello, world!" exactly', 'Did not print "Hello, world!" exactly', 'ignore', 1);
386
391
 
387
392
 
388
393
ALTER TABLE test_case ENABLE TRIGGER ALL;
393
398
 
394
399
ALTER TABLE test_case_part DISABLE TRIGGER ALL;
395
400
 
 
401
INSERT INTO test_case_part (partid, testid, part_type, test_type, data, filename) VALUES (1, 1, 'result', 'match', '', NULL);
 
402
INSERT INTO test_case_part (partid, testid, part_type, test_type, data, filename) VALUES (2, 2, 'code', 'check', 'lambda solution, attempt: ''functools'' not in attempt', NULL);
 
403
INSERT INTO test_case_part (partid, testid, part_type, test_type, data, filename) VALUES (3, 3, 'result', 'match', '', NULL);
 
404
INSERT INTO test_case_part (partid, testid, part_type, test_type, data, filename) VALUES (5, 5, 'stdout', 'norm', 'lambda x: x.strip() # Allow leading or trailing whitespace', NULL);
 
405
INSERT INTO test_case_part (partid, testid, part_type, test_type, data, filename) VALUES (4, 4, 'stdout', 'check', 'lambda solution, attempt: solution.strip() in attempt   # Substring test', NULL);
 
406
INSERT INTO test_case_part (partid, testid, part_type, test_type, data, filename) VALUES (6, 6, 'code', 'check', 'lambda solution, attempt: ''__import__'' not in attempt', NULL);
 
407
INSERT INTO test_case_part (partid, testid, part_type, test_type, data, filename) VALUES (10, 10, 'stdout', 'match', 'lambda solution, attempt: re.match("hello[^a-z]*world[^a-z]*", attempt.lower())', NULL);
 
408
INSERT INTO test_case_part (partid, testid, part_type, test_type, data, filename) VALUES (7, 7, 'stdout', 'check', 'lambda solution, attempt: re.match("hello[^a-z]*world[^a-z]*", attempt.lower())', NULL);
396
409
 
397
410
 
398
411
ALTER TABLE test_case_part ENABLE TRIGGER ALL;
399
412
 
400
413
--
 
414
-- Data for Name: test_suite; Type: TABLE DATA; Schema: public; Owner: -
 
415
--
 
416
 
 
417
ALTER TABLE test_suite DISABLE TRIGGER ALL;
 
418
 
 
419
INSERT INTO test_suite (suiteid, exerciseid, description, seq_no, function, stdin) VALUES (2, 'factorial', 'Test fac(5)', 1, 'fac', '');
 
420
INSERT INTO test_suite (suiteid, exerciseid, description, seq_no, function, stdin) VALUES (1, 'factorial', 'Test fac(4)', 0, 'fac', '');
 
421
INSERT INTO test_suite (suiteid, exerciseid, description, seq_no, function, stdin) VALUES (3, 'factorial', 'Test main', 2, 'main', '4
 
422
');
 
423
INSERT INTO test_suite (suiteid, exerciseid, description, seq_no, function, stdin) VALUES (4, 'hello', 'Prints "Hello, world!" exactly', 0, '', '');
 
424
 
 
425
 
 
426
ALTER TABLE test_suite ENABLE TRIGGER ALL;
 
427
 
 
428
--
 
429
-- Data for Name: worksheet; Type: TABLE DATA; Schema: public; Owner: -
 
430
--
 
431
 
 
432
ALTER TABLE worksheet DISABLE TRIGGER ALL;
 
433
 
 
434
INSERT INTO worksheet (worksheetid, offeringid, identifier, name, data, assessable, seq_no, format) VALUES (1, 2, 'worksheet1', 'Worksheet Basics', 'IVLE allows lecturers and tutors to create worksheets, which are presented to students, optionally, for assessment.
 
435
 
 
436
Worksheets are reStructuredText (rich text) documents which can present students with information or tutorials, much like a textbook. For example, we might explain that "recursion is when a function calls itself".
 
437
 
 
438
We can use any reStructuredText markup, such as **bold** and `links <http://ivle.org>`_. We can also embed exercises. For example, we might invite students to "try out recursion in the following exercise".
 
439
 
 
440
Beginning a line with ``.. exercise:: <exercise-name>`` embeds an exercise in a worksheet, like this:
 
441
 
 
442
.. exercise:: hello
 
443
 
 
444
Now, the student may try out the above exercise, and submit it as many times as (s)he wishes. Once they have it correct, they will receive a point on their assessment.
 
445
 
 
446
Here is a second exercise. This one involves writing functions, and has multiple parts. The test suite will test each part individually.
 
447
 
 
448
.. exercise:: factorial
 
449
', true, 0, 'rst');
 
450
 
 
451
 
 
452
ALTER TABLE worksheet ENABLE TRIGGER ALL;
 
453
 
 
454
--
 
455
-- Data for Name: worksheet_exercise; Type: TABLE DATA; Schema: public; Owner: -
 
456
--
 
457
 
 
458
ALTER TABLE worksheet_exercise DISABLE TRIGGER ALL;
 
459
 
 
460
INSERT INTO worksheet_exercise (ws_ex_id, worksheetid, exerciseid, seq_no, active, optional) VALUES (2, 1, 'hello', 0, true, false);
 
461
INSERT INTO worksheet_exercise (ws_ex_id, worksheetid, exerciseid, seq_no, active, optional) VALUES (1, 1, 'factorial', 0, true, false);
 
462
 
 
463
 
 
464
ALTER TABLE worksheet_exercise ENABLE TRIGGER ALL;
 
465
 
 
466
--
 
467
 
 
468
--
401
469
-- PostgreSQL database dump complete
402
470
--
403
471