Files
growstuff/spec/controllers/gardens_controller_spec.rb
google-labs-jules[bot] 6c7903c2a5 Fix RSpec/ExpectInHook offenses
- Move expectations from `before` hooks to `it` blocks.
- Ensure controller actions are called after expectations are set in controller specs.
- Replace synchronization expectations in hooks with Capybara `find` calls.
- Remove RSpec/ExpectInHook from .rubocop_todo.yml.

Co-authored-by: CloCkWeRX <365751+CloCkWeRX@users.noreply.github.com>
2026-04-25 18:39:43 +00:00

118 lines
3.9 KiB
Ruby

# frozen_string_literal: true
require 'rails_helper'
RSpec.describe GardensController do
include Devise::Test::ControllerHelpers
let(:valid_params) { { name: 'My second Garden' } }
let(:garden) { create(:garden) }
context "when not signed in" do
describe 'GET new' do
before { get :new, params: { slug: garden.to_param } }
it { expect(response).to redirect_to(new_member_session_path) }
end
describe 'PUT create' do
before { put :create, params: { garden: valid_params } }
it { expect(response).to redirect_to(new_member_session_path) }
end
describe 'changing existing records' do
before do
allow(Garden).to receive(:find).and_return(:garden)
end
describe 'GET edit' do
it "redirects to login" do
expect(garden).not_to receive(:save)
expect(garden).not_to receive(:save!)
expect(garden).not_to receive(:update)
expect(garden).not_to receive(:update!)
expect(garden).not_to receive(:destroy)
get :edit, params: { slug: garden.to_param }
expect(response).to redirect_to(new_member_session_path)
end
end
describe 'POST update' do
it "redirects to login" do
expect(garden).not_to receive(:save)
expect(garden).not_to receive(:save!)
expect(garden).not_to receive(:update)
expect(garden).not_to receive(:update!)
expect(garden).not_to receive(:destroy)
post :update, params: { slug: garden.to_param, garden: valid_params }
expect(response).to redirect_to(new_member_session_path)
end
end
describe 'DELETE' do
it "redirects to login" do
expect(garden).not_to receive(:save)
expect(garden).not_to receive(:save!)
expect(garden).not_to receive(:update)
expect(garden).not_to receive(:update!)
expect(garden).not_to receive(:destroy)
delete :destroy, params: { slug: garden.to_param, params: { garden: valid_params } }
expect(response).to redirect_to(new_member_session_path)
end
end
end
end
context "when signed in" do
before { sign_in member }
let!(:member) { create(:member) }
describe "for another member's garden" do
let(:not_my_garden) { double('garden') }
before do
allow(Garden).to receive(:find).and_return(:not_my_garden)
end
describe 'GET edit' do
it "redirects to root" do
expect(not_my_garden).not_to receive(:save)
expect(not_my_garden).not_to receive(:save!)
expect(not_my_garden).not_to receive(:update)
expect(not_my_garden).not_to receive(:update!)
expect(not_my_garden).not_to receive(:destroy)
get :edit, params: { slug: not_my_garden.to_param }
expect(response).to redirect_to(root_path)
end
end
describe 'POST update' do
it "redirects to root" do
expect(not_my_garden).not_to receive(:save)
expect(not_my_garden).not_to receive(:save!)
expect(not_my_garden).not_to receive(:update)
expect(not_my_garden).not_to receive(:update!)
expect(not_my_garden).not_to receive(:destroy)
post :update, params: { slug: not_my_garden.to_param, garden: valid_params }
expect(response).to redirect_to(root_path)
end
end
describe 'DELETE' do
it "redirects to root" do
expect(not_my_garden).not_to receive(:save)
expect(not_my_garden).not_to receive(:save!)
expect(not_my_garden).not_to receive(:update)
expect(not_my_garden).not_to receive(:update!)
expect(not_my_garden).not_to receive(:destroy)
delete :destroy, params: { slug: not_my_garden.to_param, params: { garden: valid_params } }
expect(response).to redirect_to(root_path)
end
end
end
end
end