ensl.org/DEVELOPMENT.md

98 lines
3.8 KiB
Markdown
Raw Normal View History

# Development
Install instructions in INSTALL.md
2020-04-11 12:44:57 +00:00
## Basic commands for development
2020-04-11 12:44:57 +00:00
Load env variables (don't skip this step):
source script/env.sh .env .env.development
2020-03-31 18:46:49 +00:00
Start:
docker-compose up --build development`
2020-03-31 18:46:49 +00:00
Build or rebuild:
docker-compose build`
2020-03-25 23:34:52 +00:00
2020-03-31 18:46:49 +00:00
Debug:
docker attach ensl_development
2020-03-31 18:46:49 +00:00
2020-03-22 17:44:09 +00:00
To get inside docker web+test containers:
2020-03-23 03:24:44 +00:00
2020-04-10 16:57:08 +00:00
docker-compose exec -u root development /bin/bash`
docker-compose exec -u web development /bin/bash`
docker-compose exec -u root test /bin/bash`
docker-compose exec -u web test /bin/bash`
2020-03-23 03:24:44 +00:00
2020-03-22 17:44:09 +00:00
Restart the web container
2020-03-23 03:24:44 +00:00
docker-compose restart web`
2020-03-23 03:24:44 +00:00
2020-03-22 17:44:09 +00:00
Run some tests:
2020-03-23 03:24:44 +00:00
docker-compose exec -u web test bundle exec rspec`
docker-compose exec -u web test bundle exec rspec spec/controllers/shoutmsgs_controller_spec.rb`
2020-04-11 12:44:57 +00:00
## Unresolved issues for dev
2020-04-10 16:57:08 +00:00
There are some unresolved issues to setup dev env.
1. Make sure tmp, tmp/sockets, tmp/pids and log exist.
1. Make sure docker has access to its dirs. You might have to `sudo chown -R 999:999 for` for `db/data` if you have permission issues with docker.
2020-04-11 12:44:57 +00:00
1. You might have to run migrations manually. `bundle exec rake db:migrate`
2020-04-10 16:57:08 +00:00
## Tips
1. If you need to run stuff on your host (eg. ruby, rubocop, bundle install etc) run all commands from the: `Dockerfile.dev`. It should setup identical setup for your machine.
1. Add docker container names to /etc/hosts. This makes it possible to run test from local machine without using the container since editor/IDE don't integrate with Docker so well.
sudo echo `docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' ensl_dev_db` db >> /etc/hosts
1. VS Code and RubyMine are great IDE's/editors.
1. To run VS Code plugin Ruby Test Explorer in docker container you need to create path to custom path, copy the formatter and it whines about and it [still fails a bit](https://github.com/connorshea/vscode-ruby-test-adapter/issues/21).
2020-04-11 12:44:57 +00:00
1. You can run tests easier if you setup the stuff on your own computer.
1. Do not commit too much without testing. Also keep commits small for documentation and reversability issues.
1. You need to rebuild the docker image when you change gems.
## Design of ENSL Application
Read this to understand design decisions and follow them!
1. Env variables should be used everywhere and loaded from .env* files using Dotenv
2020-04-11 12:44:57 +00:00
* Load order is in [here]|(https://github.com/bkeepers/dotenv#what-other-env-files-can-i-use)
* Local changes go to .env*local and NOT .env
* Passwords are in ENV variables for now so they don't have to duplicated between DB and Rails.
1. Everything should be running on containers.
2020-04-11 12:44:57 +00:00
* Docker-compose is the heart of deployment
* Dockerfile should contain the gems and prebuilt assets for production
* The app contents are added to the docker image *on build* but it is mounted as **volume**. It will override the Dockerfile content.
1. The public directory contains everything public. NGINX will try to find files there and ask from PUMA if it doesn't.
* The local public directories (images, files, icons, avatars etc.) are to be addeed to .gitignore
* Assets are compiled on-fly in development mode.
* In production/staging etc. assets are precompiled and stored. Entry script can do this.
## Tags in code
FIXME, TODO, EXPLAIN, OBSOLETE
## TODO issues for dev
1. Puma should be running (eg. spring), and if debugger is used it should be able to connect via docker-compose up
1. Should directories exist?
1. docker-compose has some .env specific vars and then
## Best practices
Take a look at these before writing anything.
1. https://nvie.com/posts/a-successful-git-branching-model/
1. https://docs.docker.com/develop/develop-images/dockerfile_best-practices/
1. https://github.com/rubocop-hq/ruby-style-guide
1. https://rails-bestpractices.com/
1. http://www.betterspecs.org/
1. https://github.com/rubocop-hq/rspec-style-guide
1. Run rubocop