環境:
- Rails 3.2.3
- Mac OS X Lion
- Ruby-1.9.3-p194(MRI)
Railsアプリを使用しており、メニューオプションとして使用するいくつかのリンクの一種の「left-nav-pane」としてapp / views / layouts/application.html.erbを使用しています。
メニューにlink_toを使用する2つのリンクがあります(ここでは簡潔にするために縮小しています)。1つのリンクを削除してアプリを実行すると、残りのリンクは本来の機能を果たします。2番目のリンクを削除して最初のリンクを復元すると、最初のリンクはITが行うことになっていることを実行します。
ただし、メニューに両方のリンクが同時にある場合は、どちらか一方をクリックしても機能しますが、2番目をクリックするとランタイムエラーが発生します。
PryとRailsソース自体(3.2.3)を使用して、フレームワークのどこでエラーが発生しているかを特定しました。例外はactionpack-3.2.3/lib / action_view / template.rbで発生し、次のコード行のrenderメソッドで発生しています。
def render(view, locals, buffer=nil, &block)
ActiveSupport::Notifications.instrument("!render_template.action_view", :virtual_path => @virtual_path) do
compile!(view)
view.send(method_name, locals, buffer, &block) # <----ERROR OCCURS HERE
end
rescue Exception => e
handle_render_error(view, e)
end
method_name=_app_views_layouts_application_html_erb___1387085669206687706_70334317584180の値
ビューにはこの名前のメソッドがあります。'send'を実行すると、次の例外が発生します。
ActionController::RoutingError: No route matches {:action=>"signup_for_role",
:controller=>"assignments", :club_id=>nil, :member_id=>[#<Member id: 2, first_name:
"Joseph", last_name: "Smith", start_date: "2012-01-01", end_date: "9999-12-31",
created_at: "2012-04-07 13:58:46", updated_at: "2012-05-06 21:54:12", club_id: 2, email:
"joe.smith@gmail.com", assignable: true, address_one: nil, address_two: nil, city: nil,
state: nil, zip_code: nil, phone: nil, mobile_phone: nil>]}
メソッド内のコードはソースコードファイルではなくRailsによって生成されているため、Pryを使用してステップスルーすることはできません。メッセージを「送信」して結果を確認することしかできません。
問題の2つのリンクを含むレイアウトのコードは次のとおりです。
<!DOCTYPE html>
<html>
<head>
<title>MyApp</title>
<%= stylesheet_link_tag "application" %>
<%= javascript_include_tag "application" %>
<%= csrf_meta_tags %>
</head>
<body>
<div style='padding-left:10px; margin-top:10px; ' >
<div class='container' style='margin-top:50px; margin-left:50px;padding-right:200px; '>
<!-- This link_to works, whether alone, or when the other link_to is present -->
<%= link_to "Sign Up for a Role", signup_for_role_club_member_assignments_path(params[:club_id], current_user_as_member) %>
<br/><br/>
<!-- This link_to fails when both link_to's are present, but works when the other link_to is removed. -->
<%= link_to "Clubs", clubs_path %><br>
</div>
<!-- ***************************************************************** -->
<!-- Yield below... this is where the currently selected view displays -->
<!-- ***************************************************************** -->
<div class='container' style='margin-left:200px' >
<%= yield %>
</div>
</div>
</body>
</html>
最後に、routes.rbファイルは次のとおりです。
Rolemaster::Application.routes.draw do
resources :sessions
resources :enrollments
resources :logs
resources :clubs do
resources :members do
resources :assignments do
collection do
get 'signup_for_role'
get 'display_success'
get 'past_activity'
end
end
resources :absences
end
resources :roles
resources :role_groups
resources :meetings do
get 'forassignment', :on => :collection
get 'print'
resources :assignments
end
resources :assignments do
post 'generate', :on => :collection
end
resources :absences do
get 'list', :on => :collection
end
end
resources :users do
put "update_password" => "users#update_password"
put "update_email" => "users#update_email"
get "edit_password" => "users#edit_password"
get "edit_email" => "users#edit_email"
end
match "agendas/print"
get "enrollments/new"
post "enrollments/create"
get "log_in" => "sessions#new", :as => "log_in"
get "log_out" => "sessions#destroy", :as => "log_out"
get "sign_up" => 'users#new', :as => 'sign_up'
get "test/email"
get "sessions/revoke_admin"
get "sessions/revoke_super_user"
get "admins" => "admins#index"
root :to => 'sessions#new'
end
どんな助けでも大歓迎です。私はおそらくこれまでに20時間以上を費やしました。