2 |
3 | <%= render 'form' %>
4 |
5 | <%= link_to 'Show', @pet %> |
6 | <%= link_to 'Back', pets_path %>
7 |
--------------------------------------------------------------------------------
/test/models/pet_test.rb:
--------------------------------------------------------------------------------
1 | require 'test_helper'
2 |
3 | class PetTest < ActiveSupport::TestCase
4 | # test "the truth" do
5 | # assert true
6 | # end
7 | end
8 |
--------------------------------------------------------------------------------
/app/views/pets/show.json.jbuilder:
--------------------------------------------------------------------------------
1 | json.extract! @pet, :id, :name, :colour, :owner_name, :identifying_characteristics, :special_instructions, :created_at, :updated_at
2 |
--------------------------------------------------------------------------------
/bin/rails:
--------------------------------------------------------------------------------
1 | #!/usr/bin/env ruby
2 | APP_PATH = File.expand_path('../../config/application', __FILE__)
3 | require_relative '../config/boot'
4 | require 'rails/commands'
5 |
--------------------------------------------------------------------------------
/config.ru:
--------------------------------------------------------------------------------
1 | # This file is used by Rack-based servers to start the application.
2 |
3 | require ::File.expand_path('../config/environment', __FILE__)
4 | run Rails.application
5 |
--------------------------------------------------------------------------------
/config/initializers/session_store.rb:
--------------------------------------------------------------------------------
1 | # Be sure to restart your server when you modify this file.
2 |
3 | PetThing::Application.config.session_store :cookie_store, key: '_pet-thing_session'
4 |
--------------------------------------------------------------------------------
/config/environment.rb:
--------------------------------------------------------------------------------
1 | # Load the Rails application.
2 | require File.expand_path('../application', __FILE__)
3 |
4 | # Initialize the Rails application.
5 | PetThing::Application.initialize!
6 |
--------------------------------------------------------------------------------
/config/boot.rb:
--------------------------------------------------------------------------------
1 | # Set up gems listed in the Gemfile.
2 | ENV['BUNDLE_GEMFILE'] ||= File.expand_path('../../Gemfile', __FILE__)
3 |
4 | require 'bundler/setup' if File.exist?(ENV['BUNDLE_GEMFILE'])
5 |
--------------------------------------------------------------------------------
/app/assets/stylesheets/pets.css.scss:
--------------------------------------------------------------------------------
1 | // Place all the styles related to the Pets controller here.
2 | // They will automatically be included in application.css.
3 | // You can use Sass (SCSS) here: http://sass-lang.com/
4 |
--------------------------------------------------------------------------------
/app/views/pets/index.json.jbuilder:
--------------------------------------------------------------------------------
1 | json.array!(@pets) do |pet|
2 | json.extract! pet, :id, :name, :colour, :owner_name, :identifying_characteristics, :special_instructions
3 | json.url pet_url(pet, format: :json)
4 | end
5 |
--------------------------------------------------------------------------------
/public/robots.txt:
--------------------------------------------------------------------------------
1 | # See http://www.robotstxt.org/robotstxt.html for documentation on how to use the robots.txt file
2 | #
3 | # To ban all spiders from the entire site uncomment the next two lines:
4 | # User-agent: *
5 | # Disallow: /
6 |
--------------------------------------------------------------------------------
/config/initializers/filter_parameter_logging.rb:
--------------------------------------------------------------------------------
1 | # Be sure to restart your server when you modify this file.
2 |
3 | # Configure sensitive parameters which will be filtered from the log file.
4 | Rails.application.config.filter_parameters += [:password]
5 |
--------------------------------------------------------------------------------
/config/initializers/mime_types.rb:
--------------------------------------------------------------------------------
1 | # Be sure to restart your server when you modify this file.
2 |
3 | # Add new mime types for use in respond_to blocks:
4 | # Mime::Type.register "text/richtext", :rtf
5 | # Mime::Type.register_alias "text/html", :iphone
6 |
--------------------------------------------------------------------------------
/app/controllers/application_controller.rb:
--------------------------------------------------------------------------------
1 | class ApplicationController < ActionController::Base
2 | # Prevent CSRF attacks by raising an exception.
3 | # For APIs, you may want to use :null_session instead.
4 | protect_from_forgery with: :exception
5 | end
6 |
--------------------------------------------------------------------------------
/Rakefile:
--------------------------------------------------------------------------------
1 | # Add your own tasks in files placed in lib/tasks ending in .rake,
2 | # for example lib/tasks/capistrano.rake, and they will automatically be available to Rake.
3 |
4 | require File.expand_path('../config/application', __FILE__)
5 |
6 | PetThing::Application.load_tasks
7 |
--------------------------------------------------------------------------------
/test/controllers/pet/steps_controller_test.rb:
--------------------------------------------------------------------------------
1 | require 'test_helper'
2 |
3 | class Pet::StepsControllerTest < ActionController::TestCase
4 | test "should get show" do
5 | get :show
6 | assert_response :success
7 | end
8 |
9 | test "should get update" do
10 | get :update
11 | assert_response :success
12 | end
13 |
14 | end
15 |
--------------------------------------------------------------------------------
/db/migrate/20140919000739_create_pets.rb:
--------------------------------------------------------------------------------
1 | class CreatePets < ActiveRecord::Migration
2 | def change
3 | create_table :pets do |t|
4 | t.string :name
5 | t.string :colour
6 | t.string :owner_name
7 | t.text :identifying_characteristics
8 | t.text :special_instructions
9 |
10 | t.timestamps
11 | end
12 | end
13 | end
14 |
--------------------------------------------------------------------------------
/db/seeds.rb:
--------------------------------------------------------------------------------
1 | # This file should contain all the record creation needed to seed the database with its default values.
2 | # The data can then be loaded with the rake db:seed (or created alongside the db with db:setup).
3 | #
4 | # Examples:
5 | #
6 | # cities = City.create([{ name: 'Chicago' }, { name: 'Copenhagen' }])
7 | # Mayor.create(name: 'Emanuel', city: cities.first)
8 |
--------------------------------------------------------------------------------
/app/views/layouts/application.html.erb:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 | PetThing
5 | <%= stylesheet_link_tag "application", media: "all", "data-turbolinks-track" => true %>
6 | <%= javascript_include_tag "application", "data-turbolinks-track" => true %>
7 | <%= csrf_meta_tags %>
8 |
9 |
10 |
11 | <%= yield %>
12 |
13 |
14 |
15 |
--------------------------------------------------------------------------------
/Gemfile:
--------------------------------------------------------------------------------
1 | source 'https://rubygems.org'
2 |
3 | ruby '2.1.2'
4 |
5 | # Bundle edge Rails instead: gem 'rails', github: 'rails/rails'
6 | gem 'rails', '4.0.5'
7 |
8 | # Use SCSS for stylesheets
9 | gem 'sass-rails', '~> 4.0.2'
10 | gem 'jquery-rails'
11 |
12 |
13 | gem 'wicked'
14 |
15 | group :development, :test do
16 | gem 'sqlite3'
17 | end
18 |
19 | group :production do
20 | gem 'pg'
21 | gem 'rails_12factor'
22 | end
23 |
--------------------------------------------------------------------------------
/test/fixtures/pets.yml:
--------------------------------------------------------------------------------
1 | # Read about fixtures at http://api.rubyonrails.org/classes/ActiveRecord/FixtureSet.html
2 |
3 | one:
4 | name: MyString
5 | colour: MyString
6 | owner_name: MyString
7 | identifying_characteristics: MyText
8 | special_instructions: MyText
9 |
10 | two:
11 | name: MyString
12 | colour: MyString
13 | owner_name: MyString
14 | identifying_characteristics: MyText
15 | special_instructions: MyText
16 |
--------------------------------------------------------------------------------
/config/initializers/backtrace_silencers.rb:
--------------------------------------------------------------------------------
1 | # Be sure to restart your server when you modify this file.
2 |
3 | # You can add backtrace silencers for libraries that you're using but don't wish to see in your backtraces.
4 | # Rails.backtrace_cleaner.add_silencer { |line| line =~ /my_noisy_library/ }
5 |
6 | # You can also remove all the silencers if you're trying to debug a problem that might stem from framework code.
7 | # Rails.backtrace_cleaner.remove_silencers!
8 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | # See https://help.github.com/articles/ignoring-files for more about ignoring files.
2 | #
3 | # If you find yourself ignoring temporary files generated by your text editor
4 | # or operating system, you probably want to add a global ignore instead:
5 | # git config --global core.excludesfile '~/.gitignore_global'
6 |
7 | # Ignore bundler config.
8 | /.bundle
9 |
10 | # Ignore the default SQLite database.
11 | /db/*.sqlite3
12 | /db/*.sqlite3-journal
13 |
14 | # Ignore all logfiles and tempfiles.
15 | /log/*.log
16 | /tmp
17 |
--------------------------------------------------------------------------------
/test/test_helper.rb:
--------------------------------------------------------------------------------
1 | ENV["RAILS_ENV"] ||= "test"
2 | require File.expand_path('../../config/environment', __FILE__)
3 | require 'rails/test_help'
4 |
5 | class ActiveSupport::TestCase
6 | ActiveRecord::Migration.check_pending!
7 |
8 | # Setup all fixtures in test/fixtures/*.yml for all tests in alphabetical order.
9 | #
10 | # Note: You'll currently still have to declare fixtures explicitly in integration tests
11 | # -- they do not yet inherit this setting
12 | fixtures :all
13 |
14 | # Add more helper methods to be used by all tests here...
15 | end
16 |
--------------------------------------------------------------------------------
/config/initializers/wrap_parameters.rb:
--------------------------------------------------------------------------------
1 | # Be sure to restart your server when you modify this file.
2 |
3 | # This file contains settings for ActionController::ParamsWrapper which
4 | # is enabled by default.
5 |
6 | # Enable parameter wrapping for JSON. You can disable this by setting :format to an empty array.
7 | ActiveSupport.on_load(:action_controller) do
8 | wrap_parameters format: [:json] if respond_to?(:wrap_parameters)
9 | end
10 |
11 | # To enable root element in JSON for ActiveRecord objects.
12 | # ActiveSupport.on_load(:active_record) do
13 | # self.include_root_in_json = true
14 | # end
15 |
--------------------------------------------------------------------------------
/app/assets/stylesheets/application.css:
--------------------------------------------------------------------------------
1 | /*
2 | * This is a manifest file that'll be compiled into application.css, which will include all the files
3 | * listed below.
4 | *
5 | * Any CSS and SCSS file within this directory, lib/assets/stylesheets, vendor/assets/stylesheets,
6 | * or vendor/assets/stylesheets of plugins, if any, can be referenced here using a relative path.
7 | *
8 | * You're free to add application-wide styles to this file and they'll appear at the top of the
9 | * compiled file, but it's generally better to create a new file per style scope.
10 | *
11 | *= require_self
12 | *= require_tree .
13 | */
14 |
--------------------------------------------------------------------------------
/app/views/pet/steps/instructions.html.erb:
--------------------------------------------------------------------------------
1 | <%= form_for @pet, method: :put, url: wizard_path do |f| %>
2 | <% if f.object.errors.any? %>
3 |
4 | <% f.object.errors.full_messages.each do |error| %>
5 |
<%= error %>
6 | <% end %>
7 |
8 | <% end %>
9 |
10 |
23 | <% end %>
24 |
25 |
--------------------------------------------------------------------------------
/config/database.yml:
--------------------------------------------------------------------------------
1 | # SQLite version 3.x
2 | # gem install sqlite3
3 | #
4 | # Ensure the SQLite 3 gem is defined in your Gemfile
5 | # gem 'sqlite3'
6 | development:
7 | adapter: sqlite3
8 | database: db/development.sqlite3
9 | pool: 5
10 | timeout: 5000
11 |
12 | # Warning: The database defined as "test" will be erased and
13 | # re-generated from your development database when you run "rake".
14 | # Do not set this db to the same as development or production.
15 | test:
16 | adapter: sqlite3
17 | database: db/test.sqlite3
18 | pool: 5
19 | timeout: 5000
20 |
21 | production:
22 | adapter: sqlite3
23 | database: db/production.sqlite3
24 | pool: 5
25 | timeout: 5000
26 |
--------------------------------------------------------------------------------
/app/models/pet.rb:
--------------------------------------------------------------------------------
1 | class Pet < ActiveRecord::Base
2 | cattr_accessor :form_steps do
3 | %w(identity characteristics instructions)
4 | end
5 |
6 | attr_accessor :form_step
7 |
8 | validates :name, :owner_name, presence: true, if: -> { required_for_step?(:identity) }
9 | validates :identifying_characteristics, :colour, presence: true, if: -> { required_for_step?(:characteristics) }
10 | validates :special_instructions, presence: true, if: -> { required_for_step?(:instructions) }
11 |
12 | def required_for_step?(step)
13 | return true if form_step.nil?
14 | return true if self.form_steps.index(step.to_s) <= self.form_steps.index(form_step)
15 | end
16 |
17 |
18 |
19 | end
20 |
--------------------------------------------------------------------------------
/app/views/pet/steps/identity.html.erb:
--------------------------------------------------------------------------------
1 | <%= form_for @pet, method: :put, url: wizard_path do |f| %>
2 | <% if f.object.errors.any? %>
3 |
4 | <% f.object.errors.full_messages.each do |error| %>
5 |
<%= error %>
6 | <% end %>
7 |
8 | <% end %>
9 |
10 |
27 | <% end %>
28 |
--------------------------------------------------------------------------------
/app/assets/javascripts/application.js:
--------------------------------------------------------------------------------
1 | // This is a manifest file that'll be compiled into application.js, which will include all the files
2 | // listed below.
3 | //
4 | // Any JavaScript/Coffee file within this directory, lib/assets/javascripts, vendor/assets/javascripts,
5 | // or vendor/assets/javascripts of plugins, if any, can be referenced here using a relative path.
6 | //
7 | // It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the
8 | // compiled file.
9 | //
10 | // Read Sprockets README (https://github.com/sstephenson/sprockets#sprockets-directives) for details
11 | // about supported directives.
12 | //
13 | //= require jquery
14 | //= require jquery_ujs
15 | //= require_tree .
16 |
--------------------------------------------------------------------------------
/config/initializers/secret_token.rb:
--------------------------------------------------------------------------------
1 | # Be sure to restart your server when you modify this file.
2 |
3 | # Your secret key is used for verifying the integrity of signed cookies.
4 | # If you change this key, all old signed cookies will become invalid!
5 |
6 | # Make sure the secret is at least 30 characters and all random,
7 | # no regular words or you'll be exposed to dictionary attacks.
8 | # You can use `rake secret` to generate a secure secret key.
9 |
10 | # Make sure your secret_key_base is kept private
11 | # if you're sharing your code publicly.
12 | PetThing::Application.config.secret_key_base = '9848a9e79ced169876efa21fba8943dd76e1dc9cdac4ce096bb1803d81f93545dc87e5ddabae0f77ce0136113a5e08c7c30e91c340ee8b8faf3f1b1640042b14'
13 |
--------------------------------------------------------------------------------
/config/initializers/inflections.rb:
--------------------------------------------------------------------------------
1 | # Be sure to restart your server when you modify this file.
2 |
3 | # Add new inflection rules using the following format. Inflections
4 | # are locale specific, and you may define rules for as many different
5 | # locales as you wish. All of these examples are active by default:
6 | # ActiveSupport::Inflector.inflections(:en) do |inflect|
7 | # inflect.plural /^(ox)$/i, '\1en'
8 | # inflect.singular /^(ox)en/i, '\1'
9 | # inflect.irregular 'person', 'people'
10 | # inflect.uncountable %w( fish sheep )
11 | # end
12 |
13 | # These inflection rules are supported but not enabled by default:
14 | # ActiveSupport::Inflector.inflections(:en) do |inflect|
15 | # inflect.acronym 'RESTful'
16 | # end
17 |
--------------------------------------------------------------------------------
/config/locales/en.yml:
--------------------------------------------------------------------------------
1 | # Files in the config/locales directory are used for internationalization
2 | # and are automatically loaded by Rails. If you want to use locales other
3 | # than English, add the necessary files in this directory.
4 | #
5 | # To use the locales, use `I18n.t`:
6 | #
7 | # I18n.t 'hello'
8 | #
9 | # In views, this is aliased to just `t`:
10 | #
11 | # <%= t('hello') %>
12 | #
13 | # To use a different locale, set it with `I18n.locale`:
14 | #
15 | # I18n.locale = :es
16 | #
17 | # This would use the information in config/locales/es.yml.
18 | #
19 | # To learn more, please read the Rails Internationalization guide
20 | # available at http://guides.rubyonrails.org/i18n.html.
21 |
22 | en:
23 | hello: "Hello world"
24 |
--------------------------------------------------------------------------------
/app/views/pet/steps/characteristics.html.erb:
--------------------------------------------------------------------------------
1 | <%= form_for @pet, method: :put, url: wizard_path do |f| %>
2 | <% if f.object.errors.any? %>
3 |
4 | <% f.object.errors.full_messages.each do |error| %>
5 |
37 | <% end %>
38 |
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | The MIT License (MIT)
2 |
3 | Copyright (c) 2014 Josh McArthur
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
22 |
23 |
--------------------------------------------------------------------------------
/db/schema.rb:
--------------------------------------------------------------------------------
1 | # encoding: UTF-8
2 | # This file is auto-generated from the current state of the database. Instead
3 | # of editing this file, please use the migrations feature of Active Record to
4 | # incrementally modify your database, and then regenerate this schema definition.
5 | #
6 | # Note that this schema.rb definition is the authoritative source for your
7 | # database schema. If you need to create the application database on another
8 | # system, you should be using db:schema:load, not running all the migrations
9 | # from scratch. The latter is a flawed and unsustainable approach (the more migrations
10 | # you'll amass, the slower it'll run and the greater likelihood for issues).
11 | #
12 | # It's strongly recommended that you check this file into your version control system.
13 |
14 | ActiveRecord::Schema.define(version: 20140919000739) do
15 |
16 | create_table "pets", force: true do |t|
17 | t.string "name"
18 | t.string "colour"
19 | t.string "owner_name"
20 | t.text "identifying_characteristics"
21 | t.text "special_instructions"
22 | t.datetime "created_at"
23 | t.datetime "updated_at"
24 | end
25 |
26 | end
27 |
--------------------------------------------------------------------------------
/config/environments/development.rb:
--------------------------------------------------------------------------------
1 | PetThing::Application.configure do
2 | # Settings specified here will take precedence over those in config/application.rb.
3 |
4 | # In the development environment your application's code is reloaded on
5 | # every request. This slows down response time but is perfect for development
6 | # since you don't have to restart the web server when you make code changes.
7 | config.cache_classes = false
8 |
9 | # Do not eager load code on boot.
10 | config.eager_load = false
11 |
12 | # Show full error reports and disable caching.
13 | config.consider_all_requests_local = true
14 | config.action_controller.perform_caching = false
15 |
16 | # Don't care if the mailer can't send.
17 | config.action_mailer.raise_delivery_errors = false
18 |
19 | # Print deprecation notices to the Rails logger.
20 | config.active_support.deprecation = :log
21 |
22 | # Raise an error on page load if there are pending migrations
23 | config.active_record.migration_error = :page_load
24 |
25 | # Debug mode disables concatenation and preprocessing of assets.
26 | # This option may cause significant delays in view rendering with a large
27 | # number of complex assets.
28 | config.assets.debug = true
29 | end
30 |
--------------------------------------------------------------------------------
/app/assets/stylesheets/scaffolds.css.scss:
--------------------------------------------------------------------------------
1 | body {
2 | background-color: #fff;
3 | color: #333;
4 | font-family: verdana, arial, helvetica, sans-serif;
5 | font-size: 13px;
6 | line-height: 18px;
7 | }
8 |
9 | p, ol, ul, td {
10 | font-family: verdana, arial, helvetica, sans-serif;
11 | font-size: 13px;
12 | line-height: 18px;
13 | }
14 |
15 | pre {
16 | background-color: #eee;
17 | padding: 10px;
18 | font-size: 11px;
19 | }
20 |
21 | a {
22 | color: #000;
23 | &:visited {
24 | color: #666;
25 | }
26 | &:hover {
27 | color: #fff;
28 | background-color: #000;
29 | }
30 | }
31 |
32 | div {
33 | &.field, &.actions {
34 | margin-bottom: 10px;
35 | }
36 | }
37 |
38 | #notice {
39 | color: green;
40 | }
41 |
42 | .field_with_errors {
43 | padding: 2px;
44 | background-color: red;
45 | display: table;
46 | }
47 |
48 | #error_explanation {
49 | width: 450px;
50 | border: 2px solid red;
51 | padding: 7px;
52 | padding-bottom: 0;
53 | margin-bottom: 20px;
54 | background-color: #f0f0f0;
55 | h2 {
56 | text-align: left;
57 | font-weight: bold;
58 | padding: 5px 5px 5px 15px;
59 | font-size: 12px;
60 | margin: -7px;
61 | margin-bottom: 0px;
62 | background-color: #c00;
63 | color: #fff;
64 | }
65 | ul li {
66 | font-size: 12px;
67 | list-style: square;
68 | }
69 | }
70 |
--------------------------------------------------------------------------------
/app/controllers/pets_controller.rb:
--------------------------------------------------------------------------------
1 | class PetsController < ApplicationController
2 | before_action :set_pet, only: [:show, :edit, :update, :destroy]
3 |
4 | # GET /pets
5 | # GET /pets.json
6 | def index
7 | # Normally you'd have more complex requirements about
8 | # when not to show rows, but we don't show any records that don't have a name
9 | @pets = Pet.where.not(name: nil)
10 | end
11 |
12 | # GET /pets/1
13 | # GET /pets/1.json
14 | def show
15 | end
16 |
17 | # GET /pets/new
18 | def new
19 | @pet = Pet.new
20 | end
21 |
22 | # POST /pets
23 | # POST /pets.json
24 | def create
25 | @pet = Pet.new
26 | @pet.save(validate: false)
27 | redirect_to pet_step_path(@pet, Pet.form_steps.first)
28 | end
29 |
30 | # DELETE /pets/1
31 | # DELETE /pets/1.json
32 | def destroy
33 | @pet.destroy
34 | respond_to do |format|
35 | format.html { redirect_to pets_url }
36 | format.json { head :no_content }
37 | end
38 | end
39 |
40 | private
41 | # Use callbacks to share common setup or constraints between actions.
42 | def set_pet
43 | @pet = Pet.find(params[:id])
44 | end
45 |
46 | # Never trust parameters from the scary internet, only allow the white list through.
47 | def pet_params
48 | params.require(:pet).permit(:name, :colour, :owner_name, :identifying_characteristics, :special_instructions)
49 | end
50 | end
51 |
--------------------------------------------------------------------------------
/public/500.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 | We're sorry, but something went wrong (500)
5 |
48 |
49 |
50 |
51 |
52 |
53 |
We're sorry, but something went wrong.
54 |
55 |
If you are the application owner check the logs for more information.
56 |
57 |
58 |
--------------------------------------------------------------------------------
/test/controllers/pets_controller_test.rb:
--------------------------------------------------------------------------------
1 | require 'test_helper'
2 |
3 | class PetsControllerTest < ActionController::TestCase
4 | setup do
5 | @pet = pets(:one)
6 | end
7 |
8 | test "should get index" do
9 | get :index
10 | assert_response :success
11 | assert_not_nil assigns(:pets)
12 | end
13 |
14 | test "should get new" do
15 | get :new
16 | assert_response :success
17 | end
18 |
19 | test "should create pet" do
20 | assert_difference('Pet.count') do
21 | post :create, pet: { colour: @pet.colour, identifying_characteristics: @pet.identifying_characteristics, name: @pet.name, owner_name: @pet.owner_name, special_instructions: @pet.special_instructions }
22 | end
23 |
24 | assert_redirected_to pet_path(assigns(:pet))
25 | end
26 |
27 | test "should show pet" do
28 | get :show, id: @pet
29 | assert_response :success
30 | end
31 |
32 | test "should get edit" do
33 | get :edit, id: @pet
34 | assert_response :success
35 | end
36 |
37 | test "should update pet" do
38 | patch :update, id: @pet, pet: { colour: @pet.colour, identifying_characteristics: @pet.identifying_characteristics, name: @pet.name, owner_name: @pet.owner_name, special_instructions: @pet.special_instructions }
39 | assert_redirected_to pet_path(assigns(:pet))
40 | end
41 |
42 | test "should destroy pet" do
43 | assert_difference('Pet.count', -1) do
44 | delete :destroy, id: @pet
45 | end
46 |
47 | assert_redirected_to pets_path
48 | end
49 | end
50 |
--------------------------------------------------------------------------------
/public/422.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 | The change you wanted was rejected (422)
5 |
48 |
49 |
50 |
51 |
52 |
53 |
The change you wanted was rejected.
54 |
Maybe you tried to change something you didn't have access to.
55 |
56 |
If you are the application owner check the logs for more information.
57 |
58 |
59 |
--------------------------------------------------------------------------------
/public/404.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 | The page you were looking for doesn't exist (404)
5 |
48 |
49 |
50 |
51 |
52 |
53 |
The page you were looking for doesn't exist.
54 |
You may have mistyped the address or the page may have moved.
55 |
56 |
If you are the application owner check the logs for more information.
57 |
58 |
59 |
--------------------------------------------------------------------------------
/config/environments/test.rb:
--------------------------------------------------------------------------------
1 | PetThing::Application.configure do
2 | # Settings specified here will take precedence over those in config/application.rb.
3 |
4 | # The test environment is used exclusively to run your application's
5 | # test suite. You never need to work with it otherwise. Remember that
6 | # your test database is "scratch space" for the test suite and is wiped
7 | # and recreated between test runs. Don't rely on the data there!
8 | config.cache_classes = true
9 |
10 | # Do not eager load code on boot. This avoids loading your whole application
11 | # just for the purpose of running a single test. If you are using a tool that
12 | # preloads Rails for running tests, you may have to set it to true.
13 | config.eager_load = false
14 |
15 | # Configure static asset server for tests with Cache-Control for performance.
16 | config.serve_static_assets = true
17 | config.static_cache_control = "public, max-age=3600"
18 |
19 | # Show full error reports and disable caching.
20 | config.consider_all_requests_local = true
21 | config.action_controller.perform_caching = false
22 |
23 | # Raise exceptions instead of rendering exception templates.
24 | config.action_dispatch.show_exceptions = false
25 |
26 | # Disable request forgery protection in test environment.
27 | config.action_controller.allow_forgery_protection = false
28 |
29 | # Tell Action Mailer not to deliver emails to the real world.
30 | # The :test delivery method accumulates sent emails in the
31 | # ActionMailer::Base.deliveries array.
32 | config.action_mailer.delivery_method = :test
33 |
34 | # Print deprecation notices to the stderr.
35 | config.active_support.deprecation = :stderr
36 | end
37 |
--------------------------------------------------------------------------------
/config/routes.rb:
--------------------------------------------------------------------------------
1 | PetThing::Application.routes.draw do
2 | resources :pets, only: [:new, :create, :index, :destroy] do
3 | resources :steps, only: [:show, :update], controller: 'pet/steps'
4 | end
5 |
6 | root to: 'pets#index'
7 |
8 | # The priority is based upon order of creation: first created -> highest priority.
9 | # See how all your routes lay out with "rake routes".
10 |
11 | # You can have the root of your site routed with "root"
12 | # root 'welcome#index'
13 |
14 | # Example of regular route:
15 | # get 'products/:id' => 'catalog#view'
16 |
17 | # Example of named route that can be invoked with purchase_url(id: product.id)
18 | # get 'products/:id/purchase' => 'catalog#purchase', as: :purchase
19 |
20 | # Example resource route (maps HTTP verbs to controller actions automatically):
21 | # resources :products
22 |
23 | # Example resource route with options:
24 | # resources :products do
25 | # member do
26 | # get 'short'
27 | # post 'toggle'
28 | # end
29 | #
30 | # collection do
31 | # get 'sold'
32 | # end
33 | # end
34 |
35 | # Example resource route with sub-resources:
36 | # resources :products do
37 | # resources :comments, :sales
38 | # resource :seller
39 | # end
40 |
41 | # Example resource route with more complex sub-resources:
42 | # resources :products do
43 | # resources :comments
44 | # resources :sales do
45 | # get 'recent', on: :collection
46 | # end
47 | # end
48 |
49 | # Example resource route with concerns:
50 | # concern :toggleable do
51 | # post 'toggle'
52 | # end
53 | # resources :posts, concerns: :toggleable
54 | # resources :photos, concerns: :toggleable
55 |
56 | # Example resource route within a namespace:
57 | # namespace :admin do
58 | # # Directs /admin/products/* to Admin::ProductsController
59 | # # (app/controllers/admin/products_controller.rb)
60 | # resources :products
61 | # end
62 | end
63 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | Rails Multistep Forms with Wizard
2 | ===
3 |
4 | This is the accompanying Rails application to [my blog post on Multistep forms in Rails](http://brains.rabid.co.nz/2014/09/29/rails-multistep-forms.html). If you haven't already read that post, it is suggested that you read it to have the context of this application.
5 |
6 | If you're just after having a play with this, there's a demo application hosted on Heroku, at: [https://jm-multistep-blog-demo.herokuapp.com](https://jm-multistep-blog-demo.herokuapp.com) to play with.
7 |
8 | If you want to poke around the code, you can explore the project here on Github. Please open an issue if you have questions or trouble.
9 |
10 | If you want to try and add to this example, or improve it in any way, you can clone the project and make your own changes:
11 |
12 | 1. Clone: `git clone git://github.com/joshmcarthur/rails-multistep-forms-demo`
13 | 2. Install dependencies: `bundle install`
14 | 3. Set up database (SQLite3): `rake db:setup`
15 | 4. Start Rails server: `rails server`
16 | 5. Open http://localhost:3000 in your browser
17 |
18 | License
19 | ---
20 |
21 | The MIT License (MIT)
22 |
23 | Copyright (c) 2014 Josh McArthur
24 |
25 | Permission is hereby granted, free of charge, to any person obtaining a copy
26 | of this software and associated documentation files (the "Software"), to deal
27 | in the Software without restriction, including without limitation the rights
28 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
29 | copies of the Software, and to permit persons to whom the Software is
30 | furnished to do so, subject to the following conditions:
31 |
32 | The above copyright notice and this permission notice shall be included in all
33 | copies or substantial portions of the Software.
34 |
35 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
36 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
37 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
38 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
39 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
40 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
41 | SOFTWARE.
42 |
--------------------------------------------------------------------------------
/Gemfile.lock:
--------------------------------------------------------------------------------
1 | GEM
2 | remote: https://rubygems.org/
3 | specs:
4 | actionmailer (4.0.5)
5 | actionpack (= 4.0.5)
6 | mail (~> 2.5.4)
7 | actionpack (4.0.5)
8 | activesupport (= 4.0.5)
9 | builder (~> 3.1.0)
10 | erubis (~> 2.7.0)
11 | rack (~> 1.5.2)
12 | rack-test (~> 0.6.2)
13 | activemodel (4.0.5)
14 | activesupport (= 4.0.5)
15 | builder (~> 3.1.0)
16 | activerecord (4.0.5)
17 | activemodel (= 4.0.5)
18 | activerecord-deprecated_finders (~> 1.0.2)
19 | activesupport (= 4.0.5)
20 | arel (~> 4.0.0)
21 | activerecord-deprecated_finders (1.0.3)
22 | activesupport (4.0.5)
23 | i18n (~> 0.6, >= 0.6.9)
24 | minitest (~> 4.2)
25 | multi_json (~> 1.3)
26 | thread_safe (~> 0.1)
27 | tzinfo (~> 0.3.37)
28 | arel (4.0.2)
29 | builder (3.1.4)
30 | erubis (2.7.0)
31 | hike (1.2.3)
32 | i18n (0.6.11)
33 | jquery-rails (3.1.2)
34 | railties (>= 3.0, < 5.0)
35 | thor (>= 0.14, < 2.0)
36 | mail (2.5.4)
37 | mime-types (~> 1.16)
38 | treetop (~> 1.4.8)
39 | mime-types (1.25.1)
40 | minitest (4.7.5)
41 | multi_json (1.10.1)
42 | pg (0.16.0)
43 | polyglot (0.3.5)
44 | rack (1.5.2)
45 | rack-test (0.6.2)
46 | rack (>= 1.0)
47 | rails (4.0.5)
48 | actionmailer (= 4.0.5)
49 | actionpack (= 4.0.5)
50 | activerecord (= 4.0.5)
51 | activesupport (= 4.0.5)
52 | bundler (>= 1.3.0, < 2.0)
53 | railties (= 4.0.5)
54 | sprockets-rails (~> 2.0.0)
55 | rails_12factor (0.0.2)
56 | rails_serve_static_assets
57 | rails_stdout_logging
58 | rails_serve_static_assets (0.0.1)
59 | rails_stdout_logging (0.0.1)
60 | railties (4.0.5)
61 | actionpack (= 4.0.5)
62 | activesupport (= 4.0.5)
63 | rake (>= 0.8.7)
64 | thor (>= 0.18.1, < 2.0)
65 | rake (10.3.2)
66 | sass (3.2.19)
67 | sass-rails (4.0.3)
68 | railties (>= 4.0.0, < 5.0)
69 | sass (~> 3.2.0)
70 | sprockets (~> 2.8, <= 2.11.0)
71 | sprockets-rails (~> 2.0)
72 | sprockets (2.11.0)
73 | hike (~> 1.2)
74 | multi_json (~> 1.0)
75 | rack (~> 1.0)
76 | tilt (~> 1.1, != 1.3.0)
77 | sprockets-rails (2.0.1)
78 | actionpack (>= 3.0)
79 | activesupport (>= 3.0)
80 | sprockets (~> 2.8)
81 | sqlite3 (1.3.9)
82 | thor (0.19.1)
83 | thread_safe (0.3.4)
84 | tilt (1.4.1)
85 | treetop (1.4.15)
86 | polyglot
87 | polyglot (>= 0.3.1)
88 | tzinfo (0.3.41)
89 | wicked (1.1.0)
90 | rails (>= 3.0.7)
91 |
92 | PLATFORMS
93 | ruby
94 |
95 | DEPENDENCIES
96 | jquery-rails
97 | pg
98 | rails (= 4.0.5)
99 | rails_12factor
100 | sass-rails (~> 4.0.2)
101 | sqlite3
102 | wicked
103 |
--------------------------------------------------------------------------------
/config/environments/production.rb:
--------------------------------------------------------------------------------
1 | PetThing::Application.configure do
2 | # Settings specified here will take precedence over those in config/application.rb.
3 |
4 | # Code is not reloaded between requests.
5 | config.cache_classes = true
6 |
7 | # Eager load code on boot. This eager loads most of Rails and
8 | # your application in memory, allowing both thread web servers
9 | # and those relying on copy on write to perform better.
10 | # Rake tasks automatically ignore this option for performance.
11 | config.eager_load = true
12 |
13 | # Full error reports are disabled and caching is turned on.
14 | config.consider_all_requests_local = false
15 | config.action_controller.perform_caching = true
16 |
17 | # Enable Rack::Cache to put a simple HTTP cache in front of your application
18 | # Add `rack-cache` to your Gemfile before enabling this.
19 | # For large-scale production use, consider using a caching reverse proxy like nginx, varnish or squid.
20 | # config.action_dispatch.rack_cache = true
21 |
22 | # Disable Rails's static asset server (Apache or nginx will already do this).
23 | config.serve_static_assets = false
24 |
25 | # Compress JavaScripts and CSS.
26 | # config.assets.js_compressor = :uglifier
27 | # config.assets.css_compressor = :sass
28 |
29 | # Do not fallback to assets pipeline if a precompiled asset is missed.
30 | config.assets.compile = false
31 |
32 | # Generate digests for assets URLs.
33 | config.assets.digest = true
34 |
35 | # Version of your assets, change this if you want to expire all your assets.
36 | config.assets.version = '1.0'
37 |
38 | # Specifies the header that your server uses for sending files.
39 | # config.action_dispatch.x_sendfile_header = "X-Sendfile" # for apache
40 | # config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for nginx
41 |
42 | # Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies.
43 | # config.force_ssl = true
44 |
45 | # Set to :debug to see everything in the log.
46 | config.log_level = :info
47 |
48 | # Prepend all log lines with the following tags.
49 | # config.log_tags = [ :subdomain, :uuid ]
50 |
51 | # Use a different logger for distributed setups.
52 | # config.logger = ActiveSupport::TaggedLogging.new(SyslogLogger.new)
53 |
54 | # Use a different cache store in production.
55 | # config.cache_store = :mem_cache_store
56 |
57 | # Enable serving of images, stylesheets, and JavaScripts from an asset server.
58 | # config.action_controller.asset_host = "http://assets.example.com"
59 |
60 | # Precompile additional assets.
61 | # application.js, application.css, and all non-JS/CSS in app/assets folder are already added.
62 | # config.assets.precompile += %w( search.js )
63 |
64 | # Ignore bad email addresses and do not raise email delivery errors.
65 | # Set this to true and configure the email server for immediate delivery to raise delivery errors.
66 | # config.action_mailer.raise_delivery_errors = false
67 |
68 | # Enable locale fallbacks for I18n (makes lookups for any locale fall back to
69 | # the I18n.default_locale when a translation can not be found).
70 | config.i18n.fallbacks = true
71 |
72 | # Send deprecation notices to registered listeners.
73 | config.active_support.deprecation = :notify
74 |
75 | # Disable automatic flushing of the log to improve performance.
76 | # config.autoflush_log = false
77 |
78 | # Use default logging formatter so that PID and timestamp are not suppressed.
79 | config.log_formatter = ::Logger::Formatter.new
80 | end
81 |
--------------------------------------------------------------------------------