Skip to content

N4M3L355/robomission

 
 

Repository files navigation

RoboMission

RoboMission is an intelligent web application for learning elementary programming, aiming at creating a flow experience. RoboMission is developed by Adaptive Learning group at Masaryk University.

Start working on the project

  1. Install Python 3.5, virtualenv, virtualenvwrapper and npm.

  2. Configure virtualenv and virtualenvwrapper by adding the following two lines in your ~/.bashrc:

     export WORKON_HOME=~/.virtualenvs
     export VIRTUALENVWRAPPER_PYTHON='/usr/bin/python3'
     source /usr/local/bin/virtualenvwrapper.sh
    

    The path to the virtualenvwrapper.sh might be different depending on the OS and the way you install it.

    Load the changes:

       $ source ~/.bashrc
    
  3. Clone the project repository:

     $ git clone https://github.com/adaptive-learning/robomission.git
    
  4. Create virtual environment and bind it with the project directory:

     $ cd robomission
     $ mkvirtualenv robomission && setvirtualenvproject
    

    The name of the virtual environment (robomission) should now appear in front of the prompt.

  5. Install dependencies and initialize DB:

     $ make install
    

    The make install command uses pip to install install backend dependencies, npm for frontend dependencies, and then it sets up the database for development. (See Makefile for details.) You can deactivate the virtual environment by calling deactivate.

  6. Create dummy file with secret keys:

     $ cp settings_secret_template.py settings_secret.py
    

Workflow

  1. Start the virtual environment and jump to the project directory:

     $ workon robomission
    
  2. Pull the changes from the repository.

     $ git pull
    
  3. Update dependencies and database:

     $ make update
    
  4. Create and checkout a git branch for the implemented feature.

     $ git checkout -b name_of_the_feature
    
  5. Write unit tests for the implemented feature (and possibly integration tests as well). Check that the tests don't pass.

     $ make test
    
  6. Develop the feature. Enjoy it, experience the state of flow :-)

  • To start a server:

      $ make server
    
  • To open python console (with all models automatically imported):

     $ make shell
    
  • To open jupyter notebooek:

     $ make notebook
    
  • To load new tasks (or other domain changes) to DB:

      $ make domain
    
  • If you change the data model, create and apply a migration:

      $ ./backend/manage.py makemigrations
      $ ./backend/manage.py migrate
    
  • Take a regular breaks and stretch yourself (including your eyes).

  1. Test the implemented feature and check the code by a linter:

     $ make test
     $ make lint
    
  2. Commit changes:

     $ git add changed_files
     $ git commit -m "Implement feature X"
    
  3. Merge the feature branch to the master branch:

    $ git checkout master
    $ git merge name_of_the_feature
    
  4. Push changes to the GitHub:

    $ git push
    
  5. Deactivate the virtual environment:

    $ deactivate
    
  6. Celebrate the developed feature with some physical exercise and healthy snack.

Docker alternative

  1. Install Docker and Docker Compose.

  2. Create settings_secret.py configuration file:

     $ cp backend/robomission/settings_secret_template.py backend/robomission/settings_secret.py 
    
  3. Build the container:

     $ docker-compose build
    
  4. Run the container in development friendly mode:

     $ docker-compose run web make liveserver
    

    This will run Django and Webpack simultaneously. Webpack will output network address for testing.

    Important files for development are linked(in docker-compose.yml). If you want to rerun setup, stop container and build it.

Tips

  • Use export SHOW_SQL_QUERIES=True to log all performed SQL queries. Environment variables can be also passed by make, e.g. make server SHOW_SQL_QUERIES=True.

About

Intelligent web app for learning programming

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Jupyter Notebook 47.3%
  • JavaScript 32.0%
  • Python 20.2%
  • Makefile 0.3%
  • HTML 0.2%
  • Dockerfile 0.0%