控制器规格

一个简单的通过示例

给定一个名为“spec/controllers/widgetscontrollerspec.rb”的文件,其中包含

require "rails_helper"

RSpec.describe WidgetsController, type: :controller do
  describe "GET index" do
    it "has a 200 status code" do
      get :index
      expect(response.status).to eq(200)
    end
  end
end

我运行`rspec spec`时

那么示例应该通过。

控制器暴露给全局 before 钩子

给定一个名为“spec/controllers/widgetscontrollerspec.rb”的文件,其中包含

require "rails_helper"

RSpec.configure {|c| c.before { expect(controller).not_to be_nil }}

RSpec.describe WidgetsController, type: :controller do
  describe "GET index" do
    it "doesn't matter" do
    end
  end
end

我运行`rspec spec`时

那么示例应该通过。

为示例 JSON 设置不同的内容类型(请求类型)

给定一个名为“spec/controllers/widgetscontrollerspec.rb”的文件,其中包含

require "rails_helper"

RSpec.describe WidgetsController, type: :controller do
  describe "responds to" do
    it "responds to html by default" do
      post :create, :params => { :widget => { :name => "Any Name" } }
      expect(response.content_type).to eq "text/html; charset=utf-8"
    end

    it "responds to custom formats when provided in the params" do
      post :create, :params => { :widget => { :name => "Any Name" }, :format => :json }
      expect(response.content_type).to eq "application/json; charset=utf-8"
    end
  end
end

我运行`rspec spec`时

那么示例应该通过。

为示例 JSON 设置不同的媒体类型(请求类型)

给定一个名为“spec/controllers/widgetscontrollerspec.rb”的文件,其中包含

require "rails_helper"

RSpec.describe WidgetsController, type: :controller do
  describe "responds to" do
    it "responds to html by default" do
      post :create, :params => { :widget => { :name => "Any Name" } }
      expect(response.media_type).to eq "text/html"
    end

    it "responds to custom formats when provided in the params" do
      post :create, :params => { :widget => { :name => "Any Name" }, :format => :json }
      expect(response.media_type).to eq "application/json"
    end
  end
end

我运行`rspec spec`时

那么示例应该通过。