forked from fedi/mastodon
60 lines
1.7 KiB
Ruby
60 lines
1.7 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'rails_helper'
|
|
|
|
describe SearchQueryTransformer do
|
|
subject { described_class.new.apply(parser, current_account: nil) }
|
|
|
|
let(:parser) { SearchQueryParser.new.parse(query) }
|
|
|
|
context 'with "hello world"' do
|
|
let(:query) { 'hello world' }
|
|
|
|
it 'transforms clauses' do
|
|
expect(subject.must_clauses.map(&:term)).to match_array %w(hello world)
|
|
expect(subject.must_not_clauses).to be_empty
|
|
expect(subject.filter_clauses).to be_empty
|
|
end
|
|
end
|
|
|
|
context 'with "hello -world"' do
|
|
let(:query) { 'hello -world' }
|
|
|
|
it 'transforms clauses' do
|
|
expect(subject.must_clauses.map(&:term)).to match_array %w(hello)
|
|
expect(subject.must_not_clauses.map(&:term)).to match_array %w(world)
|
|
expect(subject.filter_clauses).to be_empty
|
|
end
|
|
end
|
|
|
|
context 'with "hello is:reply"' do
|
|
let(:query) { 'hello is:reply' }
|
|
|
|
it 'transforms clauses' do
|
|
expect(subject.must_clauses.map(&:term)).to match_array %w(hello)
|
|
expect(subject.must_not_clauses).to be_empty
|
|
expect(subject.filter_clauses.map(&:term)).to match_array %w(reply)
|
|
end
|
|
end
|
|
|
|
context 'with "foo: bar"' do
|
|
let(:query) { 'foo: bar' }
|
|
|
|
it 'transforms clauses' do
|
|
expect(subject.must_clauses.map(&:term)).to match_array %w(foo bar)
|
|
expect(subject.must_not_clauses).to be_empty
|
|
expect(subject.filter_clauses).to be_empty
|
|
end
|
|
end
|
|
|
|
context 'with "foo:bar"' do
|
|
let(:query) { 'foo:bar' }
|
|
|
|
it 'transforms clauses' do
|
|
expect(subject.must_clauses.map(&:term)).to contain_exactly('foo bar')
|
|
expect(subject.must_not_clauses).to be_empty
|
|
expect(subject.filter_clauses).to be_empty
|
|
end
|
|
end
|
|
end
|