Skip to content

KieraAllen/adopt_dont_shop_paired_2008

 
 

Repository files navigation

Adopt Don't Shop

BE Mod 2 Weeks 2 & 3 Paired Project

Turing School Project Background and Instructions

Includes:

  • Learning goals
  • Requirements
  • User stories
  • Rubric

Table of Contents

Introduction

Adopt Don't Shop was the project assigned to the 2008 Back End cohort during Module 2. Students were put into pairs and tasked with creating a fictitious pet adoption platform.

The adoption platform is designed to house and manipulate data for pets, shelters, users, applications, and reviews. Visitors can apply to adopt multiple pets and write reviews for shelters. The site provided functionality for an admin user to approve or reject individual pets on a user's application, which results in acceptance or rejection of the application.

Statistics were another aspect of the platform and included the average rating of all a user's reviews, count of pets at an individual shelter, along with the average review rating for a shelter and number of applications for a shelter.

Demo

The app is deployed to Heroku here.

Features

  • Ruby 2.5.3
  • Rails 5.2.4.3
  • PostgreSQL
  • Heroku
  • ActiveRecord
  • Gems

Team Members

Jesse Mellinger - Github

Kiera Allen - Github

Adherence to Learning Goals

Rails

We used the MVC design pattern to organize our code, working to include appropriate logic within models, views, and controllers.

  • Models - our models were structures to house all our raw data logic, such as calculations and filtering or manipulating data without altering it.
  • Views - our views presented the data without much logic, using instance variables from our controllers along with methods from our models and the occasional conditional statement.
  • Controllers - after completing the user stories, we reviewed our controllers to confirm that there was little data manipulation, making changes and creating model instance methods as needed.

The following is an example of a change we implemented to adhere to MVC:

Controller BEFORE

class ApplicationsController < ApplicationController

  def show
    @application = Application.find(params[:id])

    if !params[:search].nil?
      @search_results = Pet.where('lower(name) like ?', "%#{params[:search].downcase}%")
    else
      @search_results = Pet.where(name: params[:search])
    end
  end
end

Controller AFTER

class ApplicationsController < ApplicationController

  def show
    @application = Application.find_application(params[:id])
    @search_results = Pet.find_all_pets_by_name(params[:search])
  end
end
  • We moved the conditional block from the controller and created a class method in our Pet model using a ternary operator (a one-line if statement).

Model AFTER

class Pet < ApplicationRecord
  def self.find_all_pets_by_name(name)
    name ? Pet.where('lower(name) like ?', "%#{name.downcase}%" : Array.new
  end
end

As requested by specific user stories, we used flash messages to alert a user to an error or missing information.

ActiveRecord

When creating queries that manipulated data in our models (e.g., calculating, selecting, filter, and ordering), we utilized ActiveRecord methods, first creating SQL queries to help us form the final ActiveRecord query structure.

Databases

Our database relationships are as follows:

  • Shelter class:

    • has_many :pets
    • has_many :reviews
  • User class:

    • has_many :reviews
    • has_many :applications
  • Review class:

    • belongs_to :shelter
    • belongs_to :user
  • Pet class:

    • belongs_to :shelter
    • has_many :pet_applications
    • has_many :applications, through: :pet_applications
  • Application class:

    • belongs_to :user
    • has_many :pet_applications
    • has_many :pets, through: :pet_applications
  • PetApplication class:

    • belongs_to :pet
    • belongs_to :application

Testing and Debugging

We started by writing integrative feature tests utilizing sad path testing, subsequently creating unit tests when we decided we needed a model class or instance method. We wrote additional model tests for validations and relationships.

Test Coverage

adopt-dont-shop-coverage

Web Applications

Throughout our construction of the app, we implemented proper Representational State Transfer style by confirming our routes contained the appropriate HTTP verbs, paths, and controllers/actions. There were only a couple examples of non-ReSTful routes that were created before we started this project.

Schema

Adopt Don't Shop Schema

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Ruby 89.6%
  • HTML 9.3%
  • Other 1.1%