1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
|
Yaksh
=====
|Build Status| |Documentation Status| |Version Status| |Coverage Status|
To get an overview of the Yaksh interface please refer to the user documentation at `Yaksh Docs <http://yaksh.readthedocs.io>`_
This is a Quickstart guide to help users setup a trial instance. If you wish to deploy Yaksh in a production environment here is a `Production Deployment Guide <https://github.com/FOSSEE/online\_test/blob/master/README\_production.rst>`_
Introduction
============
This project provides an "exam" app that lets users take an online
programming quiz.
Features
========
- Define fairly complicated programming problems and have users solve
the problem.
- Immediate verification of code solution.
- Supports pretty much arbitrary coding questions in Python, C, C++, Java, R, Scilab and
Bash.
- Supports Multiple choice, Fill in the blanks, Arrange options and File upload based questions.
- Since it runs on Python, you could technically test any Python
based library.
- Create course with lessons and quiz for online learning.
- Almost real-time monitoring for quiz.
- Supports automatic and manual grading, regrading of quiz.
- Add grading system to the course.
- Scales to over 500+ simultaneous users.
- Distributed under the BSD license.
Requirements
============
Python 3.6, 3.7, 3.8
Django 3.0.3
Celery 4.4.2
Installation
============
**Note**: Currently, only Linux and MacOS is supported for the project.
If Python 3.6 and above is not available in the system, then we recommend using
miniconda. Download miniconda with Python 3.6 and above.
**Installing Miniconda**
1. Download miniconda from https://docs.conda.io/en/latest/miniconda.html according to the OS version.
2. Follow the installation instructions as given in https://conda.io/projects/conda/en/latest/user-guide/install/index.html#regular-installation
3. Restart the Terminal.
**Pre-Requisite**
* Install redis server
Redis is required for celery. Celery runs in background for regrading the papers.
::
sudo apt install redis-server (Debian/Ubuntu)
yum install redis (Centos)
* Start redis server
::
systemctl start redis
* Check redis server status
::
systemctl status redis
* Ensure `pip <https://pip.pypa.io/en/latest/installing.html>`_ is installed
**Installing Yaksh**
* **Clone the repository**
::
git clone https://github.com/FOSSEE/online_test.git
* **Go to the online_test directory**
::
cd online_test
* **Install the dependencies**:
* Install Django and dependencies
::
pip3 install -r requirements/requirements-common.txt
* Install Code Server dependencies
::
sudo pip3 install -r requirements/requirements-codeserver.txt
Quick Start
^^^^^^^^^^^
1. Start up the code server that executes the user code safely:
- To run the code server in a sandboxed docker environment, run the
command:
::
$ invoke start
- Make sure that you have Docker installed on your system
beforehand. `Docker
Installation <https://docs.docker.com/engine/installation/#desktop>`__
- To run the code server without docker, locally use:
::
$ invoke start --unsafe
- Note this command will run the yaksh code server locally on your
machine and is susceptible to malicious code. You will have to
install the code server requirements in sudo mode.
2. On another terminal, run the application using the following command:
::
$ invoke serve
- *Note:* The serve command will run the django application server
on the 8000 port and hence this port will be unavailable to other
processes.
3. Open your browser and open the URL ``http://localhost:8000/exam``
4. Login as a teacher to edit the quiz or as a student to take the quiz
Credentials:
- Student - Username: student \| Password: student
- Teacher - Username: teacher \| Password: teacher
5. User can also login to the Default Django admin using;
- Admin - Username: admin \| Password: admin
History
=======
At FOSSEE, Nishanth had implemented a nice django based app to test for
multiple-choice questions. Prabhu Ramachandran was inspired by a
programming contest that he saw at PyCon APAC 2011. Chris Boesch, who
administered the contest, used a nice web application
`Singpath <http://singpath.com>`__ that he had built on top of GAE that
basically checked your Python code, live. This made it fun and
interesting.
Prabhu wanted an implementation that was not tied to GAE and hence wrote
the initial cut of what is now 'Yaksh'. The idea being that anyone can
use this to test students programming skills and not have to worry about
grading their answers manually and instead do so on their machines.
The application has since been refactored and maintained by FOSSEE
Developers.
Contact
=======
For further information and support you can contact
Python Team at FOSSEE: pythonsupport@fossee.in
License
=======
This is distributed under the terms of the BSD license. Copyright
information is at the bottom of this file.
Authors
=======
`FOSSEE Developers <https://github.com/FOSSEE/online_test/graphs/contributors>`_
Copyright (c) 2011-2017 `FOSSEE <https://fossee.in>`_
.. |Build Status| image:: https://travis-ci.org/FOSSEE/online_test.svg?branch=master
:target: https://travis-ci.org/FOSSEE/online_test
.. |Documentation Status| image:: https://readthedocs.org/projects/yaksh/badge/?version=latest
:target: http://yaksh.readthedocs.io/en/latest/?badge=latest
.. |Version Status| image:: https://badge.fury.io/gh/fossee%2Fonline_test.svg
:target: https://badge.fury.io/gh/fossee%2Fonline_test
.. |Coverage Status| image:: https://codecov.io/gh/fossee/online_test/branch/master/graph/badge.svg
:target: https://codecov.io/gh/fossee/online_test
|