debian-mirror-gitlab/spec/lib/gitlab/search/query_spec.rb

102 lines
3.3 KiB
Ruby
Raw Normal View History

2019-12-04 20:38:33 +05:30
# frozen_string_literal: true
2018-11-08 19:23:39 +05:30
require 'spec_helper'
2020-07-28 23:09:34 +05:30
RSpec.describe Gitlab::Search::Query do
2018-11-08 19:23:39 +05:30
let(:query) { 'base filter:wow anotherfilter:noway name:maybe other:mmm leftover' }
let(:subject) do
described_class.new(query) do
filter :filter
filter :name, parser: :upcase.to_proc
filter :other
end
end
it { expect(described_class).to be < SimpleDelegator }
it 'leaves undefined filters in the main query' do
expect(subject.term).to eq('base anotherfilter:noway leftover')
end
it 'parses filters' do
expect(subject.filters.count).to eq(3)
expect(subject.filters.map { |f| f[:value] }).to match_array(%w[wow MAYBE mmm])
end
context 'with an empty filter' do
let(:query) { 'some bar name: baz' }
it 'ignores empty filters' do
expect(subject.term).to eq('some bar name: baz')
end
end
context 'with a pipe' do
let(:query) { 'base | nofilter' }
it 'does not escape the pipe' do
expect(subject.term).to eq(query)
end
end
2020-10-24 23:57:45 +05:30
context 'with an exclusive filter' do
let(:query) { 'something -name:bingo -other:dingo' }
it 'negates the filter' do
expect(subject.filters).to all(include(negated: true))
end
end
2021-03-11 19:13:27 +05:30
context 'with filter value in quotes' do
let(:query) { '"foo bar" name:"my test script.txt"' }
it 'does not break the filter value in quotes' do
expect(subject.term).to eq('"foo bar"')
expect(subject.filters[0]).to include(name: :name, negated: false, value: "MY TEST SCRIPT.TXT")
end
end
context 'with extra white spaces between the query words' do
let(:query) { ' foo = bar name:"my test.txt"' }
it 'removes the extra whitespace between tokens' do
expect(subject.term).to eq('foo = bar')
expect(subject.filters[0]).to include(name: :name, negated: false, value: "MY TEST.TXT")
end
end
2022-11-25 23:54:43 +05:30
context 'with mutliple filename filters' do
let(:query) { 'something filename:myfile.txt -filename:ANOTHERFILE.yml filename:somethingelse.txt' }
let(:subject) do
described_class.new(query) do
filter :filename
end
end
it 'creates a filter for each filename in query' do
expect(subject.filters.count).to eq(3)
expect(subject.filters[0]).to include(name: :filename, negated: false, value: 'myfile.txt')
expect(subject.filters[1]).to include(name: :filename, negated: true, value: 'anotherfile.yml')
expect(subject.filters[2]).to include(name: :filename, negated: false, value: 'somethingelse.txt')
end
context 'when multiple extension filters are added' do
let(:query) { 'something filename:myfile.txt -extension:yml -filename:ANOTHERFILE.yml extension:txt' }
let(:subject) do
described_class.new(query) do
filter :filename
filter :extension
end
end
it 'creates a filter for each filename and extension in query' do
expect(subject.filters.count).to eq(4)
expect(subject.filters[0]).to include(name: :filename, negated: false, value: 'myfile.txt')
expect(subject.filters[1]).to include(name: :filename, negated: true, value: 'anotherfile.yml')
expect(subject.filters[2]).to include(name: :extension, negated: true, value: 'yml')
expect(subject.filters[3]).to include(name: :extension, negated: false, value: 'txt')
end
end
end
2018-11-08 19:23:39 +05:30
end