diff options
author | Arthur <arthur@hoa.ro> | 2016-02-15 21:43:07 +0100 |
---|---|---|
committer | Arthur <arthur@hoa.ro> | 2016-02-15 21:43:07 +0100 |
commit | bfec695df1205864b46ca7175e1598b184602687 (patch) | |
tree | 9d64988c49fd53978c58c64bbd013a363c5b2d78 /tests | |
parent | 07c2f73543b358d39b3751c8542966794f28db03 (diff) | |
parent | 522b278b03280ed809025ebbeb3eac284b68bf81 (diff) | |
download | Shaarli-bfec695df1205864b46ca7175e1598b184602687.tar.gz Shaarli-bfec695df1205864b46ca7175e1598b184602687.tar.zst Shaarli-bfec695df1205864b46ca7175e1598b184602687.zip |
Merge pull request #455 from ArthurHoaro/improved-search-454
Improved search: combine AND, exact terms and exclude search.
Diffstat (limited to 'tests')
-rw-r--r-- | tests/LinkDBTest.php | 2 | ||||
-rw-r--r-- | tests/LinkFilterTest.php | 79 | ||||
-rw-r--r-- | tests/utils/ReferenceLinkDB.php | 15 |
3 files changed, 89 insertions, 7 deletions
diff --git a/tests/LinkDBTest.php b/tests/LinkDBTest.php index 765f771e..b6a273b3 100644 --- a/tests/LinkDBTest.php +++ b/tests/LinkDBTest.php | |||
@@ -278,6 +278,7 @@ class LinkDBTest extends PHPUnit_Framework_TestCase | |||
278 | 'stallman' => 1, | 278 | 'stallman' => 1, |
279 | 'free' => 1, | 279 | 'free' => 1, |
280 | '-exclude' => 1, | 280 | '-exclude' => 1, |
281 | 'stuff' => 2, | ||
281 | ), | 282 | ), |
282 | self::$publicLinkDB->allTags() | 283 | self::$publicLinkDB->allTags() |
283 | ); | 284 | ); |
@@ -297,6 +298,7 @@ class LinkDBTest extends PHPUnit_Framework_TestCase | |||
297 | 'w3c' => 1, | 298 | 'w3c' => 1, |
298 | 'css' => 1, | 299 | 'css' => 1, |
299 | 'Mercurial' => 1, | 300 | 'Mercurial' => 1, |
301 | 'stuff' => 2, | ||
300 | '-exclude' => 1, | 302 | '-exclude' => 1, |
301 | '.hidden' => 1, | 303 | '.hidden' => 1, |
302 | ), | 304 | ), |
diff --git a/tests/LinkFilterTest.php b/tests/LinkFilterTest.php index 164af0d4..31fd4cf4 100644 --- a/tests/LinkFilterTest.php +++ b/tests/LinkFilterTest.php | |||
@@ -27,7 +27,7 @@ class LinkFilterTest extends PHPUnit_Framework_TestCase | |||
27 | public function testFilter() | 27 | public function testFilter() |
28 | { | 28 | { |
29 | $this->assertEquals( | 29 | $this->assertEquals( |
30 | 6, | 30 | 7, |
31 | count(self::$linkFilter->filter('', '')) | 31 | count(self::$linkFilter->filter('', '')) |
32 | ); | 32 | ); |
33 | 33 | ||
@@ -165,6 +165,17 @@ class LinkFilterTest extends PHPUnit_Framework_TestCase | |||
165 | } | 165 | } |
166 | 166 | ||
167 | /** | 167 | /** |
168 | * Full-text search - no result found. | ||
169 | */ | ||
170 | public function testFilterFullTextNoResult() | ||
171 | { | ||
172 | $this->assertEquals( | ||
173 | 0, | ||
174 | count(self::$linkFilter->filter(LinkFilter::$FILTER_TEXT, 'azertyuiop')) | ||
175 | ); | ||
176 | } | ||
177 | |||
178 | /** | ||
168 | * Full-text search - result from a link's URL | 179 | * Full-text search - result from a link's URL |
169 | */ | 180 | */ |
170 | public function testFilterFullTextURL() | 181 | public function testFilterFullTextURL() |
@@ -222,7 +233,7 @@ class LinkFilterTest extends PHPUnit_Framework_TestCase | |||
222 | ); | 233 | ); |
223 | 234 | ||
224 | $this->assertEquals( | 235 | $this->assertEquals( |
225 | 2, | 236 | 3, |
226 | count(self::$linkFilter->filter(LinkFilter::$FILTER_TEXT, '"free software"')) | 237 | count(self::$linkFilter->filter(LinkFilter::$FILTER_TEXT, '"free software"')) |
227 | ); | 238 | ); |
228 | } | 239 | } |
@@ -250,12 +261,72 @@ class LinkFilterTest extends PHPUnit_Framework_TestCase | |||
250 | public function testFilterFullTextMixed() | 261 | public function testFilterFullTextMixed() |
251 | { | 262 | { |
252 | $this->assertEquals( | 263 | $this->assertEquals( |
253 | 2, | 264 | 3, |
254 | count(self::$linkFilter->filter(LinkFilter::$FILTER_TEXT, 'free software')) | 265 | count(self::$linkFilter->filter(LinkFilter::$FILTER_TEXT, 'free software')) |
255 | ); | 266 | ); |
256 | } | 267 | } |
257 | 268 | ||
258 | /** | 269 | /** |
270 | * Full-text search - test exclusion with '-'. | ||
271 | */ | ||
272 | public function testExcludeSearch() | ||
273 | { | ||
274 | $this->assertEquals( | ||
275 | 1, | ||
276 | count(self::$linkFilter->filter(LinkFilter::$FILTER_TEXT, 'free -gnu')) | ||
277 | ); | ||
278 | |||
279 | $this->assertEquals( | ||
280 | 6, | ||
281 | count(self::$linkFilter->filter(LinkFilter::$FILTER_TEXT, '-revolution')) | ||
282 | ); | ||
283 | } | ||
284 | |||
285 | /** | ||
286 | * Full-text search - test AND, exact terms and exclusion combined, across fields. | ||
287 | */ | ||
288 | public function testMultiSearch() | ||
289 | { | ||
290 | $this->assertEquals( | ||
291 | 2, | ||
292 | count(self::$linkFilter->filter( | ||
293 | LinkFilter::$FILTER_TEXT, | ||
294 | '"Free Software " stallman "read this" @website stuff' | ||
295 | )) | ||
296 | ); | ||
297 | |||
298 | $this->assertEquals( | ||
299 | 1, | ||
300 | count(self::$linkFilter->filter( | ||
301 | LinkFilter::$FILTER_TEXT, | ||
302 | '"free software " stallman "read this" -beard @website stuff' | ||
303 | )) | ||
304 | ); | ||
305 | } | ||
306 | |||
307 | /** | ||
308 | * Full-text search - make sure that exact search won't work across fields. | ||
309 | */ | ||
310 | public function testSearchExactTermMultiFieldsKo() | ||
311 | { | ||
312 | $this->assertEquals( | ||
313 | 0, | ||
314 | count(self::$linkFilter->filter( | ||
315 | LinkFilter::$FILTER_TEXT, | ||
316 | '"designer naming"' | ||
317 | )) | ||
318 | ); | ||
319 | |||
320 | $this->assertEquals( | ||
321 | 0, | ||
322 | count(self::$linkFilter->filter( | ||
323 | LinkFilter::$FILTER_TEXT, | ||
324 | '"designernaming"' | ||
325 | )) | ||
326 | ); | ||
327 | } | ||
328 | |||
329 | /** | ||
259 | * Tag search with exclusion. | 330 | * Tag search with exclusion. |
260 | */ | 331 | */ |
261 | public function testTagFilterWithExclusion() | 332 | public function testTagFilterWithExclusion() |
@@ -266,7 +337,7 @@ class LinkFilterTest extends PHPUnit_Framework_TestCase | |||
266 | ); | 337 | ); |
267 | 338 | ||
268 | $this->assertEquals( | 339 | $this->assertEquals( |
269 | 5, | 340 | 6, |
270 | count(self::$linkFilter->filter(LinkFilter::$FILTER_TAG, '-free')) | 341 | count(self::$linkFilter->filter(LinkFilter::$FILTER_TAG, '-free')) |
271 | ); | 342 | ); |
272 | } | 343 | } |
diff --git a/tests/utils/ReferenceLinkDB.php b/tests/utils/ReferenceLinkDB.php index da3e8c65..61faef05 100644 --- a/tests/utils/ReferenceLinkDB.php +++ b/tests/utils/ReferenceLinkDB.php | |||
@@ -14,12 +14,21 @@ class ReferenceLinkDB | |||
14 | function __construct() | 14 | function __construct() |
15 | { | 15 | { |
16 | $this->addLink( | 16 | $this->addLink( |
17 | 'Free as in Freedom 2.0', | 17 | 'Free as in Freedom 2.0 @website', |
18 | 'https://static.fsf.org/nosvn/faif-2.0.pdf', | 18 | 'https://static.fsf.org/nosvn/faif-2.0.pdf', |
19 | 'Richard Stallman and the Free Software Revolution', | 19 | 'Richard Stallman and the Free Software Revolution. Read this.', |
20 | 0, | 20 | 0, |
21 | '20150310_114633', | 21 | '20150310_114633', |
22 | 'free gnu software stallman -exclude' | 22 | 'free gnu software stallman -exclude stuff' |
23 | ); | ||
24 | |||
25 | $this->addLink( | ||
26 | 'Link title: @website', | ||
27 | 'local', | ||
28 | 'Stallman has a beard and is part of the Free Software Foundation (or not). Seriously, read this.', | ||
29 | 0, | ||
30 | '20150310_114651', | ||
31 | 'stuff' | ||
23 | ); | 32 | ); |
24 | 33 | ||
25 | $this->addLink( | 34 | $this->addLink( |