mirror of
https://framagit.org/tykayn/mastodon.git
synced 2023-08-25 08:33:12 +02:00
3160e050a9
Conflicts: - `app/helpers/accounts_helper.rb`: Conflict due to upstream changing how followers count is displayed while we have an option to hide followers count. Ported upstream change. - `app/views/accounts/_header.html.haml`: Conflict due to upstream changing how followers count is displayed while we have an option to hide followers count. Ported upstream change. - `app/views/directories/index.html.haml`: Conflict due to upstream changing how followers count is displayed while we have an option to hide followers count. Ported upstream change.
83 lines
2.8 KiB
Ruby
83 lines
2.8 KiB
Ruby
require 'rails_helper'
|
|
|
|
describe TagFeed, type: :service do
|
|
describe '#get' do
|
|
let(:account) { Fabricate(:account) }
|
|
let(:tag1) { Fabricate(:tag) }
|
|
let(:tag2) { Fabricate(:tag) }
|
|
let!(:status1) { Fabricate(:status, tags: [tag1]) }
|
|
let!(:status2) { Fabricate(:status, tags: [tag2]) }
|
|
let!(:both) { Fabricate(:status, tags: [tag1, tag2]) }
|
|
|
|
it 'can add tags in "any" mode' do
|
|
results = described_class.new(tag1, nil, any: [tag2.name]).get(20)
|
|
expect(results).to include status1
|
|
expect(results).to include status2
|
|
expect(results).to include both
|
|
end
|
|
|
|
it 'can remove tags in "all" mode' do
|
|
results = described_class.new(tag1, nil, all: [tag2.name]).get(20)
|
|
expect(results).to_not include status1
|
|
expect(results).to_not include status2
|
|
expect(results).to include both
|
|
end
|
|
|
|
it 'can remove tags in "none" mode' do
|
|
results = described_class.new(tag1, nil, none: [tag2.name]).get(20)
|
|
expect(results).to include status1
|
|
expect(results).to_not include status2
|
|
expect(results).to_not include both
|
|
end
|
|
|
|
it 'ignores an invalid mode' do
|
|
results = described_class.new(tag1, nil, wark: [tag2.name]).get(20)
|
|
expect(results).to include status1
|
|
expect(results).to_not include status2
|
|
expect(results).to include both
|
|
end
|
|
|
|
it 'handles being passed non existent tag names' do
|
|
results = described_class.new(tag1, nil, any: ['wark']).get(20)
|
|
expect(results).to include status1
|
|
expect(results).to_not include status2
|
|
expect(results).to include both
|
|
end
|
|
|
|
it 'can restrict to an account' do
|
|
BlockService.new.call(account, status1.account)
|
|
results = described_class.new(tag1, account, none: [tag2.name]).get(20)
|
|
expect(results).to_not include status1
|
|
end
|
|
|
|
it 'can restrict to local' do
|
|
status1.account.update(domain: 'example.com')
|
|
status1.update(local: false, uri: 'example.com/toot')
|
|
results = described_class.new(tag1, nil, any: [tag2.name], local: true).get(20)
|
|
expect(results).to_not include status1
|
|
end
|
|
|
|
it 'allows replies to be included' do
|
|
original = Fabricate(:status)
|
|
status = Fabricate(:status, tags: [tag1], in_reply_to_id: original.id)
|
|
|
|
results = described_class.new(tag1, nil).get(20)
|
|
expect(results).to include(status)
|
|
end
|
|
|
|
context 'on a local-only status' do
|
|
let!(:status) { Fabricate(:status, tags: [tag1], local_only: true) }
|
|
|
|
it 'does not show local-only statuses without a viewer' do
|
|
results = described_class.new(tag1, nil).get(20)
|
|
expect(results).to_not include(status)
|
|
end
|
|
|
|
it 'shows local-only statuses given a viewer' do
|
|
results = described_class.new(tag1, account).get(20)
|
|
expect(results).to include(status)
|
|
end
|
|
end
|
|
end
|
|
end
|