From 484c9709b67685c95de351a39e3dfb140acd3681 Mon Sep 17 00:00:00 2001 From: Matt Jankowski Date: Fri, 5 May 2017 14:56:00 -0400 Subject: Misc spec coverage improvements (#2821) * Dont use raise_error by itself (avoids warning) * Add coverage for AccountFilter * Improve coverage and refactor for Subscription#lease_seconds * Improve coverage and refactor for NotificationMailer * Simplify assignment of min/max threshold on subscription --- spec/models/account_filter_spec.rb | 18 +++++++++++++++--- 1 file changed, 15 insertions(+), 3 deletions(-) (limited to 'spec/models/account_filter_spec.rb') diff --git a/spec/models/account_filter_spec.rb b/spec/models/account_filter_spec.rb index 1599c5ae8..52b4c4893 100644 --- a/spec/models/account_filter_spec.rb +++ b/spec/models/account_filter_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' describe AccountFilter do describe 'with empty params' do it 'defaults to alphabetic account list' do - filter = AccountFilter.new({}) + filter = described_class.new({}) expect(filter.results).to eq Account.alphabetic end @@ -11,7 +11,7 @@ describe AccountFilter do describe 'with invalid params' do it 'raises with key error' do - filter = AccountFilter.new(wrong: true) + filter = described_class.new(wrong: true) expect { filter.results }.to raise_error(/wrong/) end @@ -19,7 +19,7 @@ describe AccountFilter do describe 'with valid params' do it 'combines filters on Account' do - filter = AccountFilter.new(by_domain: 'test.com', silenced: true) + filter = described_class.new(by_domain: 'test.com', silenced: true) allow(Account).to receive(:where).and_return(Account.none) allow(Account).to receive(:silenced).and_return(Account.none) @@ -27,5 +27,17 @@ describe AccountFilter do expect(Account).to have_received(:where).with(domain: 'test.com') expect(Account).to have_received(:silenced) end + + describe 'that call account methods' do + %i(local remote silenced recent).each do |option| + it "delegates the #{option} option" do + allow(Account).to receive(option).and_return(Account.none) + filter = described_class.new({ option => true }) + filter.results + + expect(Account).to have_received(option) + end + end + end end end -- cgit