Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Boxiang Sun
gitlab-ce
Commits
d4eea275
Commit
d4eea275
authored
Nov 24, 2017
by
Douwe Maan
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Modify fuzzy_arel_match to search for equality when a term shorter than 3 characters is provided
parent
b2c5363d
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
30 additions
and
7 deletions
+30
-7
lib/gitlab/sql/pattern.rb
lib/gitlab/sql/pattern.rb
+12
-5
spec/lib/gitlab/sql/pattern_spec.rb
spec/lib/gitlab/sql/pattern_spec.rb
+18
-2
No files found.
lib/gitlab/sql/pattern.rb
View file @
d4eea275
...
...
@@ -4,7 +4,7 @@ module Gitlab
extend
ActiveSupport
::
Concern
MIN_CHARS_FOR_PARTIAL_MATCHING
=
3
REGEX_QUOTED_WORD
=
/(?<=
^| )"[^"]+"(?= |$
)/
REGEX_QUOTED_WORD
=
/(?<=
\A| )"[^"]+"(?= |\z
)/
class_methods
do
def
to_pattern
(
query
)
...
...
@@ -20,11 +20,18 @@ module Gitlab
end
def
fuzzy_arel_match
(
column
,
query
)
words
=
select_fuzzy_words
(
query
)
query
=
query
.
squish
return
nil
unless
query
.
present?
matches
=
words
.
map
{
|
word
|
arel_table
[
column
].
matches
(
to_pattern
(
word
))
}
words
=
select_fuzzy_words
(
query
)
matches
.
reduce
{
|
result
,
match
|
result
.
and
(
match
)
}
if
words
.
any?
words
.
map
{
|
word
|
arel_table
[
column
].
matches
(
to_pattern
(
word
))
}.
reduce
(
:and
)
else
# No words of at least 3 chars, but we can search for an exact
# case insensitive match with the query as a whole
arel_table
[
column
].
matches
(
sanitize_sql_like
(
query
))
end
end
def
select_fuzzy_words
(
query
)
...
...
@@ -32,7 +39,7 @@ module Gitlab
query
=
quoted_words
.
reduce
(
query
)
{
|
q
,
quoted_word
|
q
.
sub
(
quoted_word
,
''
)
}
words
=
query
.
split
(
/\s+/
)
words
=
query
.
split
quoted_words
.
map!
{
|
quoted_word
|
quoted_word
[
1
..-
2
]
}
...
...
spec/lib/gitlab/sql/pattern_spec.rb
View file @
d4eea275
...
...
@@ -151,8 +151,8 @@ describe Gitlab::SQL::Pattern do
context
'with a word shorter than 3 chars'
do
let
(
:query
)
{
'fo'
}
it
'returns
nil
'
do
expect
(
fuzzy_arel_match
).
to
be_nil
it
'returns
a single equality condition
'
do
expect
(
fuzzy_arel_match
.
to_sql
).
to
match
(
/title.*I?LIKE 'fo'/
)
end
end
...
...
@@ -164,6 +164,22 @@ describe Gitlab::SQL::Pattern do
end
end
context
'with two words both shorter than 3 chars'
do
let
(
:query
)
{
'fo ba'
}
it
'returns a single ILIKE condition'
do
expect
(
fuzzy_arel_match
.
to_sql
).
to
match
(
/title.*I?LIKE 'fo ba'/
)
end
end
context
'with two words, one shorter 3 chars'
do
let
(
:query
)
{
'foo ba'
}
it
'returns a single ILIKE condition using the longer word'
do
expect
(
fuzzy_arel_match
.
to_sql
).
to
match
(
/title.+I?LIKE '\%foo\%'/
)
end
end
context
'with a multi-word surrounded by double quote and two words'
do
let
(
:query
)
{
'foo "really bar" baz'
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment