From: Marc Tobias Metten Date: Thu, 19 Jul 2018 00:31:54 +0000 (+0200) Subject: tests for Nominatim::TokenList X-Git-Tag: v3.2.0~45^2 X-Git-Url: https://git.openstreetmap.org./nominatim.git/commitdiff_plain/0892eab1d36b14fea8de73590c477612b5165ce6 tests for Nominatim::TokenList --- diff --git a/lib/TokenList.php b/lib/TokenList.php index 96b756f8..a91c735e 100644 --- a/lib/TokenList.php +++ b/lib/TokenList.php @@ -32,6 +32,17 @@ class TokenList // List of list of tokens indexed by their word_token. private $aTokens = array(); + + /** + * Return total number of tokens. + * + * @return Integer + */ + public function count() + { + return count($this->aTokens); + } + /** * Check if there are tokens for the given token word. * diff --git a/test/php/Nominatim/TokenListTest.php b/test/php/Nominatim/TokenListTest.php new file mode 100644 index 00000000..38f13e18 --- /dev/null +++ b/test/php/Nominatim/TokenListTest.php @@ -0,0 +1,116 @@ +oNormalizer = $this->getMock(\MockNormalizer::class, array('transliterate')); + $this->oNormalizer->method('transliterate') + ->will($this->returnCallback(function ($text) { + return strtolower($text); + })); + } + + private function wordResult($aFields) + { + $aRow = array( + 'word_id' => null, + 'word_token' => null, + 'word' => null, + 'class' => null, + 'type' => null, + 'country_code' => null, + 'count' => 0 + ); + return array_merge($aRow, $aFields); + } + + public function testList() + { + $TL = new TokenList; + + $this->assertEquals(0, $TL->count()); + + $TL->addToken('word1', 'token1'); + $TL->addToken('word1', 'token2'); + + $this->assertEquals(1, $TL->count()); + + $this->assertTrue($TL->contains('word1')); + $this->assertEquals(array('token1', 'token2'), $TL->get('word1')); + + $this->assertFalse($TL->contains('unknownword')); + $this->assertEquals(array(), $TL->get('unknownword')); + } + + public function testAddress() + { + $this->expectOutputRegex('/

/'); + + $oDbStub = $this->getMock(\DB::class, array('getAll')); + $oDbStub->method('getAll') + ->will($this->returnCallback(function ($sql) { + $aResults = array(); + if (preg_match('/1051/', $sql)) { + $aResults[] = $this->wordResult(array( + 'word_id' => 999, + 'word_token' => '1051', + 'class' => 'place', + 'type' => 'house' + )); + } + if (preg_match('/64286/', $sql)) { + $aResults[] = $this->wordResult(array( + 'word_id' => 999, + 'word_token' => '64286', + 'word' => '64286', + 'class' => 'place', + 'type' => 'postcode' + )); + } + if (preg_match('/darmstadt/', $sql)) { + $aResults[] = $this->wordResult(array( + 'word_id' => 999, + 'word_token' => 'darmstadt', + 'count' => 533 + )); + } + if (preg_match('/alemagne/', $sql)) { + $aResults[] = $this->wordResult(array( + 'word_id' => 999, + 'word_token' => 'alemagne', + 'country_code' => 'de', + )); + } + if (preg_match('/mexico/', $sql)) { + $aResults[] = $this->wordResult(array( + 'word_id' => 999, + 'word_token' => 'mexico', + 'country_code' => 'mx', + )); + } + return $aResults; + })); + + $aCountryCodes = array('de', 'fr'); + $sNormQuery = '1051 hauptstr 64286 darmstadt alemagne mexico'; + $aTokens = explode(' ', $sNormQuery); + + $TL = new TokenList; + $TL->addTokensFromDB($oDbStub, $aTokens, $aCountryCodes, $sNormQuery, $this->oNormalizer); + $this->assertEquals(4, $TL->count()); + + $this->assertEquals(array(new Token\HouseNumber(999, '1051')), $TL->get('1051')); + $this->assertEquals(array(new Token\Country(999, 'de')), $TL->get('alemagne')); + $this->assertEquals(array(new Token\Postcode(999, '64286')), $TL->get('64286')); + $this->assertEquals(array(new Token\Word(999, true, 533)), $TL->get('darmstadt')); + } +}