-
Notifications
You must be signed in to change notification settings - Fork 516
Docker
Docker is a container platform that makes it easier to start a development environment with all the required dependencies.
To start you only need to have git
, docker
, and docker compose
installed. Everything else will be done via Docker itself.
Note: If you do not install the Desktop version of Docker, such as with a Linux-based OS, make sure to also install Docker Compose.
Fork the otwarchive repository on GitHub and then clone it and set up the original repository as a remote:
git clone [email protected]:YOURGITHUB/otwarchive.git
git remote add upstream [email protected]:otwcode/otwarchive.git
For security, you should modify the default database password before starting your local environment, unless you trust your firewall and everyone on your local network.
- In
config/docker/database.yml
, change the default DB password ("change_me"). - In
docker-compose.yml
, change the MySQL root password to the same value (also default "change_me").
In the shell of your choice, navigate to the repository root and run the initialization script.
For Unix-like systems such as Linux or macOS:
./script/docker/init.sh
Or for Windows:
script\docker\init.cmd
This will pull and build all required Docker images, copy all the required configuration files, run the initialization tasks (setting up the database, indexing for search, etc.) and finally start the Rails application.
When the script has finished, you should be able to access your archive by visiting http://localhost:3000/ in the browser of your choice.
Refer to Development Data for creating admin and user accounts in your development environment.
If you cannot access your archive there, you will likely end up needing to re-run the init script after fixing the issue--simply running docker compose up -d web
may appear to succeed while skipping critical steps.
An error like Error starting userland proxy: Bind for 0.0.0.0:3306 failed: port is already allocated
, on Linux, indicates that another service is running using a default port for one of the necessary docker containers. The first-line fix is to try docker container ls
and, if one of the listed containers is using the same port (0.0.0.0:3306
, here), shut that down with docker stop
. If no containers appear, it's a different service, often mysql
or redis
. Investigating this should use sudo netstat -p -nlp
and look for the port number (3306
), but BE CAREFUL - make sure you know what the process is before shutting it down, as killing arbitrary processes (with kill
) can damage your system.
If you're on Linux and the version of the archive that shows up on localhost seems to be missing a lot of the css, you may need to change the ownership of the files docker generated, as in the official Rails on Docker Compose example, and then re-run the init script. In particular it's the permissions of the files in public/system/skins/
that cause the css issue, but all files created by Docker are owned by root, and this can cause problems when trying to access them from within the container:
sudo chown -R $USER:$USER .
After the one-off initialization tasks have been run, to start up the container open your shell and use the following command:
docker compose up -d web
Then you will be able to access your archive by visiting http://localhost:3000/ in the browser of your choice.
You can start a Rails console in the development environment:
docker compose exec web bundle exec rails c
Or get a shell inside the container and execute commands as you would normally:
docker compose exec web bash
You can use docker compose ps
to see the currently running containers and docker compose logs web
to see the logs of the web container.
To stop docker again, execute docker compose --profile dev down
.
To create your search indexes (and fill them with data), you'll need to start the background workers.
In the commands below, note that the file paths, such as spec/models/unsorted_tag_spec.rb
, are examples. You will have to put in the correct file path to the tests you would like to run. If you would like to run all of the tests, use spec
for RSpec tests and features
for Cucumber tests.
To run RSpec tests:
# To run the specific test file spec/models/unsorted_tag_spec.rb
docker compose run --rm test bundle exec rspec spec/models/unsorted_tag_spec.rb
To run Cucumber tests:
# To run the specific test file features/tag_sets/tag_set.feature
docker compose run --rm test bundle exec cucumber features/tag_sets/tag_set.feature
To stop the containers for the testing profile, execute docker compose --profile test down
.
If there have been changes to the Dockerfile
setup (e.g. gem, Ruby updates), you'll need to rebuild the containers:
docker compose up --build --force-recreate --no-deps -d web test
If there have been changes that added database migrations, you need to the run the migrations for the dev db:
docker compose run --rm web bundle exec rails db:migrate
And the test db:
docker compose run --rm test bundle exec rails db:migrate
- If you haven't yet, start the application with
docker compose up -d web
. - Once the container is running, attach to it with
docker compose attach web
. - Add breakpoints with
require 'pry'; binding.pry
in the code. Once you hit the breakpoint, the terminal attached to the container will display apry
prompt ready for commands.
If you have any questions regarding code development, please don't hesitate to send an email to [email protected] and we will try to get back to you as soon as possible!
- Home
- Set Up Instructions
- Docker (All platforms)
- Gitpod (Cloud-based development)
- Linux
- OS X
- Creating Development Data
- Writing and Tracking Code
- Automated Testing
- Architecture
-
Getting Started Guide
- Getting Set Up
- Your First Pull Request
- More About Git
- Jira