mirror of
https://github.com/openfoodfoundation/openfoodnetwork
synced 2026-01-24 20:36:49 +00:00
68 lines
1.9 KiB
Ruby
68 lines
1.9 KiB
Ruby
require 'spec_helper'
|
|
|
|
module Api
|
|
describe CustomersController, type: :controller do
|
|
include AuthenticationWorkflow
|
|
render_views
|
|
|
|
let(:user) { create(:user) }
|
|
|
|
describe "index" do
|
|
let!(:customer1) { create(:customer) }
|
|
let!(:customer2) { create(:customer) }
|
|
|
|
before do
|
|
user.customers << customer1
|
|
allow(controller).to receive(:spree_current_user) { user }
|
|
end
|
|
|
|
it "lists customers associated with the current user" do
|
|
spree_get :index
|
|
expect(response.status).to eq 200
|
|
expect(json_response.length).to eq 1
|
|
expect(json_response.first[:id]).to eq customer1.id
|
|
end
|
|
end
|
|
|
|
describe "#update" do
|
|
let(:customer) { create(:customer, user: user) }
|
|
let(:params) { { format: :json, id: customer.id, customer: { code: '123' } } }
|
|
|
|
context "as a user who is not associated with the customer" do
|
|
before do
|
|
allow(controller).to receive(:spree_current_user) { create(:user) }
|
|
end
|
|
|
|
it "returns unauthorized" do
|
|
spree_post :update, params
|
|
assert_unauthorized!
|
|
end
|
|
end
|
|
|
|
context "as the user associated with the customer" do
|
|
before do
|
|
allow(controller).to receive(:spree_current_user) { user }
|
|
end
|
|
|
|
context "when the update request is successful" do
|
|
it "returns the id of the updated customer" do
|
|
spree_post :update, params
|
|
expect(response.status).to eq 200
|
|
expect(json_response[:id]).to eq customer.id
|
|
end
|
|
end
|
|
|
|
context "when the update request fails" do
|
|
before { params[:customer][:email] = '' }
|
|
|
|
it "returns a 422, with an error message" do
|
|
spree_post :update, params
|
|
expect(response.status).to be 422
|
|
expect(json_response[:error]).to be
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|