【问题标题】:No Route Matches ... Rails Engine没有路线匹配... Rails 引擎
【发布时间】:2014-04-07 23:08:09
【问题描述】:

所以我不断收到错误:

No route matches {:action=>"create", :controller=>"xaaron/api_keys"}

测试中抛出的:

it "should not create an api key for those not logged in" do
  post :create
  expect(response).to redirect_to xaaron.login_path
end

当我转到spec/dummy 并运行rake routes 命令时,我看到了:

       api_keys GET    /api_keys(.:format)                 xaaron/api_keys#index
                POST   /api_keys(.:format)                 xaaron/api_keys#create
    new_api_key GET    /api_keys/new(.:format)             xaaron/api_keys#new
   edit_api_key GET    /api_keys/:id/edit(.:format)        xaaron/api_keys#edit
        api_key GET    /api_keys/:id(.:format)             xaaron/api_keys#show
                PATCH  /api_keys/:id(.:format)             xaaron/api_keys#update
                PUT    /api_keys/:id(.:format)             xaaron/api_keys#update
                DELETE /api_keys/:id(.:format)             xaaron/api_keys#destroy

这表明是的,这条路线确实存在。我的这个引擎的路由文件看起来像:

Xaaron::Engine.routes.draw do
      get 'login' => 'sessions#new', :as => 'login'
      get 'logout' => 'sessions#destroy', :as => 'logout'
      get 'signup' => 'users#new', :as => 'signup'
      get 'permission_denied' => 'error#denied', :as => 'permission_denied'
      get 'record_not_found' => 'error#error', :as => 'record_not_found'
      get 'password_reset' => 'password_resets#edit', :as => 'rest_user_password'

      resource :error, controller: 'error'

      resources :users
      resources :api_keys
      resources :sessions
      resources :roles
      resources :password_resets
end

我错过了什么?

更新

对于那些好奇我如何获得这些路由的人,这是因为虚拟应用程序的路由文件是这样设置的(默认情况下):

Rails.application.routes.draw do

  mount Xaaron::Engine => "/xaaron"
end

更新二

我一直在阅读this api docs on how routing is done in engines,我相信我这样做的方式是正确的,但控制器是如何定义的:

module Xaaron
  class ApiKeysController < ActionController::Base
    before_action :authenticate_user!

    def index
      @api_key = Xaaron::ApiKey.where(:user_id => current_user.id)
    end

    def create
      @api_key = Xaaron::ApiKey.new(:user_id => current_user.id, :api_key => SecureRandom.hex(16))
      create_api_key(@api_key)
    end

    def destroy
      Xaaron::ApiKey.find(params[:id]).destroy
      flash[:notice] = 'Api Key has been deleted.'
      redirect_to xarron.api_keys_path
    end
  end
end

【问题讨论】:

  • 感谢您的更新。我将对mount 做一点研究。 api_keys 控制器是如何定义的?它在模块xaaron 内吗?请分享一些具体细节/代码。
  • @KirtiThorat 已经进行了适当的更新。如前所述,我也一直在阅读:api.rubyonrails.org/classes/Rails/Engine.html 以更好地了解路线在引擎中的具体工作方式。而且我相信我已经正确地做到了——尽管我一定遗漏了一些简单的东西。

标签: ruby-on-rails ruby rails-engines


【解决方案1】:

您需要告诉您的规范您正在使用引擎路线:

describe ApiKeysController do
  routes { Xaaron::Engine.routes }

  it "should not create an api key for those not logged in" do
    post :create
    expect(response).to redirect_to xaaron.login_path
  end
end

【讨论】:

猜你喜欢
  • 1970-01-01
  • 2012-10-11
  • 2017-07-13
  • 2013-12-31
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多