mirror of
https://git.bsd.gay/fef/nyastodon.git
synced 2025-01-12 15:07:02 +01:00
6d7e05ec1f
* Add tests for StreamEntry - `#object_type` - `#verb` - `#mentions` * Fix to test results instead of implementations
192 lines
4.5 KiB
Ruby
192 lines
4.5 KiB
Ruby
require 'rails_helper'
|
|
|
|
RSpec.describe StreamEntry, type: :model do
|
|
let(:alice) { Fabricate(:account, username: 'alice') }
|
|
let(:bob) { Fabricate(:account, username: 'bob') }
|
|
let(:status) { Fabricate(:status, account: alice) }
|
|
let(:reblog) { Fabricate(:status, account: bob, reblog: status) }
|
|
let(:reply) { Fabricate(:status, account: bob, thread: status) }
|
|
let(:stream_entry) { Fabricate(:stream_entry, activity: activity) }
|
|
let(:activity) { reblog }
|
|
|
|
describe '#object_type' do
|
|
before do
|
|
allow(stream_entry).to receive(:orphaned?).and_return(orphaned)
|
|
allow(stream_entry).to receive(:targeted?).and_return(targeted)
|
|
end
|
|
|
|
subject { stream_entry.object_type }
|
|
|
|
context 'orphaned? is true' do
|
|
let(:orphaned) { true }
|
|
let(:targeted) { false }
|
|
|
|
it 'returns :activity' do
|
|
is_expected.to be :activity
|
|
end
|
|
end
|
|
|
|
context 'targeted? is true' do
|
|
let(:orphaned) { false }
|
|
let(:targeted) { true }
|
|
|
|
it 'returns :activity' do
|
|
is_expected.to be :activity
|
|
end
|
|
end
|
|
|
|
context 'orphaned? and targeted? are false' do
|
|
let(:orphaned) { false }
|
|
let(:targeted) { false }
|
|
|
|
context 'activity is reblog' do
|
|
let(:activity) { reblog }
|
|
|
|
it 'returns :note' do
|
|
is_expected.to be :note
|
|
end
|
|
end
|
|
|
|
context 'activity is reply' do
|
|
let(:activity) { reply }
|
|
|
|
it 'returns :comment' do
|
|
is_expected.to be :comment
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
describe '#verb' do
|
|
before do
|
|
allow(stream_entry).to receive(:orphaned?).and_return(orphaned)
|
|
end
|
|
|
|
subject { stream_entry.verb }
|
|
|
|
context 'orphaned? is true' do
|
|
let(:orphaned) { true }
|
|
|
|
it 'returns :delete' do
|
|
is_expected.to be :delete
|
|
end
|
|
end
|
|
|
|
context 'orphaned? is false' do
|
|
let(:orphaned) { false }
|
|
|
|
context 'activity is reblog' do
|
|
let(:activity) { reblog }
|
|
|
|
it 'returns :share' do
|
|
is_expected.to be :share
|
|
end
|
|
end
|
|
|
|
context 'activity is reply' do
|
|
let(:activity) { reply }
|
|
|
|
it 'returns :post' do
|
|
is_expected.to be :post
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
describe '#mentions' do
|
|
before do
|
|
allow(stream_entry).to receive(:orphaned?).and_return(orphaned)
|
|
end
|
|
|
|
subject { stream_entry.mentions }
|
|
|
|
context 'orphaned? is true' do
|
|
let(:orphaned) { true }
|
|
|
|
it 'returns []' do
|
|
is_expected.to eq []
|
|
end
|
|
end
|
|
|
|
context 'orphaned? is false' do
|
|
before do
|
|
reblog.mentions << Fabricate(:mention, account: alice)
|
|
reblog.mentions << Fabricate(:mention, account: bob)
|
|
end
|
|
|
|
let(:orphaned) { false }
|
|
|
|
it 'returns [Account] includes alice and bob' do
|
|
is_expected.to eq [alice, bob]
|
|
end
|
|
end
|
|
end
|
|
|
|
describe '#targeted?' do
|
|
it 'returns true for a reblog' do
|
|
expect(reblog.stream_entry.targeted?).to be true
|
|
end
|
|
|
|
it 'returns false otherwise' do
|
|
expect(status.stream_entry.targeted?).to be false
|
|
end
|
|
end
|
|
|
|
describe '#threaded?' do
|
|
it 'returns true for a reply' do
|
|
expect(reply.stream_entry.threaded?).to be true
|
|
end
|
|
|
|
it 'returns false otherwise' do
|
|
expect(status.stream_entry.threaded?).to be false
|
|
end
|
|
end
|
|
|
|
describe 'delegated methods' do
|
|
context 'with a nil status' do
|
|
subject { described_class.new(status: nil) }
|
|
|
|
it 'returns nil for target' do
|
|
expect(subject.target).to be_nil
|
|
end
|
|
|
|
it 'returns nil for title' do
|
|
expect(subject.title).to be_nil
|
|
end
|
|
|
|
it 'returns nil for content' do
|
|
expect(subject.content).to be_nil
|
|
end
|
|
|
|
it 'returns nil for thread' do
|
|
expect(subject.thread).to be_nil
|
|
end
|
|
end
|
|
|
|
context 'with a real status' do
|
|
let(:original) { Fabricate(:status, text: 'Test status') }
|
|
let(:status) { Fabricate(:status, reblog: original, thread: original) }
|
|
subject { described_class.new(status: status) }
|
|
|
|
it 'delegates target' do
|
|
expect(status.target).not_to be_nil
|
|
expect(subject.target).to eq(status.target)
|
|
end
|
|
|
|
it 'delegates title' do
|
|
expect(status.title).not_to be_nil
|
|
expect(subject.title).to eq(status.title)
|
|
end
|
|
|
|
it 'delegates content' do
|
|
expect(status.content).not_to be_nil
|
|
expect(subject.content).to eq(status.content)
|
|
end
|
|
|
|
it 'delegates thread' do
|
|
expect(status.thread).not_to be_nil
|
|
expect(subject.thread).to eq(status.thread)
|
|
end
|
|
end
|
|
end
|
|
end
|