- [competition] after the competition ends, make all ctasks of an unlocked chain visible
- [competition] chains can now be restricted to selected teams
- [competition] submission count limit can be customized per-task now
- [competition] optionally make team categories non-configurable by teams themselves
- [competition] optionally hide team categories from teams themselves
- [competition] added a new "teams/participants/competitors" admin page, used to change team categories
- [competition] added
Chain.close_minutes, used to close the submission for a given chain after a given period of time - [competition] added an option to show per-category scoreboards
- [userprofile] added a registration challenge to fight spam
- [competition] individual (non-team) competitions and courses: adjusted the GUI based on
Competition.max_team_size - [competition] removed the confusing angle brackets in "<Write the question/message here>"
- [competition] using "unlock days" and "close days" not only for courses, but depending on the competition/course duration
- [general] improved the design of some forms by utilizing
bootstrap_toolkit - [general] added a "courses" link in the main menu, separately list competitions and courses
- [general] max length of text previews increased from 4 kB to ~100 kB
- [task] removed
Task.prerequisites, the ability to restrict the visibility of a task based on the completion of other tasks - [task] removed
Task.solution_settings, the ability to customize when task solution are accessible
- [general] improved the setup scripts and clarified the Docker-based installation instructions
- [competition] added some Cypress tests for competitions
- [competition] courses now use the
/course/<id>/URL pattern by default - [competition] courses and competitions URLs are automatically redirected to the correct URL (as returned by
get_absolute_url()) - [competition] made the solution help optional in the competition and course help pages
- [competition] split
views.pyinto multiple filesviews/*.py - [posts] changed the prefix of PostsForm to avoid
idcollision
Note: docker-based installation is work in progress. The docker files are not optimal nor secure for production.
The containers and the repository worktree are organized as follows:
- No shared volumes are used, thus the container contains the copies of source and other files (because of performance issues of shared volumes in Docker on certain systems).
- Instead, when developing, use
./docker/docker_rsync.shto continuously synchronize source files from the worktree to the container. Avoid editing source files directly in the container, because they will be overwritten by this script. - This includes
./skoljka/settings/local.py. Thus, if you want to have two different containers (two different instances of skoljka image), create another git worktree. - The
local/folder (media and other files) are stored only in the container. - This Docker setup should be considered a dev image, not a production or deploy image. Concretely, any changes to the JavaScript or SCSS files requires running the build script from within the container.
To set up the container, first build the image and start the container:
./docker/docker_build.sh skoljka-image-name
./docker/docker_mount.sh skoljka-image-name skoljka-container-nameFrom outside the container, run the following to prepare the worktree (i.e. local.py) and start synchronizing the container with the worktree:
./docker/setup_external.sh
./docker/docker_rsync.sh skoljka-container-nameIn another terminal, open a terminal in the container:
docker exec -it skoljka-container-name /bin/bash(If this command looks stuck, press enter to see the interactive shell.)
Within the container, run the following:
cd /app
./docker/setup_internal.shTo run skoljka, run
cd /app
python2 manage.py runserver 0.0.0.0:8000The webserver is accessible at http://localhost:8000/ .
To stop running the container, run:
docker stop skoljka-container-name
To resume the container, run:
# Outside the container.
docker start skoljka-container-name
# Within the container.
service mysql start # Sometimes fails on the first try.
mysqlcheck --repair --all-databases # Sometimes needed.# Install outside of the Python environment, to get the newest version.
python3 -m pip install pre-commit
pre-commit installThis procedure is based on the following tutorial: http://michal.karzynski.pl/blog/2013/06/09/django-nginx-gunicorn-virtualenv-supervisor/
NOTE: Consider using Docker installation above. The following installation procedure might be broken.
- Go to your projects folder (e.g.
~/projects). Create and go to a virtual environment:
sudo apt-get install gettext git python2.7-dev python-virtualenv
virtualenv -p `which python2` skoljka
cd skoljka
echo -e "export PYTHONPATH=\$PWD:\$PWD/skoljka:\$PYTHONPATH\nexport PROD=true\n\nsource bin/activate" > profile
source profile- Clone skoljka and run the installation script:
git clone https://github.com/ikicic/skoljka.git
cd skoljka
scripts/install_dependencies.sh
scripts/setup.sh- Create an empty
UTF8database (use your username):
mysql -e "CREATE DATABASE skoljka CHARACTER SET utf8 COLLATE utf8_general_ci;" -u username -p-
Fill out
settings/local.py, at least the fields marked asREQUIRED. -
Initialize database and build:
python2 manage.py syncdb --noinput
python2 manage.py loaddata folders userprofiles
python2 build.pyYou can now use Django test server by running python2 manage.py runserver.
The database is pre-filled with superuser arhiva whose password is a.
Note that in settings/local.py the variable DEBUG is False by default, so static files won't be loaded correctly.
The following three sections are used only for running in the release mode.
You should now be in ~/projects/skoljka/skoljka/.
-
Run
cd ..to move to~/projects/skoljka/. -
Create file
runserver.sh. (fill out user and group variables)
#!/bin/bash
set -e
PORT=8079 # Internal port for non-static files
LOGFILE=logs/skoljka.log
NUM_WORKERS=3
# user/group to run as
USER=""
GROUP=""
source profile
exec gunicorn skoljka.wsgi:application -w $NUM_WORKERS \
--user=$USER --group=$GROUP --log-level=debug \
--log-file=$LOGFILE -b localhost:$PORT- Set up
gunicorn.
chmod +x runserver.sh
mkdir -p logs
pip install gunicorn- Run the following commands:
sudo apt-get install supervisor
touch logs/gunicorn_supervisor.log- Create file
/etc/supervisor/conf.d/skoljka.conf(usesudo, and change these paths)
[program:skoljka]
directory = /home/username/projects/skoljka/
command = /home/username/projects/skoljka/runserver.sh
user = username
stdout_logfile = /home/username/projects/skoljka/logs/gunicorn_supervisor.log
stderr_logfile = /home/username/projects/skoljka/logs/gunicorn_supervisor.log
- Run
skoljkaDjango webserver:
sudo supervisorctl reread
sudo supervisorctl update
sudo supervisorctl restart skoljka- Install and start
nginx:
sudo apt-get install nginx
sudo service nginx start-
Create
/etc/nginx/sites-available/skoljkaand the symlink/etc/nginx/sites-enabled/skoljkato the first file. Use e.g.8080as the main port and remember to redirect/to the port8079. Look at the tutorial for the details. -
Restart
nginx
sudo service nginx restartThe syntax to restrict which tests are executed:
python2 manage.py test --noinput competition.ChainSortingTest.test_custom_orderingTo run the E2E tests, first launch the test server in the Docker container:
python2 manage.py testserver --noinput --traceback --addrport=0.0.0.0:8000 skoljka/userprofile/fixtures/test_userprofiles.json skoljka/folder/fixtures/test_folders.jsonThen, run the tests:
npx cypress runOr, launch the GUI with:
npx cypress open