mirror of
https://github.com/mattermost/mattermost.git
synced 2025-02-25 18:55:24 -06:00
* initial implementation of after, before, on search flags allowing to restrict the search to a specific day or a date range * missed setting beforeDate in SearchParams in one place * fixed condition when only flags are used for search without any plain terms * changed date format used for after/before/on flags to be in ISO8601 format as suggested in PR comments, added a helper function to pad month and day with zeroes allowing the user user either format, with or without leading zeroes * corrected expected compare to date setting for the TestParseDateFilterToTimeISO8601 test * fixed a bug for the scenario when you only have the date flags without any terms, added a couple of tests for that scenario * updated the date filter logic to use parameters to construct the query instead of simply appending strings together, as suggested in the pull request comments * added search unit test using date flags * added a helper function to create a test post with a createat date manually set, updated the test for search using date flags to create test posts with different createat dates to be able to better test the functionality * MM-11817 Add support for after/before/on search flags with Elasticsearch * add support to search posts to perform the search in context of the client's timezone when filtering by createat date using on: after: before: flags * updated tests to match the new signature
304 lines
15 KiB
Go
304 lines
15 KiB
Go
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See License.txt for license information.
|
|
|
|
package model
|
|
|
|
import (
|
|
"testing"
|
|
)
|
|
|
|
func TestSplitWords(t *testing.T) {
|
|
if words := splitWords(""); len(words) != 0 {
|
|
t.Fatalf("Incorrect output splitWords: %v", words)
|
|
}
|
|
|
|
if words := splitWords(" "); len(words) != 0 {
|
|
t.Fatalf("Incorrect output splitWords: %v", words)
|
|
}
|
|
|
|
if words := splitWords("word"); len(words) != 1 || words[0] != "word" {
|
|
t.Fatalf("Incorrect output splitWords: %v", words)
|
|
}
|
|
|
|
if words := splitWords("wo\"rd"); len(words) != 2 || words[0] != "wo" || words[1] != "\"rd" {
|
|
t.Fatalf("Incorrect output splitWords: %v", words)
|
|
}
|
|
|
|
if words := splitWords("wo\"rd\""); len(words) != 2 || words[0] != "wo" || words[1] != "\"rd\"" {
|
|
t.Fatalf("Incorrect output splitWords: %v", words)
|
|
}
|
|
|
|
if words := splitWords("word1 word2 word3"); len(words) != 3 || words[0] != "word1" || words[1] != "word2" || words[2] != "word3" {
|
|
t.Fatalf("Incorrect output splitWords: %v", words)
|
|
}
|
|
|
|
if words := splitWords("word1 \"word2 word3"); len(words) != 3 || words[0] != "word1" || words[1] != "\"word2" || words[2] != "word3" {
|
|
t.Fatalf("Incorrect output splitWords: %v", words)
|
|
}
|
|
|
|
if words := splitWords("\"word1 word2 word3"); len(words) != 3 || words[0] != "\"word1" || words[1] != "word2" || words[2] != "word3" {
|
|
t.Fatalf("Incorrect output splitWords: %v", words)
|
|
}
|
|
|
|
if words := splitWords("word1 word2 word3\""); len(words) != 4 || words[0] != "word1" || words[1] != "word2" || words[2] != "word3" || words[3] != "\"" {
|
|
t.Fatalf("Incorrect output splitWords: %v", words)
|
|
}
|
|
|
|
if words := splitWords("word1 #word2 ##word3"); len(words) != 3 || words[0] != "word1" || words[1] != "#word2" || words[2] != "##word3" {
|
|
t.Fatalf("Incorrect output splitWords: %v", words)
|
|
}
|
|
|
|
if words := splitWords(" word1 word2 word3 "); len(words) != 3 || words[0] != "word1" || words[1] != "word2" || words[2] != "word3" {
|
|
t.Fatalf("Incorrect output splitWords: %v", words)
|
|
}
|
|
|
|
if words := splitWords("\"quoted\""); len(words) != 1 || words[0] != "\"quoted\"" {
|
|
t.Fatalf("Incorrect output splitWords: %v", words)
|
|
}
|
|
|
|
if words := splitWords("\"quoted multiple words\""); len(words) != 1 || words[0] != "\"quoted multiple words\"" {
|
|
t.Fatalf("Incorrect output splitWords: %v", words)
|
|
}
|
|
|
|
if words := splitWords("some stuff \"quoted multiple words\" more stuff"); len(words) != 5 || words[0] != "some" || words[1] != "stuff" || words[2] != "\"quoted multiple words\"" || words[3] != "more" || words[4] != "stuff" {
|
|
t.Fatalf("Incorrect output splitWords: %v", words)
|
|
}
|
|
|
|
if words := splitWords("some \"stuff\" \"quoted multiple words\" #some \"more stuff\""); len(words) != 5 || words[0] != "some" || words[1] != "\"stuff\"" || words[2] != "\"quoted multiple words\"" || words[3] != "#some" || words[4] != "\"more stuff\"" {
|
|
t.Fatalf("Incorrect output splitWords: %v", words)
|
|
}
|
|
}
|
|
|
|
func TestParseSearchFlags(t *testing.T) {
|
|
if words, flags := parseSearchFlags(splitWords("")); len(words) != 0 {
|
|
t.Fatalf("got words from empty input")
|
|
} else if len(flags) != 0 {
|
|
t.Fatalf("got flags from empty input")
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("word")); len(words) != 1 || words[0] != "word" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 0 {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("apple banana cherry")); len(words) != 3 || words[0] != "apple" || words[1] != "banana" || words[2] != "cherry" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 0 {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("apple banana from:chan")); len(words) != 2 || words[0] != "apple" || words[1] != "banana" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 1 || flags[0][0] != "from" || flags[0][1] != "chan" {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("#apple #banana from:chan")); len(words) != 2 || words[0] != "#apple" || words[1] != "#banana" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 1 || flags[0][0] != "from" || flags[0][1] != "chan" {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("apple banana from: chan")); len(words) != 2 || words[0] != "apple" || words[1] != "banana" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 1 || flags[0][0] != "from" || flags[0][1] != "chan" {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("apple banana in: chan")); len(words) != 2 || words[0] != "apple" || words[1] != "banana" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 1 || flags[0][0] != "in" || flags[0][1] != "chan" {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("apple banana channel:chan")); len(words) != 2 || words[0] != "apple" || words[1] != "banana" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 1 || flags[0][0] != "channel" || flags[0][1] != "chan" {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("fruit: cherry")); len(words) != 2 || words[0] != "fruit" || words[1] != "cherry" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 0 {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("channel:")); len(words) != 1 || words[0] != "channel" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 0 {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("channel: first in: second from:")); len(words) != 1 || words[0] != "from" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 2 || flags[0][0] != "channel" || flags[0][1] != "first" || flags[1][0] != "in" || flags[1][1] != "second" {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("channel: first channel: second from: third from: fourth")); len(words) != 0 {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 4 || flags[0][0] != "channel" || flags[0][1] != "first" || flags[1][0] != "channel" || flags[1][1] != "second" ||
|
|
flags[2][0] != "from" || flags[2][1] != "third" || flags[3][0] != "from" || flags[3][1] != "fourth" {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("\"quoted\"")); len(words) != 1 || words[0] != "\"quoted\"" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 0 {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("\"quoted multiple words\"")); len(words) != 1 || words[0] != "\"quoted multiple words\"" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 0 {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("some \"stuff\" \"quoted multiple words\" some \"more stuff\"")); len(words) != 5 || words[0] != "some" || words[1] != "\"stuff\"" || words[2] != "\"quoted multiple words\"" || words[3] != "some" || words[4] != "\"more stuff\"" {
|
|
t.Fatalf("Incorrect output splitWords: %v", words)
|
|
} else if len(flags) != 0 {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("some in:here \"stuff\" \"quoted multiple words\" from:someone \"more stuff\"")); len(words) != 4 || words[0] != "some" || words[1] != "\"stuff\"" || words[2] != "\"quoted multiple words\"" || words[3] != "\"more stuff\"" {
|
|
t.Fatalf("Incorrect output splitWords: %v", words)
|
|
} else if len(flags) != 2 || flags[0][0] != "in" || flags[0][1] != "here" || flags[1][0] != "from" || flags[1][1] != "someone" {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("after:2018-1-1")); len(words) != 0 {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 1 || flags[0][0] != "after" || flags[0][1] != "2018-1-1" {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("apple banana after:2018-1-1")); len(words) != 2 || words[0] != "apple" || words[1] != "banana" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 1 || flags[0][0] != "after" || flags[0][1] != "2018-1-1" {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("apple banana before:2018-1-1")); len(words) != 2 || words[0] != "apple" || words[1] != "banana" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 1 || flags[0][0] != "before" || flags[0][1] != "2018-1-1" {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("apple banana after:2018-1-1 before:2018-1-10")); len(words) != 2 || words[0] != "apple" || words[1] != "banana" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 2 || flags[0][0] != "after" || flags[0][1] != "2018-1-1" || flags[1][0] != "before" || flags[1][1] != "2018-1-10" {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("#apple #banana after:2018-1-1")); len(words) != 2 || words[0] != "#apple" || words[1] != "#banana" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 1 || flags[0][0] != "after" || flags[0][1] != "2018-1-1" {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("#apple #banana before:2018-1-1")); len(words) != 2 || words[0] != "#apple" || words[1] != "#banana" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 1 || flags[0][0] != "before" || flags[0][1] != "2018-1-1" {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("#apple #banana after:2018-1-1 before:2018-1-10")); len(words) != 2 || words[0] != "#apple" || words[1] != "#banana" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 2 || flags[0][0] != "after" || flags[0][1] != "2018-1-1" || flags[1][0] != "before" || flags[1][1] != "2018-1-10" {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("apple banana after: 2018-1-1")); len(words) != 2 || words[0] != "apple" || words[1] != "banana" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 1 || flags[0][0] != "after" || flags[0][1] != "2018-1-1" {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("apple banana before: 2018-1-1")); len(words) != 2 || words[0] != "apple" || words[1] != "banana" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 1 || flags[0][0] != "before" || flags[0][1] != "2018-1-1" {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("apple banana after: 2018-1-1 before: 2018-1-10")); len(words) != 2 || words[0] != "apple" || words[1] != "banana" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 2 || flags[0][0] != "after" || flags[0][1] != "2018-1-1" || flags[1][0] != "before" || flags[1][1] != "2018-1-10" {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("apple banana after: 2018-1-1 before: 2018-1-10 #fruit")); len(words) != 3 || words[0] != "apple" || words[1] != "banana" || words[2] != "#fruit" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 2 || flags[0][0] != "after" || flags[0][1] != "2018-1-1" || flags[1][0] != "before" || flags[1][1] != "2018-1-10" {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
|
|
if words, flags := parseSearchFlags(splitWords("test after:2018-7-1")); len(words) != 1 || words[0] != "test" {
|
|
t.Fatalf("got incorrect words %v", words)
|
|
} else if len(flags) != 1 || flags[0][0] != "after" || flags[0][1] != "2018-7-1" {
|
|
t.Fatalf("got incorrect flags %v", flags)
|
|
}
|
|
}
|
|
|
|
func TestParseSearchParams(t *testing.T) {
|
|
if sp := ParseSearchParams("", 0); len(sp) != 0 {
|
|
t.Fatalf("Incorrect output from parse search params: %v", sp)
|
|
}
|
|
|
|
if sp := ParseSearchParams(" ", 0); len(sp) != 0 {
|
|
t.Fatalf("Incorrect output from parse search params: %v", sp)
|
|
}
|
|
|
|
if sp := ParseSearchParams("words words", 0); len(sp) != 1 || sp[0].Terms != "words words" || sp[0].IsHashtag || len(sp[0].InChannels) != 0 || len(sp[0].FromUsers) != 0 {
|
|
t.Fatalf("Incorrect output from parse search params: %v", sp)
|
|
}
|
|
|
|
if sp := ParseSearchParams("\"my stuff\"", 0); len(sp) != 1 || sp[0].Terms != "\"my stuff\"" || sp[0].IsHashtag || len(sp[0].InChannels) != 0 || len(sp[0].FromUsers) != 0 {
|
|
t.Fatalf("Incorrect output from parse search params: %v", sp)
|
|
}
|
|
|
|
if sp := ParseSearchParams("#words #words", 0); len(sp) != 1 || sp[0].Terms != "#words #words" || !sp[0].IsHashtag || len(sp[0].InChannels) != 0 || len(sp[0].FromUsers) != 0 {
|
|
t.Fatalf("Incorrect output from parse search params: %v", sp)
|
|
}
|
|
|
|
if sp := ParseSearchParams("#words words", 0); len(sp) != 2 || sp[1].Terms != "#words" || !sp[1].IsHashtag || len(sp[1].InChannels) != 0 || len(sp[1].FromUsers) != 0 || sp[0].Terms != "words" || sp[0].IsHashtag || len(sp[0].InChannels) != 0 {
|
|
t.Fatalf("Incorrect output from parse search params: %v", sp)
|
|
}
|
|
|
|
if sp := ParseSearchParams("in:channel", 0); len(sp) != 1 || sp[0].Terms != "" || len(sp[0].InChannels) != 1 || sp[0].InChannels[0] != "channel" || len(sp[0].FromUsers) != 0 {
|
|
t.Fatalf("Incorrect output from parse search params: %v", sp)
|
|
}
|
|
|
|
if sp := ParseSearchParams("testing in:channel", 0); len(sp) != 1 || sp[0].Terms != "testing" || len(sp[0].InChannels) != 1 || sp[0].InChannels[0] != "channel" || len(sp[0].FromUsers) != 0 {
|
|
t.Fatalf("Incorrect output from parse search params: %v", sp)
|
|
}
|
|
|
|
if sp := ParseSearchParams("in:channel testing", 0); len(sp) != 1 || sp[0].Terms != "testing" || len(sp[0].InChannels) != 1 || sp[0].InChannels[0] != "channel" || len(sp[0].FromUsers) != 0 {
|
|
t.Fatalf("Incorrect output from parse search params: %v", sp)
|
|
}
|
|
|
|
if sp := ParseSearchParams("in:channel in:otherchannel", 0); len(sp) != 1 || sp[0].Terms != "" || len(sp[0].InChannels) != 2 || sp[0].InChannels[0] != "channel" || sp[0].InChannels[1] != "otherchannel" || len(sp[0].FromUsers) != 0 {
|
|
t.Fatalf("Incorrect output from parse search params: %v", sp)
|
|
}
|
|
|
|
if sp := ParseSearchParams("testing in:channel from:someone", 0); len(sp) != 1 || sp[0].Terms != "testing" || len(sp[0].InChannels) != 1 || sp[0].InChannels[0] != "channel" || len(sp[0].FromUsers) != 1 || sp[0].FromUsers[0] != "someone" {
|
|
t.Fatalf("Incorrect output from parse search params: %v", sp[0])
|
|
}
|
|
|
|
if sp := ParseSearchParams("##hashtag +#plus+", 0); len(sp) != 1 || sp[0].Terms != "#hashtag #plus" || !sp[0].IsHashtag || len(sp[0].InChannels) != 0 || len(sp[0].FromUsers) != 0 {
|
|
t.Fatalf("Incorrect output from parse search params: %v", sp[0])
|
|
}
|
|
|
|
if sp := ParseSearchParams("wildcar*", 0); len(sp) != 1 || sp[0].Terms != "wildcar*" || sp[0].IsHashtag || len(sp[0].InChannels) != 0 || len(sp[0].FromUsers) != 0 {
|
|
t.Fatalf("Incorrect output from parse search params: %v", sp[0])
|
|
}
|
|
|
|
if sp := ParseSearchParams("after:2018-8-1 testing", 0); len(sp) != 1 || sp[0].Terms != "testing" || len(sp[0].AfterDate) == 0 || sp[0].AfterDate != "2018-8-1" {
|
|
t.Fatalf("Incorrect output from parse search params: %v", sp)
|
|
}
|
|
|
|
if sp := ParseSearchParams("after:2018-8-1", 0); len(sp) != 1 || sp[0].Terms != "" || len(sp[0].AfterDate) == 0 || sp[0].AfterDate != "2018-8-1" {
|
|
t.Fatalf("Incorrect output from parse search params: %v", sp)
|
|
}
|
|
}
|