-
Notifications
You must be signed in to change notification settings - Fork 129
Setup Local Competitions
- Install the prerequisites
- Get the source code
- Configure your local environment
- Install app schema and default data
- Configure the Bundle Service to run Locally
- Start the web server
- Start the worker role
-
Fork the CodaLab repo from GitHub.
-
Clone your fork.
git clone https://github.com/<username>/codalab.git
For more details and recommended practices, see Developer Guidelines.
In this segment, you will run the dev_setup script. This will install all dependencies and create a new virtual environment (venv) for CodaLab.
-
Run the dev_setup script.
Windows
cd codalab .\dev_setup.bat
If you are going to use SQL Server as a database, you will need to install the Python PyODBC library. Before running
dev_setup
, you can download the installer, then run the setup script as follows (assuming the installer was downloaded at the root of a D drive):cd codalab dev_setup.bat D:\pyodbc-3.0.7.win-amd64-py2.7.exe
Linux
cd codalab source ./dev_setup.sh
-
Activate the virtual environment.
Windows
venv\Scripts\activate
Linux
source venv/bin/activate
Using virtualenvwrapper
mkvirtualenv -p python2 codalab
workon codalab
pip install -r ./codalab/requirements/dev.txt
Now you are ready to install the application schema and default data into the database.
You can configure CodaLab to use either SQL Server or MySQL. Both of these require you to explicitly create a database.
Follow these steps to install MySQL Python.
Windows
-
Open a Windows command prompt.
-
Navigate to the virtual environment (venv) for CodaLab and use the following command to install MySql-Python.
easy_install mysql-python
-
Launch the MySQL Command Line Client.
-
Use the following command to create a new database:
create database if not exists MySQL_DevDB;
Linux
-
Open a terminal window.
-
Run the following command to install MySQL:
sudo apt-get install mysql-server
-
Login to MySQL as root by typing the following command:
mysql -u root -p
Enter your root password when prompted. -
Use the following command to create a new database:
create database if not exists MySQL_DevDB;
-
Type
exit
to return to the terminal prompt.
Mac
-
Open a terminal window.
-
Login to MySQL as root by typing the following command:
mysql -u root -p
Enter your root password when prompted. -
Use the following command to create a new database:
create database if not exists MySQL_DevDB;
-
Type
exit
to return to the terminal prompt. -
Finish up installation for Django
export DYLD_LIBRARY_PATH=/usr/local/mysql/lib:$DYLD_LIBRARY_PATH
We provide a docker compose file to start MYSQL database. With docker
installed, run:
docker-compose up
The local configuration file local.py
tells CodaLab which type of database you are using, and stores credentials for the database.
-
Follow these instructions to set up Azure bundle storage: [Set Up Data Storage] (https://github.com/codalab/codalab/wiki/Dev_Set-up-data-storage). Should be done before proceeding.
-
Open
codalab/codalab/settings/local_sample.py
. -
Save a copy of
local_sample.py
namedlocal.py
in the same directory. Naming is important, since CodaLab will recognizelocal.py
. -
Open
local.py
. -
In the
DATABASES
section, enter the configuration settings for the database you want to use.SQL Server*
DATABASES = { 'default': { 'ENGINE': 'sql_server.pyodbc', 'NAME': 'somename', # Leaver user and password blank to use integrated security 'USER': '', 'PASSWORD': '', 'HOST': '(localdb)\\v11.0', 'PORT': '', 'OPTIONS': { 'driver': 'SQL Server Native Client 11.0', } }
MySQL
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'MySQL_DevDB', 'USER': 'someuser', 'PASSWORD': 'somepassword', 'HOST': 'someserver', # Empty for localhost through domain sockets or '127.0.0.1' for localhost through TCP. 'PORT': '', # Set to empty string for default. }
Note: If you want to use MySQL you'll need to manually install it and create a database before proceeding. CodaLab setup does not install MySQL.
To initialize the database, you will need to run a few standard Django commands, and the CodaLab database initialization script.
- validate: Validates all installed models (according to the INSTALLED_APPS setting) and prints validation errors to standard output.
-
syncdb: Synchronizes the database state with the current set of models and migrations (note that the
migrate
option is used). - initialize.py: Inserts initial data into the database.
-
Run the following commands to initialize the database.
Windows
cd codalab python manage.py validate python manage.py syncdb --migrate python scripts\initialize.py
Linux
cd codalab python manage.py validate python manage.py syncdb --migrate python scripts/initialize.py
-
Run tests to verify that everything is working.
python manage.py test
-
Optional: Populate the site with some sample data.
Windows
python scripts\users.py python scripts\competitions.py
Linux
python scripts/users.py python scripts/competitions.py
-
Use the following command to start the CodaLab server locally.
python manage.py runserver
-
Open a browser and navigate to http://127.0.0.1:8000 to preview the site.
-
When your next coding session comes along, remember to work in the virtual environment you created:
Windows
venv\Scripts\activate
Linux
source venv/bin/activate
Note: If you experience database errors try deleting the database file (\codalab\codalab\dev_db.*) and run syncdb again. After creating a new database be sure to run initialize.py
in the scripts
folder in order to insert initial data required by the app.
In order to test competitions and bundles locally, you'll need to run the compute worker roles. There are two worker.py
scripts that you will need to run.
-
Open a command prompt and activate your CodaLab virtual environment.
-
Start the first compute worker as shown here:
cd codalab python worker.py
-
Open a second command prompt and activate your CodaLab virtual environment.
-
Start the second compute worker as shown here:
cd codalabtools\compute python worker.py