about summary refs log blame commit diff
path: root/spec/models/stream_entry_spec.rb
blob: 8f8bfbd5837566711f583e6b86c33b1772c6e866 (plain) (tree)
1
2
3
4
5
6
7
8

                                           
                                                            

                                                                      

















































































































                                                                     
 
                          





                                                       

                          





                                                       
     














































                                                                             
   
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