1
0
mirror of https://github.com/funamitech/mastodon synced 2025-01-07 10:23:57 +09:00
YuruToot/spec/lib/status_cache_hydrator_spec.rb

148 lines
4.5 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
require 'rails_helper'
describe StatusCacheHydrator do
let(:status) { Fabricate(:status) }
let(:account) { Fabricate(:account) }
describe '#hydrate' do
let(:compare_to_hash) { InlineRenderer.render(status, account, :status) }
shared_examples 'shared behavior' do
context 'when handling a new status' do
let(:poll) { Fabricate(:poll) }
let(:status) { Fabricate(:status, poll: poll) }
it 'renders the same attributes as a full render' do
expect(subject).to eql(compare_to_hash)
end
end
context 'when handling a new status with own poll' do
let(:poll) { Fabricate(:poll, account: account) }
let(:status) { Fabricate(:status, poll: poll, account: account) }
it 'renders the same attributes as a full render' do
expect(subject).to eql(compare_to_hash)
end
end
context 'when handling a filtered status' do
let(:status) { Fabricate(:status, text: 'this toot is about that banned word') }
before do
account.custom_filters.create!(phrase: 'filter1', context: %w(home), action: :hide, keywords_attributes: [{ keyword: 'banned' }, { keyword: 'irrelevant' }])
end
it 'renders the same attributes as a full render' do
expect(subject).to eql(compare_to_hash)
end
end
context 'when handling a reblog' do
let(:reblog) { Fabricate(:status) }
let(:status) { Fabricate(:status, reblog: reblog) }
2023-05-04 12:49:08 +09:00
context 'when it has been favourited' do
before do
FavouriteService.new.call(account, reblog)
end
it 'renders the same attributes as a full render' do
expect(subject).to eql(compare_to_hash)
end
end
2023-05-04 12:49:08 +09:00
context 'when it has been reblogged' do
before do
ReblogService.new.call(account, reblog)
end
it 'renders the same attributes as a full render' do
expect(subject).to eql(compare_to_hash)
end
end
2023-05-04 12:49:08 +09:00
context 'when it has been pinned' do
let(:reblog) { Fabricate(:status, account: account) }
before do
StatusPin.create!(account: account, status: reblog)
end
it 'renders the same attributes as a full render' do
expect(subject).to eql(compare_to_hash)
end
end
2023-05-04 12:49:08 +09:00
context 'when it has been followed tags' do
let(:followed_tag) { Fabricate(:tag) }
before do
reblog.tags << Fabricate(:tag)
reblog.tags << followed_tag
TagFollow.create!(tag: followed_tag, account: account, rate_limit: false)
end
it 'renders the same attributes as a full render' do
expect(subject).to eql(compare_to_hash)
end
end
2023-05-04 12:49:08 +09:00
context 'when it has a poll authored by the user' do
let(:poll) { Fabricate(:poll, account: account) }
let(:reblog) { Fabricate(:status, poll: poll, account: account) }
it 'renders the same attributes as a full render' do
expect(subject).to eql(compare_to_hash)
end
end
2023-05-04 12:49:08 +09:00
context 'when it has been voted in' do
let(:poll) { Fabricate(:poll, options: %w(Yellow Blue)) }
let(:reblog) { Fabricate(:status, poll: poll) }
before do
VoteService.new.call(account, poll, [0])
end
it 'renders the same attributes as a full render' do
expect(subject).to eql(compare_to_hash)
end
end
2023-05-04 12:49:08 +09:00
context 'when it matches account filters' do
let(:reblog) { Fabricate(:status, text: 'this toot is about that banned word') }
before do
account.custom_filters.create!(phrase: 'filter1', context: %w(home), action: :hide, keywords_attributes: [{ keyword: 'banned' }, { keyword: 'irrelevant' }])
end
it 'renders the same attributes as a full render' do
expect(subject).to eql(compare_to_hash)
end
end
end
end
context 'when cache is warm' do
subject do
Rails.cache.write("fan-out/#{status.id}", InlineRenderer.render(status, nil, :status))
described_class.new(status).hydrate(account.id)
end
it_behaves_like 'shared behavior'
end
context 'when cache is cold' do
subject do
Rails.cache.delete("fan-out/#{status.id}")
described_class.new(status).hydrate(account.id)
end
it_behaves_like 'shared behavior'
end
end
end