- We don't want to expose database ids which suggests sequencies (ex: User id 1, 2, 3) and that's why we use
external_id
to reference the database record externally. - Because of the time I used Rails API mode with Heroku, but it also would have a great fit on AWS Serveless Stack: Ruby (with no Rails) running on Lambda API Gateway RDS RDS Proxy (In case we have too many parallel connections on the database).
- Because of time I won't integrate Swagger. I'll attach one Postman collection instead.
- I won't implement Rubocop on this project but I would in real project.
- CI Is fully implemented with Github Actions and Heroku Webhooks.
- I'm going to use a paid dyno in Heroku so you guys will be saved from the boot up time. So please let me know once you finished your review so I can disabled the payed dynos. :)
I'm looking forward to discuss the code and explain why I toke some technical decisions :)
Run in Postman
Just import the postman collection file at the root folder from the project.
BooksManager API application
- Rails 6.1.0 (latest stable version)
- Ruby 3.0.0 (latest stable version)
- Docker and Docker Composer [recommended]
When not running with Docker:
- PostgreSQL 11 or newer
git clone [email protected]:diegocharles/books-manager-api.git
cd books-manager-api
docker-composer up
- wait ....
docker-composer exec web bundle exec rails db:schema:load
docker-composer exec web bundle exec rails db:migrate
docker-composer exec web bundle exec rails db:seed
Finally, you can view it into your browser: https://localhost:3001
- You can access the container shell by:
docker-composer exec web bash
- You can access the Rails Console via shell as demonstrated above or:
docker-composer exec web bundle exec rails c
- To run the Specs:
docker-composer exec web rspec
In case of troubles Just ping Diego Charles via email: [email protected]
- Database Secrets
DATABASE_NAME: ''
DATABASE_ADAPTER: ''
DATABASE_ENCODING: ''
DATABASE_POOL: ''
DATABASE_USERNAME: ''
DATABASE_PASSWORD: ''
- Application Secrets
SECRET_KEY_BASE: ''
rails db:create
rails db:migrate
rails db:migrate RAILS_ENV=test
rails db:seed
- Use Rails 6 standards - RuboCop will enforce standards
- Rails Best Practices will enforce code quality
- Master should always be deployable and stable
- For each feature, task, or bug:
- Branch from Master
- Name your branch username/kind/feature-name
- Commits:
- At minimum a commit should be done at the end of every working day even if not finished.
- Commits should contain a comment that explains what was done.
- Each ticket should have a corresponding branch that is prefixed with the authors name and has the story name.
- Examples:
- If Vik worked on feature, "User Login", I would have a branch "vik/features/feature-user-login,
- If Anil worked on bug, "User Login Bug", it would be "anil/bug/bug-user-login".
- When a feature or bug is ready to merge you will make sure your branch is up to date with master, and then issue a pull request on Github.
- Make sure all your code is commited for your branch
- Change to master and do a git pull
- Switch back to your branch and "git rebase master -i"
- Squash all your WIP commits and make the feature a single commit.
- Push your branch to Github
- Create a pull request for your branch
- You should not merge your own pull requests into master unless it's an emergency.
- Another team member should review the pull request and do the merge if everything looks good.
- Code must be tested using RSpec.
- Code will be checked with RuboCop.
- Code will be checked with Rails Best Practices