Skip to content
/ mwbase Public
forked from tperrier/mwachx

Base repo for a mobile SMS management application for maternal health

License

Notifications You must be signed in to change notification settings

uw-ictd/mwbase

 
 

Repository files navigation

Installation

You need to install [nodejs] first. nvm, the node analog to rvm can be useful for getting node installed.

You need Gulp installed globally:

$ npm i -g gulp

Clone the repo:

$ git clone https://github.com/tperrier/mwachx.git
$ cd mwachx

Install node dependencies

$ npm install --global gulp-cli bower

Install Javascript dependencies:

$ npm install

Behind the scenes this will also call bower install. You should find that you have two new folders in your project.

  • node_modules - contains the npm packages for the tools we need
  • mwbase/static/app/bower_components - contains the libraries (e.g., Angular) that we are relying on

Note: the bower_components folder would normally be installed in the root folder but we change this location through the .bowerrc file. Putting it in the static/app folder makes it easier to serve the files by a webserver.

Setup Python virtualenv and install dependencies

$ mkvirtualenv --no-site-packages mwachx
$ pip install -r requirements.txt

Setup your settings files

$ echo "from .settings_base import *" > mwach/local_settings_2.py

Setup database

# To reset the databae and create 20 new participants
$ ./tools/reset_db -n 20 

Start the backend and build the frontend with Gulp:

$ ./manage.py runserver
$ gulp

The default gulp command will start a livereload server on localhost:8000. The chrome extension is very useful.

Running tests

The project uses nose as a test runner. The easiest way to run tests is to just run ./manage.py test.

You can also use sniffer to run tests continually.

pip install sniffer
sniffer -x mwbase.tests -x -s

To fully test swappable models add the following lines to your local_settings.py

TEST_PARTICIPANT_SWAPPING = True
PARTICIPANTS_PARTICIPANT_MODEL = 'example.ExampleParticipant'
INSTALLED_APPS = INSTALLED_APPS + (
    'implementations.example',
)

Architecture

A high level architecture/overview document can be found here.

Project Todos

Support/upgrade to latest django (currently broken) Support/upgrade to latest djangorestframework (currently broken)

About

Base repo for a mobile SMS management application for maternal health

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 70.2%
  • HTML 14.9%
  • JavaScript 11.1%
  • CSS 3.7%
  • Shell 0.1%