aboutsummaryrefslogtreecommitdiffhomepage
path: root/tests
diff options
context:
space:
mode:
authorArthur <arthur@hoa.ro>2016-02-15 21:43:07 +0100
committerArthur <arthur@hoa.ro>2016-02-15 21:43:07 +0100
commitbfec695df1205864b46ca7175e1598b184602687 (patch)
tree9d64988c49fd53978c58c64bbd013a363c5b2d78 /tests
parent07c2f73543b358d39b3751c8542966794f28db03 (diff)
parent522b278b03280ed809025ebbeb3eac284b68bf81 (diff)
downloadShaarli-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.php2
-rw-r--r--tests/LinkFilterTest.php79
-rw-r--r--tests/utils/ReferenceLinkDB.php15
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(