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

« back to all changes in this revision

Viewing changes to doc/man/sample.rst

  • Committer: stevenbird
  • Date: 2007-12-05 22:41:05 UTC
  • Revision ID: svn-v3-trunk0:2b9c9e99-6f39-0410-b283-7f802c844ae2:trunk:7
GPL license

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
.. IVLE - Informatics Virtual Learning Environment
2
 
   Copyright (C) 2007-2009 The University of Melbourne
3
 
 
4
 
.. This program is free software; you can redistribute it and/or modify
5
 
   it under the terms of the GNU General Public License as published by
6
 
   the Free Software Foundation; either version 2 of the License, or
7
 
   (at your option) any later version.
8
 
 
9
 
.. This program is distributed in the hope that it will be useful,
10
 
   but WITHOUT ANY WARRANTY; without even the implied warranty of
11
 
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
 
   GNU General Public License for more details.
13
 
 
14
 
.. You should have received a copy of the GNU General Public License
15
 
   along with this program; if not, write to the Free Software
16
 
   Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
17
 
 
18
 
.. _sample-data:
19
 
 
20
 
***********
21
 
Sample data
22
 
***********
23
 
 
24
 
IVLE comes with supplied sample data to give a quick overview of the system.
25
 
This sample data may be installed by an administrative script. It should not
26
 
be installed in a production environment.
27
 
 
28
 
The sample data consists of database entries, for populating sample subjects,
29
 
offerings, users, projects, groups and worksheets, as well as some sample
30
 
files in users' Subversion repositories.
31
 
 
32
 
Installing the sample data
33
 
==========================
34
 
 
35
 
The data is stored in an SQL dump file, in ``examples/db/sample.sql``.
36
 
 
37
 
You must import this data into a **fresh** IVLE database. If you already have
38
 
a working IVLE install, it will have to be erased. A script is provided
39
 
which performs the following tasks:
40
 
 
41
 
* Unmounts all users with accounts in the current database,
42
 
* Drops the IVLE database if it already exists (prompting first),
43
 
* Creates and initialises a new IVLE database, as per :ref:`database-setup`,
44
 
* Populates the database with the sample data,
45
 
* Creates data directories and subversion repositories for all users, backing
46
 
  up directories for any existing users.
47
 
 
48
 
The script is executed with the following command from the IVLE source
49
 
directory::
50
 
 
51
 
    sudo ivle-loadsampledata examples/db/sample.sql
52
 
 
53
 
.. warning:: This script essentially destroys all contents in an existing IVLE
54
 
   installation. Be sure you wish to do this.
55
 
 
56
 
.. note:: The script may fail at the "dropping database" phase if Apache or
57
 
   another process are using the database. It is best to *restart* (not stop)
58
 
   Apache before executing the script (``sudo /etc/init.d/apache2 restart``).
59
 
 
60
 
   If the database exists, but is not properly initialised, then the script
61
 
   may fail. In this case, you should manually run ``ivle-mountallusers -u``,
62
 
   then drop the database, to ensure a clean build.
63
 
 
64
 
   If there are any existing users (including sample users from previous runs
65
 
   of the script), their files and subversion repos will be moved out of the
66
 
   way to a backup location, ``/var/lib/ivle/jails-removed-<date>/``.
67
 
   If you run this script regularly, your ``/var/lib/ivle/`` will become full
68
 
   of these backups, so you may wish to remove them often. However, they are
69
 
   typically fairly small (a few hundred kilobytes each), because they only
70
 
   contain user content, not the full jail image.
71
 
 
72
 
What is included
73
 
================
74
 
 
75
 
Subjects, semesters and offerings
76
 
---------------------------------
77
 
 
78
 
There are four semesters in the database: 2009 semesters 1 and 2, and 2010
79
 
semesters 1 and 2.
80
 
 
81
 
.. note:: We pretend that we are in 2009 semester 2 (even if that doesn't
82
 
   agree with the system clock). Therefore, 2009 semester 1 is a "past
83
 
   semester", 2009 semester 2 is the "current semester", and the 2010
84
 
   semesters are "future semesters."
85
 
 
86
 
There are four subjects in the database, with subject short names ivle-101,
87
 
ivle-102, ivle-201 and ivle-202.
88
 
 
89
 
The subjects have offerings for some of the semesters, as shown in this table:
90
 
 
91
 
+------+----------+-----------+
92
 
| Year | Semester | Subject   |
93
 
+======+==========+===========+
94
 
| 2009 | 1        | ivle-101  |
95
 
+------+----------+-----------+
96
 
| 2009 | 2        | ivle-102  |
97
 
+------+----------+-----------+
98
 
| 2010 | 1        | ivle-101  |
99
 
+------+----------+-----------+
100
 
| 2010 | 1        | ivle-201  |
101
 
+------+----------+-----------+
102
 
| 2010 | 2        | ivle-102  |
103
 
+------+----------+-----------+
104
 
| 2010 | 2        | ivle-202  |
105
 
+------+----------+-----------+
106
 
 
107
 
Users
108
 
-----
109
 
 
110
 
There are five users (username/password). Note that in all cases, the password
111
 
is "password".
112
 
 
113
 
* admin/password: This user has administrative rights over the entire system.
114
 
* lecturer/password: This is a normal user, but is enrolled as a lecturer in
115
 
  100101 (2009 semester 1) and 100102 (2009 semester 2).
116
 
* tutor/password: This is a normal user, but is enrolled as a tutor in
117
 
  100102 (2009 semester 2).
118
 
* studenta/password: This is a normal user, enrolled in 100101 (2009 semester
119
 
  1) and 100102 (2009 semester 2).
120
 
* studentb/password: This is a normal user, enrolled in 100102 (2009 semester
121
 
  2). This student has not yet accepted the Terms of Service, so does not have
122
 
  a jail created, etc.
123
 
 
124
 
.. note:: For the first three users, the Subversion password is also
125
 
   "password". This means it is possible to access their SVN repository
126
 
   with a stand-alone SVN client with that password. This is somewhat
127
 
   unrealistic, as the SVN password in IVLE is usually a randomly-generated
128
 
   string, not related to the user's IVLE login password.
129
 
 
130
 
   When studentb logs in for the first time, his SVN repository is created,
131
 
   and given a random password.
132
 
 
133
 
Files
134
 
-----
135
 
 
136
 
The repository for user "studenta" has a few sample files. All of the
137
 
directories must be checked out (using the Checkout button) before the files
138
 
can be seen from the IVLE application.
139
 
 
140
 
* In the :file:`stuff` directory is a sample file, :file:`hello.py`. This is a
141
 
  simple Python script, which can be executed with the "Serve" command.
142
 
 
143
 
Projects
144
 
--------
145
 
 
146
 
The subject 100102 has two project sets and three projects. This demonstrates
147
 
the relationship between project sets and projects.
148
 
 
149
 
The first project set is a solo project set (every student works by
150
 
themselves on all projects). It has one project in it.
151
 
 
152
 
The second project set is a group project set, for groups of 3. That means
153
 
students work in the *same* group of 3 for every project in the set. It has
154
 
two projects in it, demonstrating that the students get to keep their group
155
 
(including all of the group files) across the two projects in this set.
156
 
 
157
 
Finally, there is a single group for projects 2 and 3, which has the students
158
 
studenta and studentb enlisted.
159
 
 
160
 
Worksheets
161
 
----------
162
 
 
163
 
There are not yet any worksheets.
164
 
 
165
 
Exercises
166
 
---------
167
 
 
168
 
There is currently a single exercise, ``factorial``, which prompts the user to
169
 
write a factorial function and tests its correctness.
170
 
 
171
 
Updating the sample data
172
 
========================
173
 
 
174
 
For developers: If you need to update the sample data, follow this procedure.
175
 
 
176
 
Run the following command::
177
 
 
178
 
    pg_dump --schema=public --disable-triggers --data-only --column-inserts \
179
 
        --inserts --no-owner ivle > examples/db/sample.sql
180
 
 
181
 
Then check the diff. You may hand-edit the SQL file, but only for the purpose
182
 
of fixing up unsightly data -- it should be possible to reload from the script
183
 
and re-export with no diff.