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
This commit is contained in:
		| @@ -62,4 +62,34 @@ RSpec.describe NotificationMailer, type: :mailer do | ||||
|     end | ||||
|   end | ||||
|  | ||||
|   describe 'follow_request' do | ||||
|     let(:follow_request) { Fabricate(:follow_request, account: sender, target_account: receiver.account) } | ||||
|     let(:mail) { NotificationMailer.follow_request(receiver.account, Notification.create!(account: receiver.account, activity: follow_request)) } | ||||
|  | ||||
|     it 'renders the headers' do | ||||
|       expect(mail.subject).to eq('Pending follower: bob') | ||||
|       expect(mail.to).to eq([receiver.email]) | ||||
|     end | ||||
|  | ||||
|     it 'renders the body' do | ||||
|       expect(mail.body.encoded).to match("bob has requested to follow you") | ||||
|     end | ||||
|   end | ||||
|  | ||||
|   describe 'digest' do | ||||
|     before do | ||||
|       mention = Fabricate(:mention, account: receiver.account) | ||||
|       Fabricate(:notification, account: receiver.account, activity: mention) | ||||
|     end | ||||
|     let(:mail) { NotificationMailer.digest(receiver.account, since: 5.days.ago) } | ||||
|  | ||||
|     it 'renders the headers' do | ||||
|       expect(mail.subject).to match('notification since your last') | ||||
|       expect(mail.to).to eq([receiver.email]) | ||||
|     end | ||||
|  | ||||
|     it 'renders the body' do | ||||
|       expect(mail.body.encoded).to match('brief summary') | ||||
|     end | ||||
|   end | ||||
| end | ||||
|   | ||||
| @@ -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 | ||||
|   | ||||
| @@ -16,4 +16,52 @@ RSpec.describe Subscription, type: :model do | ||||
|       expect(subject.expired?).to be false | ||||
|     end | ||||
|   end | ||||
|  | ||||
|   describe 'lease_seconds' do | ||||
|     it 'returns the time remaing until expiration' do | ||||
|       datetime = 1.day.from_now | ||||
|       subscription = Subscription.new(expires_at: datetime) | ||||
|       travel_to(datetime - 12.hours) do | ||||
|         expect(subscription.lease_seconds).to eq(12.hours) | ||||
|       end | ||||
|     end | ||||
|   end | ||||
|  | ||||
|   describe 'lease_seconds=' do | ||||
|     it 'sets expires_at to min expiration when small value is provided' do | ||||
|       subscription = Subscription.new | ||||
|       datetime = 1.day.from_now | ||||
|       too_low = Subscription::MIN_EXPIRATION - 1000 | ||||
|       travel_to(datetime) do | ||||
|         subscription.lease_seconds = too_low | ||||
|       end | ||||
|  | ||||
|       expected = datetime + Subscription::MIN_EXPIRATION.seconds | ||||
|       expect(subscription.expires_at).to be_within(1.0).of(expected) | ||||
|     end | ||||
|  | ||||
|     it 'sets expires_at to value when valid value is provided' do | ||||
|       subscription = Subscription.new | ||||
|       datetime = 1.day.from_now | ||||
|       valid = Subscription::MIN_EXPIRATION + 1000 | ||||
|       travel_to(datetime) do | ||||
|         subscription.lease_seconds = valid | ||||
|       end | ||||
|  | ||||
|       expected = datetime + valid.seconds | ||||
|       expect(subscription.expires_at).to be_within(1.0).of(expected) | ||||
|     end | ||||
|  | ||||
|     it 'sets expires_at to max expiration when large value is provided' do | ||||
|       subscription = Subscription.new | ||||
|       datetime = 1.day.from_now | ||||
|       too_high = Subscription::MAX_EXPIRATION + 1000 | ||||
|       travel_to(datetime) do | ||||
|         subscription.lease_seconds = too_high | ||||
|       end | ||||
|  | ||||
|       expected = datetime + Subscription::MAX_EXPIRATION.seconds | ||||
|       expect(subscription.expires_at).to be_within(1.0).of(expected) | ||||
|     end | ||||
|   end | ||||
| end | ||||
|   | ||||
| @@ -25,6 +25,7 @@ RSpec.configure do |config| | ||||
|   config.include Devise::Test::ControllerHelpers, type: :controller | ||||
|   config.include Devise::Test::ControllerHelpers, type: :view | ||||
|   config.include Paperclip::Shoulda::Matchers | ||||
|   config.include ActiveSupport::Testing::TimeHelpers | ||||
|  | ||||
|   config.before :each, type: :feature do | ||||
|     https = ENV['LOCAL_HTTPS'] == 'true' | ||||
|   | ||||
| @@ -33,6 +33,6 @@ RSpec.describe SubscribeService do | ||||
|  | ||||
|   it 'fails loudly if PuSH hub is unavailable' do | ||||
|     stub_request(:post, 'http://hub.example.com/').to_return(status: 503) | ||||
|     expect { subject.call(account) }.to raise_error | ||||
|     expect { subject.call(account) }.to raise_error(/Subscription attempt failed/) | ||||
|   end | ||||
| end | ||||
|   | ||||
		Reference in New Issue
	
	Block a user