Skip to content

Latest commit

 

History

History
104 lines (77 loc) · 6.01 KB

README.md

File metadata and controls

104 lines (77 loc) · 6.01 KB

Bookkeeper Portal — 🟦 Edition

dev branch: CI & CD , deployed staging app: Heroku

main branch: CI & CD , deployed app: Heroku

License: MIT

A web application for keeping track of items and loaning them out, written in Ruby on Rails. Created in the Scalable Software Engineering course at the HPI in Potsdam.

Branch Naming

Branch names have the following structure: <type>/<team>-<issue-number>-<issue-name>

  • <type> gets replaced with feature or fix, depending on the type of changes introduced by the branch

  • <team> gets replaced with the abbreviation (e.g. BR) of the team that mostly develops on the branch

  • <issue-number> gets replaced with the number of the issue the branch aims to close

  • <issue-name> gets replaced with the name of the issue the branch aims to close, or a shortened form of it

Experimental branches may use the structure experimental/<anything>

Development Setup

Ensure you have access to a Unix-like environment through:

Application Setup

  • ruby --version Ensure Ruby v2.7.4 using rbenv or RVM
  • sqlite3 --version Ensure SQLite3 database installation
  • bundle --version Ensure Bundler installation (gem install bundler)
  • bundle config set without 'production' && bundle install Install gem dependencies from Gemfile
  • rails db:migrate Setup the database, run migrations
  • rails assets:precompile && rails s Compile assets & start dev server (default port 3000)
  • bundle exec rspec --format documentation Run the tests (using RSpec framework)

Developer Guide

Employed Frameworks

Cheat Sheets

Setup

  • bundle exec rails db:migrate RAILS_ENV=development && bundle exec rails db:migrate RAILS_ENV=test Migrate both test and development databases
  • rails assets:clobber && rails assets:precompile Redo asset compilation

Testing

  • bundle exec rspec Run the full test suite
    • --format doc More detailed test output
    • -e 'search keyword in test name' Specify what tests to run dynamically
    • --exclude-pattern "spec/features/**/*.rb" Exclude feature tests (which are typically fairly slow)
  • bundle exec rspec spec/<rest_of_file_path>.rb Specify a folder or test file to run
  • bundle exec rspec --profile Examine run time of tests
  • Code coverage reports are written to coverage/index.html after test runs (by simplecov)

Linting

  • bundle exec rubocop Use the static code analyzer RuboCop to find possible issues (based on the community Ruby style guide).
    • --autocorrect to fix what can be fixed automatically.
    • RuboCop's behavior can be controlled using .rubocop.yml

You can put the following script in .git/hooks/pre-commit to run RuboCop before each commit (run chmod +x .git/hooks/pre-commit to make it executable):

#!/bin/bash

# Exit if one of the following commands fails
set -e

# The branch we want to diff against
BASE=$(git merge-base origin/dev HEAD)

# Find all changed ruby files
FILES=$(git diff --name-only --diff-filter=d ${BASE} HEAD '*.rb')

# Execute Linters
bundle exec rubocop --force-exclusion --parallel $FILES

Debugging

  • debug anywhere in the code to access an interactive console
  • save_and_open_page within a feature test to inspect the state of a webpage in a browser
  • rails c --sandbox Test out some code in the Rails console without changing any data
  • rails dbconsole Starts the CLI of the database you're using
  • bundle exec rails routes Show all the routes (and their names) of the application
  • bundle exec rails about Show stats on current Rails installation, including version numbers

Generating

  • rails g migration DoSomething Create migration _db/migrate/*DoSomething.rb
  • rails generate takes a --pretend / -p option that shows what will be generated without changing anything