We will walk through the steps, but at a high level, they are:
- Install Xcode
- Install Xcode's Command Line Tools
- Install Homebrew
- Install RVM (Ruby Version Manager)
- Install Ruby 1.9.3
- Install PostgreSQL
- Clone the source
- Create a gemset
- Install required libraries
- Create and migrate databases
- Contribute!
Now the detail.
Xcode is Apple's development environment for native applications. We need it for two minor things: git and a compiler. Git is included with the Command Line Tools, which is the next step.
Xcode is free from the Mac App Store, you just need an Apple ID.
- After Xcode is installed, open it and go to
Preferences...
. - Go to the Downloads section and select to install Command Line Tools (see screenshot below)
Homebrew is a tool for installing various dependencies and apps onto your computer. It installs with a shell command:
ruby -e "$(curl -fsSL https://raw.github.com/mxcl/homebrew/go)"
RVM is a tool for installing and managing different versions of Ruby, as well as creating "gemsets", self-contained environments for Ruby libraries that prevent subtle, hard-to-diagnose, hard-to-resolve problems when working on multiple Ruby projects. In short, RVM is a cheap solution to an expensive problem. You can install RVM by pasting this line into your terminal:
\curl -L https://get.rvm.io | bash -s stable
Now that RVM is installed, you need to import it into your shell:
source ~/.rvm/scripts/rvm
The production environment runs Ruby 1.9.3, so you should use that version during development as well. Having installed RVM, installing this version of Ruby is a pair of commands:
rvm install 1.9.3
rvm use --default 1.9.3
This project relies on a PostgreSQL database. On a Mac the simplest way to install Postgres is with Postgres.app. You can install it according to the guide on that website.
Depending on your version of OSX, your computer may complain that Postgres.app is not from the App Store. This is a well-intentioned move by Apple to make sure your computer isn't infected with malware...but in this case it's being too picky! If you encounter this dialog, right-click on Postgres.app and choose "Open", then choose the "Open" button on the dialog that asks you to confirm that you really want to run Postgres.
Now that you've installed Postgres.app, you have a weird and annoying problem: even though OSX doesn't ship with Postgres, it does ship with psql
, the command-line application that you use to interact with Postgres. However, the version of psql
that ships with OSX doesn't interact happily with Postgres.app. You need to add Postgres.app's bin
directory to the front of your PATH so that your terminal finds Postgres.app's version of psql
instead. Run this command at your command line, and then also add it to the end of your ~/.bash_profile
:
export PATH="/Applications/Postgres.app/Contents/Versions/9.3/bin:$PATH"
You can choose to install PostgreSQL in other ways, but you may have trouble getting ruby's pg
gem to find postgres.
It is best to create your own fork of this project to contribute to it. You can do that by clicking this here link. Now that you have your own fork, you can use git to get a copy of the source for this site (remember to replace <your-github-username>
with your actual Github username):
git clone [email protected]:<your-github-username>/green_mercury.git
cd green_mercury
git remote add upstream https://github.com/code-scouts/green_mercury.git
Note that the first command will fail if you have not yet set up ssh keys for Github. They provide an excellent guide to this, which you should follow if you need help. The full range of things you can do to the code using Git and Github is outside the scope of this document, but it is extensive. If you're new to Git and Github, try Github's interactive tutorial for a crash course.
Remember earlier, when we said RVM could create Gemsets, and they were important? Time to put that to work:
rvm gemset create green_mercury
rvm gemset use green_mercury
This project uses Bundler to manage its dependencies. That means it requires only a couple of commands to get all the code libraries you need:
gem install bundler
bundle install
Now that you have the dependencies installed, it's time to create the databases for the site. At your terminal run these two commands:
psql
create database green_mercury owner <me>;
create database green_mercury_test owner <me>;
commit;
\q
That creates a pair of empty databases, so you just need to set them up with the proper tables:
rake db:migrate
rake db:migrate RAILS_ENV=test
Whew! That was quite a bit of setup. Fortunately, most of it was one-time-only: If you want to contribute to another project you'll be able to skip most of what you did this time around.
Once you have some changes that you think will improve the site, commit them with git:
git commit -a -m "A brief summary of what you did"
git push origin
Then use the new-pull-request page to create a pull request so we can see your great work!