Skip to content

Latest commit

 

History

History
134 lines (71 loc) · 3.85 KB

README.rdoc

File metadata and controls

134 lines (71 loc) · 3.85 KB

Welcome to Peer Group Supervision

Peer Group Supervision enables professionals to help each other.

Updates

This is the first version, heavy alpha.

Running the application

  1. Install required gems

bundle install

If you are using rvm, create new gemset to not mess with your default gems

  1. Setup configuration files

cp config/redis.yml.example config/redis.yml
cp config/database.yml.example config/database.yml
  1. Setup Redis

Run redis (download from redis.io/download) - tested on 2.0 and 2.2 stable releases

  1. Run node server

Instructions for installing node can be found at github.com/wolfgangihloff/peergroup-node

Clone peergroup-node repository:

git clone git://github.com/wolfgangihloff/peergroup-node.git

Run node server

node server.js
  1. Run the application

bundle exec rails server
  1. Open localhost:3000

Running tests

BIG WARNING:

As with test database, make sure that you run your tests on separate Redis database, as this will flush you data before tests.

Unfortunately Redis gem uses default url for connection (redis://localhost:6379), so if you don’t provide proper config (or use older gem than from master repository for Redis in case of unix socket), then instead of connecting to test database, your test environment could connect to other database and flush it all.

You have been warned!

  1. Install required gems

bundle install
  1. Setup database number in config/redis.yml or run separate redis server like this:

redis-server config/redis-test.conf
  1. Run Node server instance

REDIS_DB should be number that you specified in config/redis.yml

REDIS_DB=1 PGS_PORT=3666 node app-node/server.js

Eventually you can connect to separate instace of redis server (if running)

REDIS_DB=1 REDIS_PORT=6380 node app-node/server.js
  1. Run tests:

bundle exec rake spec

Note: If you encounter error during requests specs: Selenium::WebDriver::Error::ObsoleteElementError, try to use wait_until method.

Translations

Currently, the application is available in 2 languages: English and German. Default locale is set during the application boot, but is's possible to switch to different locale while application is running - just click link with locale name in the header.

To add missing translation for non-default locale:
  1. import all keys from primary locale file: rake tolk:sync

  2. importing non-primary locales: rake tolk:import

  3. start application in development mode, open up localhost:3000/tolk

  4. find your missing translation by english phrase or key without first part, so if you see: “translation missing for key en, supervisions, show, title”, then you need to search for “supervisions.show.title” key

  5. edit, and save, and when ready dump your translations: rake tolk:dump

To change the default locale edit aprropriate line in the environment file config/environments/production.rb or config/environments/development.rb. The line looks like:

# I18n.default_locale = :en

Other localized files are:
 * db/default_rules_<locale>.csv
 * app/views/pages/_about.<locale>.html.haml
 * app/views/pages/_help.<locale>.html.haml
 * README / LIESMICH

Deploying

It’s possible to run application on heroku.

To have your own instance on heroku:

  1. Install heroku client

    gem install heroku
    
  2. Create application

    heroku create --stack cedar my-peergroup-app-name
  3. Setup configuration variables

    heroku config:add NODE_PORT=80 NODE_USERNAME=node NODE_PASSWORD=secret NODE_PROTOCOL=http
* NODE_USERNAME/NODE_PASSWORD - credentials that will allow node server to connect
  1. Add redis addon

    heroku addons:add redistogo:nano
  2. Deploy code

    git push heroku master
    
Refer to heroku [docs](http://devcenter.heroku.com/articles/rails31_heroku_cedar) for more informations.
  1. Setup node server using REDISTOGO_URL - github.com/wolfgangihloff/peergroup-node#readme