Agile Web Development with Rails, Edition 4
6.1 Iteration A1: Creating the Products Maintenance Application
Table of Contents
2 Instant Gratification
We start with a simple "hello world!" demo application and in the process verify that everything is installed correctly.
Create the application
bundle exec /home/rubys/git/rails/railties/bin/rails new demo1 --skip-bundle
create
create README.rdoc
create Rakefile
create config.ru
create .gitignore
create Gemfile
create app
create app/assets/javascripts/application.js
create app/assets/stylesheets/application.css
create app/controllers/application_controller.rb
create app/helpers/application_helper.rb
create app/views/layouts/application.html.erb
create app/assets/images/.keep
create app/mailers/.keep
create app/models/.keep
create app/controllers/concerns/.keep
create app/models/concerns/.keep
create bin
create bin/bundle
create bin/rails
create bin/rake
create config
create config/routes.rb
create config/application.rb
create config/environment.rb
create config/environments
create config/environments/development.rb
create config/environments/production.rb
create config/environments/test.rb
create config/initializers
create config/initializers/backtrace_silencers.rb
create config/initializers/filter_parameter_logging.rb
create config/initializers/inflections.rb
create config/initializers/mime_types.rb
create config/initializers/secret_token.rb
create config/initializers/session_store.rb
create config/initializers/wrap_parameters.rb
create config/locales
create config/locales/en.yml
create config/boot.rb
create config/database.yml
create db
create db/seeds.rb
create lib
create lib/tasks
create lib/tasks/.keep
create lib/assets
create lib/assets/.keep
create log
create log/.keep
create public
create public/404.html
create public/422.html
create public/500.html
create public/favicon.ico
create public/robots.txt
create test/fixtures
create test/fixtures/.keep
create test/controllers
create test/controllers/.keep
create test/mailers
create test/mailers/.keep
create test/models
create test/models/.keep
create test/helpers
create test/helpers/.keep
create test/integration
create test/integration/.keep
create test/test_helper.rb
create tmp/cache
create tmp/cache/assets
create vendor/assets/javascripts
create vendor/assets/javascripts/.keep
create vendor/assets/stylesheets
create vendor/assets/stylesheets/.keep
bundle install --local
Resolving dependencies...
Using rake 11.1.2
Using i18n 0.7.0
Using minitest 4.7.5
Using multi_json 1.12.0
Using thread_safe 0.3.5
Using tzinfo 0.3.49
Using builder 3.1.4
Using erubis 2.7.0
Using rack 1.5.5
Using mime-types-data 3.2016.0221
Using activerecord-deprecated_finders 1.0.4
Using arel 4.0.2.20140205180311 from source at `/home/rubys/git/arel`
Using bundler 1.12.2
Using coffee-script-source 1.10.0
Using execjs 2.6.0
Using thor 0.19.1
Using hike 1.2.3
Using json 1.8.3
Using tilt 1.4.1
Using sass 3.2.19
Using sqlite3 1.3.11
Using activesupport 4.0.13 from source at `/home/rubys/git/rails`
Using rack-test 0.6.3
Using mime-types 3.0
Using coffee-script 2.4.1
Using uglifier 3.0.0
Using rdoc 4.2.2
Using sprockets 2.12.4
Using activemodel 4.0.13 from source at `/home/rubys/git/rails`
Using jbuilder 1.5.3
Using actionpack 4.0.13 from source at `/home/rubys/git/rails`
Using mail 2.6.4
Using sdoc 0.4.1
Using activerecord 4.0.13 from source at `/home/rubys/git/rails`
Using railties 4.0.13 from source at `/home/rubys/git/rails`
Using sprockets-rails 2.3.3 from source at `/home/rubys/git/sprockets-rails`
Using actionmailer 4.0.13 from source at `/home/rubys/git/rails`
Using coffee-rails 4.0.1
Using jquery-rails 3.1.4
Using sass-rails 4.0.5
Using rails 4.0.13 from source at `/home/rubys/git/rails`
Using turbolinks 2.5.3
Bundle complete! 11 Gemfile dependencies, 42 gems now installed.
Use `bundle show [gemname]` to see where a bundled gem is installed.
See what files were created
ls -p
app/ config/ db/ Gemfile.lock log/ Rakefile test/ vendor/
bin/ config.ru Gemfile lib/ public/ README.rdoc tmp/
Create a simple controller
rails generate controller Say hello goodbye
create app/controllers/say_controller.rb
route get "say/goodbye"
route get "say/hello"
invoke erb
create app/views/say
create app/views/say/hello.html.erb
create app/views/say/goodbye.html.erb
invoke test_unit
create test/controllers/say_controller_test.rb
invoke helper
create app/helpers/say_helper.rb
invoke test_unit
create test/helpers/say_helper_test.rb
invoke assets
invoke coffee
create app/assets/javascripts/say.js.coffee
invoke scss
create app/assets/stylesheets/say.css.scss
edit app/controllers/say_controller.rb
class SayController < ApplicationController
def hello
end
def goodbye
end
end
Start the server.
Attempt to fetch the file - note that it is missing
get /say/hello
Say#hello
Find me in app/views/say/hello.html.erb
Replace file with a simple hello world
edit app/views/say/hello.html.erb
<h1>Hello from Rails!</h1>
This time it works!
get /say/hello
Hello from Rails!
Add a simple expression
edit app/views/say/hello.html.erb
<h1>Hello from Rails!</h1>
<p>
It is now <%= Time.now %>
</p>
get /say/hello
Hello from Rails!
It is now 2016-05-06 09:40:33 -0400
Evaluate the expression in the controller.
edit app/controllers/say_controller.rb
class SayController < ApplicationController
def hello
@time = Time.now
end
def goodbye
end
end
Reference the result in the view.
edit app/views/say/hello.html.erb
<h1>Hello from Rails!</h1>
<p>
It is now <%= @time %>
</p>
get /say/hello
Hello from Rails!
It is now 2016-05-06 09:40:33 -0400
Replace the goodbye template
edit app/views/say/goodbye.html.erb
<h1>Goodbye!</h1>
<p>
It was nice having you here.
</p>
get /say/goodbye
Goodbye!
It was nice having you here.
Add a link from the hello page to the goodbye page
edit app/views/say/hello.html.erb
<h1>Hello from Rails!</h1>
<p>
It is now <%= @time %>
</p>
<p>
Time to say
<%= link_to "Goodbye", say_goodbye_path %>!
</p>
get /say/hello
Hello from Rails!
It is now 2016-05-06 09:40:33 -0400
Time to say
Goodbye!
Add a link back to the hello page
edit app/views/say/goodbye.html.erb
<h1>Goodbye!</h1>
<p>
It was nice having you here.
</p>
<p>
Say <%= link_to "Hello", say_hello_path %> again.
</p>
get /say/goodbye
Goodbye!
It was nice having you here.
Say Hello again.
Intentionally introduce a typo in the code
edit app/controllers/say_controller.rb
class SayController < ApplicationController
def hello
@time = Time.know
end
def goodbye
end
end
get /say/hello
HTTP Response Code: 500
NoMethodError
in SayController#hello
undefined method `know' for Time:Class
Extracted source (around line #4):
2
3
4
5
6
7
|
def hello
#START_HIGHLIGHT
@time = Time.know
#END_HIGHLIGHT
end
|
Rails.root: /home/rubys/git/awdwr/edition4/work-224-40/demo1
Application Trace |
Framework Trace |
Full Trace
app/controllers/say_controller.rb:4:in `hello'
/home/rubys/git/rails/actionpack/lib/action_controller/metal/implicit_render.rb:4:in `send_action'
/home/rubys/git/rails/actionpack/lib/abstract_controller/base.rb:189:in `process_action'
/home/rubys/git/rails/actionpack/lib/action_controller/metal/rendering.rb:10:in `process_action'
/home/rubys/git/rails/actionpack/lib/abstract_controller/callbacks.rb:18:in `block in process_action'
/home/rubys/git/rails/activesupport/lib/active_support/callbacks.rb:403:in `_run__1765113708135195731__process_action__callbacks'
/home/rubys/git/rails/activesupport/lib/active_support/callbacks.rb:80:in `run_callbacks'
/home/rubys/git/rails/actionpack/lib/abstract_controller/callbacks.rb:17:in `process_action'
/home/rubys/git/rails/actionpack/lib/action_controller/metal/rescue.rb:29:in `process_action'
/home/rubys/git/rails/actionpack/lib/action_controller/metal/instrumentation.rb:31:in `block in process_action'
/home/rubys/git/rails/activesupport/lib/active_support/notifications.rb:159:in `block in instrument'
/home/rubys/git/rails/activesupport/lib/active_support/notifications/instrumenter.rb:20:in `instrument'
/home/rubys/git/rails/activesupport/lib/active_support/notifications.rb:159:in `instrument'
/home/rubys/git/rails/actionpack/lib/action_controller/metal/instrumentation.rb:30:in `process_action'
/home/rubys/git/rails/actionpack/lib/action_controller/metal/params_wrapper.rb:250:in `process_action'
/home/rubys/git/rails/activerecord/lib/active_record/railties/controller_runtime.rb:18:in `process_action'
/home/rubys/git/rails/actionpack/lib/abstract_controller/base.rb:136:in `process'
/home/rubys/git/rails/actionpack/lib/abstract_controller/rendering.rb:44:in `process'
/home/rubys/git/rails/actionpack/lib/action_controller/metal.rb:195:in `dispatch'
/home/rubys/git/rails/actionpack/lib/action_controller/metal/rack_delegation.rb:13:in `dispatch'
/home/rubys/git/rails/actionpack/lib/action_controller/metal.rb:231:in `block in action'
/home/rubys/git/rails/actionpack/lib/action_dispatch/routing/route_set.rb:82:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/routing/route_set.rb:82:in `dispatch'
/home/rubys/git/rails/actionpack/lib/action_dispatch/routing/route_set.rb:50:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/journey/router.rb:71:in `block in call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/journey/router.rb:59:in `each'
/home/rubys/git/rails/actionpack/lib/action_dispatch/journey/router.rb:59:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/routing/route_set.rb:676:in `call'
rack (1.5.5) lib/rack/etag.rb:23:in `call'
rack (1.5.5) lib/rack/conditionalget.rb:25:in `call'
rack (1.5.5) lib/rack/head.rb:11:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/params_parser.rb:27:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/flash.rb:241:in `call'
rack (1.5.5) lib/rack/session/abstract/id.rb:225:in `context'
rack (1.5.5) lib/rack/session/abstract/id.rb:220:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/cookies.rb:486:in `call'
/home/rubys/git/rails/activerecord/lib/active_record/query_cache.rb:36:in `call'
/home/rubys/git/rails/activerecord/lib/active_record/connection_adapters/abstract/connection_pool.rb:626:in `call'
/home/rubys/git/rails/activerecord/lib/active_record/migration.rb:373:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/callbacks.rb:29:in `block in call'
/home/rubys/git/rails/activesupport/lib/active_support/callbacks.rb:373:in `_run__2782433338296433600__call__callbacks'
/home/rubys/git/rails/activesupport/lib/active_support/callbacks.rb:80:in `run_callbacks'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/callbacks.rb:27:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/reloader.rb:64:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/remote_ip.rb:76:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/debug_exceptions.rb:17:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/show_exceptions.rb:30:in `call'
/home/rubys/git/rails/railties/lib/rails/rack/logger.rb:38:in `call_app'
/home/rubys/git/rails/railties/lib/rails/rack/logger.rb:20:in `block in call'
/home/rubys/git/rails/activesupport/lib/active_support/tagged_logging.rb:68:in `block in tagged'
/home/rubys/git/rails/activesupport/lib/active_support/tagged_logging.rb:26:in `tagged'
/home/rubys/git/rails/activesupport/lib/active_support/tagged_logging.rb:68:in `tagged'
/home/rubys/git/rails/railties/lib/rails/rack/logger.rb:20:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/request_id.rb:21:in `call'
rack (1.5.5) lib/rack/methodoverride.rb:21:in `call'
rack (1.5.5) lib/rack/runtime.rb:17:in `call'
/home/rubys/git/rails/activesupport/lib/active_support/cache/strategy/local_cache.rb:83:in `call'
rack (1.5.5) lib/rack/lock.rb:17:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/static.rb:84:in `call'
rack (1.5.5) lib/rack/sendfile.rb:112:in `call'
/home/rubys/git/rails/railties/lib/rails/engine.rb:511:in `call'
/home/rubys/git/rails/railties/lib/rails/application.rb:97:in `call'
rack (1.5.5) lib/rack/lock.rb:17:in `call'
rack (1.5.5) lib/rack/content_length.rb:14:in `call'
rack (1.5.5) lib/rack/handler/webrick.rb:60:in `service'
/home/rubys/.rvm/rubies/ruby-2.2.4/lib/ruby/2.2.0/webrick/httpserver.rb:138:in `service'
/home/rubys/.rvm/rubies/ruby-2.2.4/lib/ruby/2.2.0/webrick/httpserver.rb:94:in `run'
/home/rubys/.rvm/rubies/ruby-2.2.4/lib/ruby/2.2.0/webrick/server.rb:294:in `block in start_thread'
app/controllers/say_controller.rb:4:in `hello'
/home/rubys/git/rails/actionpack/lib/action_controller/metal/implicit_render.rb:4:in `send_action'
/home/rubys/git/rails/actionpack/lib/abstract_controller/base.rb:189:in `process_action'
/home/rubys/git/rails/actionpack/lib/action_controller/metal/rendering.rb:10:in `process_action'
/home/rubys/git/rails/actionpack/lib/abstract_controller/callbacks.rb:18:in `block in process_action'
/home/rubys/git/rails/activesupport/lib/active_support/callbacks.rb:403:in `_run__1765113708135195731__process_action__callbacks'
/home/rubys/git/rails/activesupport/lib/active_support/callbacks.rb:80:in `run_callbacks'
/home/rubys/git/rails/actionpack/lib/abstract_controller/callbacks.rb:17:in `process_action'
/home/rubys/git/rails/actionpack/lib/action_controller/metal/rescue.rb:29:in `process_action'
/home/rubys/git/rails/actionpack/lib/action_controller/metal/instrumentation.rb:31:in `block in process_action'
/home/rubys/git/rails/activesupport/lib/active_support/notifications.rb:159:in `block in instrument'
/home/rubys/git/rails/activesupport/lib/active_support/notifications/instrumenter.rb:20:in `instrument'
/home/rubys/git/rails/activesupport/lib/active_support/notifications.rb:159:in `instrument'
/home/rubys/git/rails/actionpack/lib/action_controller/metal/instrumentation.rb:30:in `process_action'
/home/rubys/git/rails/actionpack/lib/action_controller/metal/params_wrapper.rb:250:in `process_action'
/home/rubys/git/rails/activerecord/lib/active_record/railties/controller_runtime.rb:18:in `process_action'
/home/rubys/git/rails/actionpack/lib/abstract_controller/base.rb:136:in `process'
/home/rubys/git/rails/actionpack/lib/abstract_controller/rendering.rb:44:in `process'
/home/rubys/git/rails/actionpack/lib/action_controller/metal.rb:195:in `dispatch'
/home/rubys/git/rails/actionpack/lib/action_controller/metal/rack_delegation.rb:13:in `dispatch'
/home/rubys/git/rails/actionpack/lib/action_controller/metal.rb:231:in `block in action'
/home/rubys/git/rails/actionpack/lib/action_dispatch/routing/route_set.rb:82:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/routing/route_set.rb:82:in `dispatch'
/home/rubys/git/rails/actionpack/lib/action_dispatch/routing/route_set.rb:50:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/journey/router.rb:71:in `block in call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/journey/router.rb:59:in `each'
/home/rubys/git/rails/actionpack/lib/action_dispatch/journey/router.rb:59:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/routing/route_set.rb:676:in `call'
rack (1.5.5) lib/rack/etag.rb:23:in `call'
rack (1.5.5) lib/rack/conditionalget.rb:25:in `call'
rack (1.5.5) lib/rack/head.rb:11:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/params_parser.rb:27:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/flash.rb:241:in `call'
rack (1.5.5) lib/rack/session/abstract/id.rb:225:in `context'
rack (1.5.5) lib/rack/session/abstract/id.rb:220:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/cookies.rb:486:in `call'
/home/rubys/git/rails/activerecord/lib/active_record/query_cache.rb:36:in `call'
/home/rubys/git/rails/activerecord/lib/active_record/connection_adapters/abstract/connection_pool.rb:626:in `call'
/home/rubys/git/rails/activerecord/lib/active_record/migration.rb:373:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/callbacks.rb:29:in `block in call'
/home/rubys/git/rails/activesupport/lib/active_support/callbacks.rb:373:in `_run__2782433338296433600__call__callbacks'
/home/rubys/git/rails/activesupport/lib/active_support/callbacks.rb:80:in `run_callbacks'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/callbacks.rb:27:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/reloader.rb:64:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/remote_ip.rb:76:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/debug_exceptions.rb:17:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/show_exceptions.rb:30:in `call'
/home/rubys/git/rails/railties/lib/rails/rack/logger.rb:38:in `call_app'
/home/rubys/git/rails/railties/lib/rails/rack/logger.rb:20:in `block in call'
/home/rubys/git/rails/activesupport/lib/active_support/tagged_logging.rb:68:in `block in tagged'
/home/rubys/git/rails/activesupport/lib/active_support/tagged_logging.rb:26:in `tagged'
/home/rubys/git/rails/activesupport/lib/active_support/tagged_logging.rb:68:in `tagged'
/home/rubys/git/rails/railties/lib/rails/rack/logger.rb:20:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/request_id.rb:21:in `call'
rack (1.5.5) lib/rack/methodoverride.rb:21:in `call'
rack (1.5.5) lib/rack/runtime.rb:17:in `call'
/home/rubys/git/rails/activesupport/lib/active_support/cache/strategy/local_cache.rb:83:in `call'
rack (1.5.5) lib/rack/lock.rb:17:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/static.rb:84:in `call'
rack (1.5.5) lib/rack/sendfile.rb:112:in `call'
/home/rubys/git/rails/railties/lib/rails/engine.rb:511:in `call'
/home/rubys/git/rails/railties/lib/rails/application.rb:97:in `call'
rack (1.5.5) lib/rack/lock.rb:17:in `call'
rack (1.5.5) lib/rack/content_length.rb:14:in `call'
rack (1.5.5) lib/rack/handler/webrick.rb:60:in `service'
/home/rubys/.rvm/rubies/ruby-2.2.4/lib/ruby/2.2.0/webrick/httpserver.rb:138:in `service'
/home/rubys/.rvm/rubies/ruby-2.2.4/lib/ruby/2.2.0/webrick/httpserver.rb:94:in `run'
/home/rubys/.rvm/rubies/ruby-2.2.4/lib/ruby/2.2.0/webrick/server.rb:294:in `block in start_thread'
Request
Parameters:
None
_csrf_token: "wr8RX+33ErwMbFnhxVPuHlJudbFAQcdT4RTLvdini64="
session_id: "13cbbe93f112ddfa60e6677303807d27"
GATEWAY_INTERFACE: "CGI/1.1"
HTTP_ACCEPT: "text/html"
HTTP_ACCEPT_ENCODING: "gzip;q=1.0,deflate;q=0.6,identity;q=0.3"
REMOTE_ADDR: "127.0.0.1"
REMOTE_HOST: "127.0.0.1"
SERVER_NAME: "localhost"
SERVER_PROTOCOL: "HTTP/1.1"
Response
Headers:
None
Intentionally introduce a typo in a URL
get /say/hullo
HTTP Response Code: 404
No route matches [GET] "/say/hullo"
Rails.root: /home/rubys/git/awdwr/edition4/work-224-40/demo1
Application Trace |
Framework Trace |
Full Trace
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/debug_exceptions.rb:21:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/show_exceptions.rb:30:in `call'
/home/rubys/git/rails/railties/lib/rails/rack/logger.rb:38:in `call_app'
/home/rubys/git/rails/railties/lib/rails/rack/logger.rb:20:in `block in call'
/home/rubys/git/rails/activesupport/lib/active_support/tagged_logging.rb:68:in `block in tagged'
/home/rubys/git/rails/activesupport/lib/active_support/tagged_logging.rb:26:in `tagged'
/home/rubys/git/rails/activesupport/lib/active_support/tagged_logging.rb:68:in `tagged'
/home/rubys/git/rails/railties/lib/rails/rack/logger.rb:20:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/request_id.rb:21:in `call'
rack (1.5.5) lib/rack/methodoverride.rb:21:in `call'
rack (1.5.5) lib/rack/runtime.rb:17:in `call'
/home/rubys/git/rails/activesupport/lib/active_support/cache/strategy/local_cache.rb:83:in `call'
rack (1.5.5) lib/rack/lock.rb:17:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/static.rb:84:in `call'
rack (1.5.5) lib/rack/sendfile.rb:112:in `call'
/home/rubys/git/rails/railties/lib/rails/engine.rb:511:in `call'
/home/rubys/git/rails/railties/lib/rails/application.rb:97:in `call'
rack (1.5.5) lib/rack/lock.rb:17:in `call'
rack (1.5.5) lib/rack/content_length.rb:14:in `call'
rack (1.5.5) lib/rack/handler/webrick.rb:60:in `service'
/home/rubys/.rvm/rubies/ruby-2.2.4/lib/ruby/2.2.0/webrick/httpserver.rb:138:in `service'
/home/rubys/.rvm/rubies/ruby-2.2.4/lib/ruby/2.2.0/webrick/httpserver.rb:94:in `run'
/home/rubys/.rvm/rubies/ruby-2.2.4/lib/ruby/2.2.0/webrick/server.rb:294:in `block in start_thread'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/debug_exceptions.rb:21:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/show_exceptions.rb:30:in `call'
/home/rubys/git/rails/railties/lib/rails/rack/logger.rb:38:in `call_app'
/home/rubys/git/rails/railties/lib/rails/rack/logger.rb:20:in `block in call'
/home/rubys/git/rails/activesupport/lib/active_support/tagged_logging.rb:68:in `block in tagged'
/home/rubys/git/rails/activesupport/lib/active_support/tagged_logging.rb:26:in `tagged'
/home/rubys/git/rails/activesupport/lib/active_support/tagged_logging.rb:68:in `tagged'
/home/rubys/git/rails/railties/lib/rails/rack/logger.rb:20:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/request_id.rb:21:in `call'
rack (1.5.5) lib/rack/methodoverride.rb:21:in `call'
rack (1.5.5) lib/rack/runtime.rb:17:in `call'
/home/rubys/git/rails/activesupport/lib/active_support/cache/strategy/local_cache.rb:83:in `call'
rack (1.5.5) lib/rack/lock.rb:17:in `call'
/home/rubys/git/rails/actionpack/lib/action_dispatch/middleware/static.rb:84:in `call'
rack (1.5.5) lib/rack/sendfile.rb:112:in `call'
/home/rubys/git/rails/railties/lib/rails/engine.rb:511:in `call'
/home/rubys/git/rails/railties/lib/rails/application.rb:97:in `call'
rack (1.5.5) lib/rack/lock.rb:17:in `call'
rack (1.5.5) lib/rack/content_length.rb:14:in `call'
rack (1.5.5) lib/rack/handler/webrick.rb:60:in `service'
/home/rubys/.rvm/rubies/ruby-2.2.4/lib/ruby/2.2.0/webrick/httpserver.rb:138:in `service'
/home/rubys/.rvm/rubies/ruby-2.2.4/lib/ruby/2.2.0/webrick/httpserver.rb:94:in `run'
/home/rubys/.rvm/rubies/ruby-2.2.4/lib/ruby/2.2.0/webrick/server.rb:294:in `block in start_thread'
Routes
Routes match in priority from top to bottom
6.1 Iteration A1: Creating the Products Maintenance Application
Table of Contents