diff --git a/Running-Mastodon/Development-guide.md b/Running-Mastodon/Development-guide.md index 4b2431e..953029a 100644 --- a/Running-Mastodon/Development-guide.md +++ b/Running-Mastodon/Development-guide.md @@ -3,6 +3,8 @@ Development guide **Don't use Docker to do development**. It's a quick way to get Mastodon running in production, it's **really really inconvenient for development**. Normally in Rails development environment you get hot reloading of backend code and on-the-fly compilation of assets like JS and CSS, but you lose those benefits by compiling a Docker image. If you want to contribute to Mastodon, it is worth it to simply set up a proper development environment. +## Linux + In fact, all you need is described in the [production guide](Production-guide.md), **with the following exceptions**. You **don't** need: - Nginx @@ -45,6 +47,78 @@ You can check code quality with: rubocop +## Mac + +These are self-contained instructions for setting up a development environment on a macOS system. It is assumed that you’ve cloned your fork of Mastodon to a local working directory and that you are in Terminal and in that directory. + +### Prerequisites + +- Get [Xcode](https://developer.apple.com/xcode/) Command Line Tools: + + ``` + xcode-select install + ``` + +- Get [Homebrew](https://brew.sh) and use it to install the other dependencies: + + ``` + brew install imagemagick ffmpeg yarn postgresql redis rbenv nodejs + ``` + +- Configure Rbenv: + + ``` + rbenv init + rbenv install 2.4.1 + ``` + +- Install/configure bundler to use your local rbenv: + + ``` + gem update --system + gem install bundler + rbenv rehash + ``` + +- Configure [PostgreSQL](https://www.postgresql.org): + + ``` + initdb /usr/local/var/postgres -E utf8 + createdb + export PGDATA=/usr/local/var/postgres + /usr/local/bin/postgres + /usr/local/bin/psql + ``` + + In the prompt: + + ``` + CREATE USER mastodon CREATEDB; + \q + ``` + +### Installation + +``` +bundle install --with development +yarn install --pure-lockfile +gem install foreman --no-ri --no-rdoc +bundle exec rails db:setup +bin/rails assets:precompile +``` + +### Running + +In separate Terminal windows/tabs: + +1. Start PostgreSQL: `/usr/local/bin/postgres` +2. Start Redis: `redis-server` +3. Start Mastodon (from the Mastodon folder): `foreman start` + +Go to http://localhost:3000 to see your development instance. + +Admin account is `admin@localhost:3000`. Password is `mastodonadmin`. + ## Development tips You can use a localhost->world tunneling service like [ngrok](https://ngrok.com) if you want to test federation, **however** that should not be your primary mode of operation. If you want to have a permanently federating server, set up a proper instance on a VPS with a domain name, and simply keep it up to date with your own fork of the project while doing development on localhost.