Sha256: 510fb026173c2fc67a123f1f1d65cc75423cfbe2ab77f149dd76c751c3ad544e

Contents?: true

Size: 1.01 KB

Versions: 5

Compression:

Stored size: 1.01 KB

Contents

RSpec.describe Spree::ProductsController, type: :controller do
  let!(:product) { create(:product, available_on: 1.year.from_now) }
  let!(:user) { build_stubbed(:user, spree_api_key: 'fake') }

  subject(:request) { get :show, params: { id: product.to_param }}

  before do
    allow(controller).to receive(:before_save_new_order)
    allow(controller).to receive(:spree_current_user) { user }
  end

  it 'allows admins to view non-active products' do
    allow(user).to receive(:has_spree_role?) { true }

    request
    expect(response.status).to eq(200)
  end

  it 'cannot view non-active products' do
    skip if Spree.version.to_f > 4.0
    allow(user).to receive(:has_spree_role?) { false }

    # this behaviour was introduced in rails 5.1 & Spree 3.5
    # https://github.com/spree/spree/commit/acf52960f5b9582cdfe01f0cb563766b44aabbd5
    if Spree.version.to_f > 3.4
      expect { request }.to raise_error(ActiveRecord::RecordNotFound)
    else
      request
      expect(response.status).to eq(404)
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
spree_auth_devise-4.6.3 spec/controllers/spree/products_controller_spec.rb
spree_auth_devise-4.6.2 spec/controllers/spree/products_controller_spec.rb
spree_auth_devise-4.6.1 spec/controllers/spree/products_controller_spec.rb
spree_auth_devise-4.6.0 spec/controllers/spree/products_controller_spec.rb
spree_auth_devise-4.5.0 spec/controllers/spree/products_controller_spec.rb