Installation ============ * git clone * cd scrum-buddy * install gcc rubygems ruby-devel ruby-sqlite3 sqlite-devel * install bundler * bundle install * Edit config/config.yml with the correct email * Edit db/seeds.rb with team details * bundle exec rake db:migrate * bundle exec rake db:seed * crontab -e and copy the contents of scrumbuddy.cron, (make sure to edit path/to/scrumbuddy) * [sudo ]rails server -b <ip> [-p <port>] For Production setup ==================== * RAILS_ENV=production before bundle exec * crontab -e : Replace development with production Feel free to change or remove this file, it is informational only. Repo layout =========== tmp/ - Temporary storage public/ - Content (images, css, etc. available to the public) config.ru - This file is used by Rack-based servers to start the application. ../data - For persistent data .openshift/action_hooks/pre_build - Script that gets run every git push before the build .openshift/action_hooks/build - Script that gets run every git push as part of the build process (on the CI system if available) .openshift/action_hooks/deploy - Script that gets run every git push after build but before the app is restarted .openshift/action_hooks/post_deploy - Script that gets run every git push after the app is restarted Ruby Mirror =========== OpenShift is mirroring rubygems.org at http://mirror1.prod.rhcloud.com/mirror/ruby/ This mirror is on the same network as your application, and your gem download should be faster. To use the OpenShift mirror: Edit your Gemfile and replace source 'http://rubygems.org' with source 'http://mirror1.prod.rhcloud.com/mirror/ruby/' Edit your Gemfile.lock and replace remote: http://rubygems.org/ with remote: http://mirror1.prod.rhcloud.com/mirror/ruby/ Environment Variables ===================== OpenShift Express provides several environment variables to reference for ease of use. The following list are some common variables but far from exhaustive: ENV['OPENSHIFT_GEAR_NAME'] - Application name ENV['OPENSHIFT_GEAR_DIR'] - Application dir ENV['OPENSHIFT_DATA_DIR'] - For persistent storage (between pushes) ENV['OPENSHIFT_TMP_DIR'] - Temp storage (unmodified files deleted after 10 days) When embedding a database using 'rhc app cartridge add', you can reference environment variables for username, host and password: ENV['OPENSHIFT_DB_HOST'] - DB host ENV['OPENSHIFT_DB_PORT'] - DB Port ENV['OPENSHIFT_DB_USERNAME'] - DB Username ENV['OPENSHIFT_DB_PASSWORD'] - DB Password To get a full list of environment variables, simply add a line in your .openshift/action_hooks/build script that says "export" and push. Notes about layout ================== Every time you push, everything in your remote application path gets recreated please store long term items (like an sqlite database) in ../data which will persist between pushes of your repo. Rails 3.0 =========== Option 1) (Recommended) Git push your application Gemfile/Gemfile.lock. This will cause the remote OpenShift node to run bundle install --deployment to download and install your dependencies. Each subsequent git push will use the previously downloaded dependencies as a starting point, so additional downloads will be a delta. Option 2) Git add your .bundle and vendor/bundle directories after running 'bundle install --deployment' locally. Be sure to exclude any gems that have native code or ensure they can run on RHEL x86_64.