0

環境:

  • 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時間以上を費やしました。

4

1 に答える 1

0

常にエラーメッセージを読んでください真実はそこにあります)

params[:club_id] is nil
于 2012-05-23T22:42:39.420 に答える