Skip to content

Commit

Permalink
fix: prevent global state modification by tests
Browse files Browse the repository at this point in the history
  • Loading branch information
elasticspoon committed Apr 13, 2024
1 parent e877802 commit 08a811d
Show file tree
Hide file tree
Showing 12 changed files with 193 additions and 176 deletions.
13 changes: 2 additions & 11 deletions spec/rails_helper.rb
Original file line number Diff line number Diff line change
Expand Up @@ -211,22 +211,13 @@ def seed_base_data_for_tests
Capybara.server = :puma, { Silent: true }
end

config.before(:each, clean_and_seed_db: true) do
seed_base_data_for_tests
define_global_variables
end

config.after(:each, clean_and_seed_db: true) do
DatabaseCleaner.clean_with(:truncation, except: %w[ar_internal_metadata])
end

config.before(:all, seed_db: true) do
config.before(:all, :seed_db) do
seed_base_data_for_tests
define_global_variables
end

config.after(:all, :seed_db) do
DatabaseCleaner.clean_with(:truncation, except: %w[ar_internal_metadata])
DatabaseCleaner.clean_with(:truncation)
end

config.before(:each) do
Expand Down
10 changes: 5 additions & 5 deletions spec/requests/distributions_by_county_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

RSpec.describe "DistributionsByCounties", type: :request, seed_db: true do
let(:default_params) do
{organization_name: @organization.to_param}
{organization_name: organization.to_param}
end

include_examples "distribution_by_county"
Expand All @@ -15,11 +15,11 @@

context "While signed in as bank" do
before do
sign_in(@user)
sign_in(user)
end

it "shows 'Unspecified 100%' if no served_areas" do
create(:distribution, :with_items, item: item_1, organization: @user.organization)
create(:distribution, :with_items, item: item_1, organization: organization)
get distributions_by_county_report_path(default_params)
expect(response.body).to include("Unspecified")
expect(response.body).to include("100")
Expand All @@ -28,8 +28,8 @@

context "basic behaviour with served areas" do
it "handles multiple partners with overlapping service areas properly" do
create(:distribution, :with_items, item: item_1, organization: @user.organization, partner: partner_1, issued_at: issued_at_present)
create(:distribution, :with_items, item: item_1, organization: @user.organization, partner: partner_2, issued_at: issued_at_present)
create(:distribution, :with_items, item: item_1, organization: organization, partner: partner_1, issued_at: issued_at_present)
create(:distribution, :with_items, item: item_1, organization: organization, partner: partner_2, issued_at: issued_at_present)

get distributions_by_county_report_path(default_params)

Expand Down
88 changes: 46 additions & 42 deletions spec/requests/distributions_requests_spec.rb
Original file line number Diff line number Diff line change
@@ -1,21 +1,25 @@
require 'rails_helper'

RSpec.describe "Distributions", type: :request, clean_and_seed_db: true do
RSpec.describe "Distributions", type: :request, seed_db: true do
let(:organization) { create(:organization, skip_items: true) }
let(:user) { create(:user, organization: organization) }
let(:organization_admin) { create(:organization_admin, organization: organization) }

let(:default_params) do
{ organization_name: @organization.to_param }
{ organization_name: organization.to_param }
end

let(:secret_key) { "HI MOM THIS IS ME AND I'M CODING" }
let(:crypt) { ActiveSupport::MessageEncryptor.new(secret_key) }
let(:hashed_id) { CGI.escape(crypt.encrypt_and_sign(@organization.id)) }
let(:hashed_id) { CGI.escape(crypt.encrypt_and_sign(organization.id)) }
before(:each) do
allow(Rails.application).to receive(:secret_key_base).and_return(secret_key)
allow(DistributionPdf).to receive(:new).and_return(double("DistributionPdf", compute_and_render: "PDF"))
end

context "While signed in" do
before do
sign_in(@user)
sign_in(user)
end

describe "GET #itemized_breakdown" do
Expand Down Expand Up @@ -51,22 +55,22 @@

describe "GET #reclaim" do
it "returns http success" do
get distributions_path(default_params.merge(organization_name: @organization, id: create(:distribution).id))
get distributions_path(default_params.merge(organization_name: organization, id: create(:distribution).id))
expect(response).to be_successful
end
end

describe "GET #index" do
let(:item) { create(:item) }
let!(:distribution) { create(:distribution, :with_items, :past, item: item, item_quantity: 10) }
let(:item) { create(:item, organization: organization) }
let!(:distribution) { create(:distribution, :with_items, :past, item: item, item_quantity: 10, organization: organization) }

it "returns http success" do
get distributions_path(default_params)
expect(response).to be_successful
end

it "sums distribution totals accurately" do
create(:distribution, :with_items, item_quantity: 5)
create(:distribution, :with_items, item_quantity: 5, organization: organization)
create(:line_item, :distribution, itemizable_id: distribution.id, quantity: 7)
get distributions_path(default_params)
expect(assigns(:total_items_all_distributions)).to eq(22)
Expand Down Expand Up @@ -101,8 +105,8 @@
end

describe "POST #create" do
let!(:storage_location) { create(:storage_location) }
let!(:partner) { create(:partner) }
let!(:storage_location) { create(:storage_location, organization: organization) }
let!(:partner) { create(:partner, organization: organization) }
let(:distribution) do
{ distribution: { storage_location_id: storage_location.id, partner_id: partner.id, delivery_method: :delivery } }
end
Expand All @@ -128,10 +132,10 @@
end

describe "GET #new" do
let!(:partner) { create(:partner) }
let(:request) { create(:request, partner: partner) }
let(:storage_location) { create(:storage_location, :with_items) }
let(:default_params) { { organization_name: @organization.to_param, request_id: request.id } }
let!(:partner) { create(:partner, organization: organization) }
let(:request) { create(:request, partner: partner, organization: organization) }
let(:storage_location) { create(:storage_location, :with_items, organization: organization) }
let(:default_params) { { organization_name: organization.to_param, request_id: request.id } }

it "returns http success" do
get new_distribution_path(default_params)
Expand All @@ -143,7 +147,7 @@

context "with org default but no partner default" do
it "selects org default" do
@organization.update!(default_storage_location: storage_location.id)
organization.update!(default_storage_location: storage_location.id)
get new_distribution_path(default_params)
expect(response).to be_successful
page = Nokogiri::HTML(response.body)
Expand All @@ -154,7 +158,7 @@
context "with partner default" do
it "selects partner default" do
location2 = create(:storage_location, :with_items)
@organization.update!(default_storage_location: location2.id)
organization.update!(default_storage_location: location2.id)
partner.update!(default_storage_location_id: storage_location.id)
get new_distribution_path(default_params)
expect(response).to be_successful
Expand All @@ -165,11 +169,11 @@
end

describe "GET #show" do
let(:item) { create(:item) }
let!(:distribution) { create(:distribution, :with_items, item: item, item_quantity: 1) }
let(:item) { create(:item, organization: organization) }
let!(:distribution) { create(:distribution, :with_items, item: item, item_quantity: 1, organization: organization) }

it "sums distribution totals accurately" do
distribution = create(:distribution, :with_items, item_quantity: 1)
distribution = create(:distribution, :with_items, item_quantity: 1, organization: organization)

item_quantity = 6
package_size = 2
Expand Down Expand Up @@ -219,15 +223,15 @@
page = Nokogiri::HTML(response.body)
url = page.at_css('#copy-calendar-button').attributes['data-url'].value
hash = url.match(/\?hash=(.*)&/)[1]
expect(crypt.decrypt_and_verify(CGI.unescape(hash))).to eq(@organization.id)
expect(crypt.decrypt_and_verify(CGI.unescape(hash))).to eq(organization.id)
end
end

describe 'PATCH #picked_up' do
subject { patch picked_up_distribution_path(default_params.merge(id: distribution.id)) }

context 'when the distribution is successfully updated' do
let(:distribution) { create(:distribution, state: :scheduled) }
let(:distribution) { create(:distribution, state: :scheduled, organization: organization) }

it "updates the state to 'complete'" do
subject
Expand All @@ -247,10 +251,10 @@
end

it "correctly sums the item counts from distributions" do
first_item = create(:item)
second_item = create(:item)
first_distribution = create(:distribution)
second_distribution = create(:distribution)
first_item = create(:item, organization: organization)
second_item = create(:item, organization: organization)
first_distribution = create(:distribution, organization: organization)
second_distribution = create(:distribution, organization: organization)
create(:line_item, :distribution, item_id: first_item.id, itemizable_id: first_distribution.id, quantity: 7)
create(:line_item, :distribution, item_id: first_item.id, itemizable_id: second_distribution.id, quantity: 4)
create(:line_item, :distribution, item_id: second_item.id, itemizable_id: second_distribution.id, quantity: 5)
Expand All @@ -261,10 +265,10 @@
end

it "correctly sums the item package counts from distributions" do
first_item = create(:item, package_size: 2)
second_item = create(:item, package_size: 3)
first_distribution = create(:distribution)
second_distribution = create(:distribution)
first_item = create(:item, package_size: 2, organization: organization)
second_item = create(:item, package_size: 3, organization: organization)
first_distribution = create(:distribution, organization: organization)
second_distribution = create(:distribution, organization: organization)

create(:line_item, :distribution, item_id: first_item.id, itemizable_id: first_distribution.id, quantity: 7)
create(:line_item, :distribution, item_id: first_item.id, itemizable_id: second_distribution.id, quantity: 4)
Expand All @@ -282,10 +286,10 @@
end

describe "POST #update" do
let(:location) { create(:storage_location) }
let(:partner) { create(:partner) }
let(:location) { create(:storage_location, organization: organization) }
let(:partner) { create(:partner, organization: organization) }

let(:distribution) { create(:distribution, partner: partner) }
let(:distribution) { create(:distribution, partner: partner, organization: organization) }
let(:issued_at) { distribution.issued_at }
let(:distribution_params) do
default_params.merge(
Expand All @@ -306,11 +310,11 @@
end

describe "when changing storage location" do
let(:item) { create(:item) }
let(:item) { create(:item, organization: organization) }
it "updates storage quantity correctly" do
new_storage_location = create(:storage_location)
create(:donation, :with_items, item: item, item_quantity: 30, storage_location: new_storage_location)
distribution = create(:distribution, :with_items, item: item, item_quantity: 10)
new_storage_location = create(:storage_location, organization: organization)
create(:donation, :with_items, item: item, item_quantity: 30, storage_location: new_storage_location, organization: organization)
distribution = create(:distribution, :with_items, item: item, item_quantity: 10, organization: organization)
original_storage_location = distribution.storage_location
line_item = distribution.line_items.first
line_item_params = {
Expand All @@ -330,9 +334,9 @@

# TODO this test is invalid in event-world since it's handled by the aggregate
it "rollsback updates if quantity would go below 0" do
next if Event.read_events?(@organization)
next if Event.read_events?(organization)

distribution = create(:distribution, :with_items, item_quantity: 10)
distribution = create(:distribution, :with_items, item_quantity: 10, organization: organization)
original_storage_location = distribution.storage_location

# adjust inventory so that updating will set quantity below 0
Expand Down Expand Up @@ -387,8 +391,8 @@
end

describe "GET #edit" do
let(:location) { create(:storage_location) }
let(:partner) { create(:partner) }
let(:location) { create(:storage_location, organization: organization) }
let(:partner) { create(:partner, organization: organization) }

let(:distribution) { create(:distribution, partner: partner) }

Expand All @@ -400,7 +404,7 @@

it "should show a warning if there is an inteverning audit" do
distribution.update!(created_at: 1.week.ago)
create(:audit, storage_location: distribution.storage_location)
create(:audit, storage_location: distribution.storage_location, organization: organization)
get edit_distribution_path(default_params.merge(id: distribution.id))
expect(response.body).to include("You’ve had an audit since this distribution was started.")
end
Expand Down Expand Up @@ -428,7 +432,7 @@
context 'with a correct hash id' do
it 'should render the calendar' do
get distributions_calendar_path(hash: hashed_id)
expect(CalendarService).to have_received(:calendar).with(@organization.id)
expect(CalendarService).to have_received(:calendar).with(organization.id)
expect(response.media_type).to include('text/calendar')
expect(response.body).to eq('SOME ICS STRING')
end
Expand Down
26 changes: 15 additions & 11 deletions spec/requests/users_requests_spec.rb
Original file line number Diff line number Diff line change
@@ -1,13 +1,17 @@
require "rails_helper"

RSpec.describe "Users", type: :request, clean_and_seed_db: true do
RSpec.describe "Users", type: :request, seed_db: true do
let(:organization) { create(:organization, skip_items: true) }
let(:user) { create(:user, organization: organization) }
let(:organization_admin) { create(:organization_admin, organization: organization) }

let(:partner) { create(:partner) }
let(:default_params) do
{ organization_name: @organization.to_param }
{ organization_name: organization.to_param }
end

before do
sign_in(@user)
sign_in(user)
end

describe "GET #index" do
Expand All @@ -25,13 +29,13 @@
end

describe "POST #send_partner_user_reset_password" do
let(:partner) { create(:partner) }
let(:partner) { create(:partner, organization: organization) }
let!(:user) { create(:partner_user, partner: partner, email: "[email protected]") }
let(:params) { default_params.merge(partner_id: partner.id, email: "[email protected]") }

it "should send a password" do
post partner_user_reset_password_users_path(params)
expect(response).to redirect_to(root_path(organization_name: @organization.to_param))
expect(response).to redirect_to(root_path(organization_name: organization.to_param))
expect(ActionMailer::Base.deliveries.size).to eq(1)
end

Expand Down Expand Up @@ -62,21 +66,21 @@
end
context "with a partner role" do
it "should redirect to the partner path" do
@user.add_role(Role::PARTNER, partner)
get switch_to_role_users_path(@organization,
role_id: @user.roles.find { |r| r.name == Role::PARTNER.to_s })
user.add_role(Role::PARTNER, partner)
get switch_to_role_users_path(organization,
role_id: user.roles.find { |r| r.name == Role::PARTNER.to_s })
# all bank controllers add organization_id to all routes - there's no way to
# avoid it
expect(response).to redirect_to(partners_dashboard_path(organization_name: @organization.to_param))
expect(response).to redirect_to(partners_dashboard_path(organization_name: organization.to_param))
end
end

context "without a partner role" do
it "should redirect to the root path with an error" do
get switch_to_role_users_path(@organization, role_id: admin_user.roles.first.id)
get switch_to_role_users_path(organization, role_id: admin_user.roles.first.id)
message = "Attempted to switch to a role that doesn't belong to you!"
expect(flash[:alert]).to eq(message)
expect(response).to redirect_to(root_path(@organization))
expect(response).to redirect_to(root_path(organization))
end
end
end
Expand Down
11 changes: 5 additions & 6 deletions spec/services/distributions_by_county_report_service_spec.rb
Original file line number Diff line number Diff line change
@@ -1,26 +1,25 @@
RSpec.describe DistributionByCountyReportService, type: :service, seed_db: true do
let(:organization) { create(:organization) }
let(:year) { Time.current.year }
let(:issued_at_last_year) { Time.current.utc.change(year: year - 1).to_datetime }
let(:distributions) { [] }

include_examples "distribution_by_county"

before do
@storage_location = create(:storage_location, organization: @organization)
create(:storage_location, organization: organization)
end

describe "get_breakdown" do
it "will have 100% unspecified shows if no served_areas" do
distribution_1 = create(:distribution, :with_items, item: item_1, organization: @user.organization)
distribution_1 = create(:distribution, :with_items, item: item_1, organization: user.organization)
breakdown = DistributionByCountyReportService.new.get_breakdown([distribution_1])
expect(breakdown.size).to eq(1)
expect(breakdown[0].num_items).to eq(100)
expect(breakdown[0].amount).to be_within(0.01).of(105000.0)
end

it "divides the item numbers and values according to the partner profile" do
distribution_1 = create(:distribution, :with_items, item: item_1, organization: @user.organization, partner: partner_1)
distribution_1 = create(:distribution, :with_items, item: item_1, organization: user.organization, partner: partner_1)
breakdown = DistributionByCountyReportService.new.get_breakdown([distribution_1])
expect(breakdown.size).to eq(5)
expect(breakdown[4].num_items).to eq(0)
Expand All @@ -32,8 +31,8 @@
end

it "handles multiple partners with overlapping service areas properly" do
distribution_p1 = create(:distribution, :with_items, item: item_1, organization: @user.organization, partner: partner_1, issued_at: issued_at_present)
distribution_p2 = create(:distribution, :with_items, item: item_1, organization: @user.organization, partner: partner_2, issued_at: issued_at_present)
distribution_p1 = create(:distribution, :with_items, item: item_1, organization: user.organization, partner: partner_1, issued_at: issued_at_present)
distribution_p2 = create(:distribution, :with_items, item: item_1, organization: user.organization, partner: partner_2, issued_at: issued_at_present)
breakdown = DistributionByCountyReportService.new.get_breakdown([distribution_p1, distribution_p2])
num_with_45 = 0
num_with_20 = 0
Expand Down
Loading

0 comments on commit 08a811d

Please sign in to comment.