mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-24 02:13:15 +00:00

Search with non numeric content will not hit number field (it breaks elasticsearch and is useless anyway) - Rename QueryHelper::buildPrivateFieldQueries() to wrapPrivateFieldQuery(). - Signature changed too, the third parameter is dropped an QueryContext is replaced by an array of Field. - Query builder closure is now passed an array of Field, not of index field names. - Remove Field::toConceptPathIndexFieldArray() because method name was beyond understanding (and also because it wasn't needed anymore) - Various AST node types have changed due to previous API changes
149 lines
4.6 KiB
PHP
149 lines
4.6 KiB
PHP
<?php
|
|
|
|
namespace Alchemy\Tests\Phrasea\SearchEngine\AST;
|
|
|
|
use Alchemy\Phrasea\SearchEngine\Elastic\AST\Context;
|
|
use Alchemy\Phrasea\SearchEngine\Elastic\AST\TermNode;
|
|
use Alchemy\Phrasea\SearchEngine\Elastic\Mapping;
|
|
use Alchemy\Phrasea\SearchEngine\Elastic\Search\QueryContext;
|
|
use Alchemy\Phrasea\SearchEngine\Elastic\Structure\Field;
|
|
use Alchemy\Phrasea\SearchEngine\Elastic\Thesaurus\Concept;
|
|
|
|
/**
|
|
* @group unit
|
|
* @group searchengine
|
|
* @group ast
|
|
*/
|
|
class TermNodeTest extends \PHPUnit_Framework_TestCase
|
|
{
|
|
public function testSerialization()
|
|
{
|
|
$this->assertTrue(method_exists(TermNode::class, '__toString'), 'Class does not have method __toString');
|
|
$node = new TermNode('foo');
|
|
$this->assertEquals('<term:"foo">', (string) $node);
|
|
$node_with_context = new TermNode('foo', new Context('bar'));
|
|
$this->assertEquals('<term:"foo" context:"bar">', (string) $node_with_context);
|
|
}
|
|
|
|
public function testQueryBuild()
|
|
{
|
|
$field = new Field('foo', Mapping::TYPE_STRING, ['private' => false]);
|
|
$query_context = $this->prophesize(QueryContext::class);
|
|
$query_context
|
|
->getUnrestrictedFields()
|
|
->willReturn([$field]);
|
|
$query_context
|
|
->getPrivateFields()
|
|
->willReturn([]);
|
|
|
|
$node = new TermNode('bar');
|
|
$node->setConcepts([
|
|
new Concept('/baz'),
|
|
new Concept('/qux'),
|
|
]);
|
|
$query = $node->buildQuery($query_context->reveal());
|
|
|
|
$expected = '{
|
|
"bool": {
|
|
"should": [{
|
|
"multi_match": {
|
|
"fields": ["concept_path.foo"],
|
|
"query": "/baz"
|
|
}
|
|
}, {
|
|
"multi_match": {
|
|
"fields": ["concept_path.foo"],
|
|
"query": "/qux"
|
|
}
|
|
}]
|
|
}
|
|
}';
|
|
|
|
$this->assertEquals(json_decode($expected, true), $query);
|
|
}
|
|
|
|
public function testQueryBuildWithZeroConcept()
|
|
{
|
|
$field = new Field('foo', Mapping::TYPE_STRING, ['private' => false]);
|
|
$query_context = $this->prophesize(QueryContext::class);
|
|
$query_context
|
|
->getUnrestrictedFields()
|
|
->willReturn([$field]);
|
|
$query_context
|
|
->getPrivateFields()
|
|
->willReturn([]);
|
|
|
|
$node = new TermNode('bar');
|
|
$query = $node->buildQuery($query_context->reveal());
|
|
|
|
$expected = '{
|
|
"bool": {
|
|
"should": []
|
|
}
|
|
}';
|
|
|
|
$this->assertEquals(json_decode($expected, true), $query);
|
|
}
|
|
|
|
public function testQueryBuildWithPrivateFields()
|
|
{
|
|
$public_field = new Field('foo', Mapping::TYPE_STRING, ['private' => false]);
|
|
$private_field = new Field('bar', Mapping::TYPE_STRING, [
|
|
'private' => true,
|
|
'used_by_collections' => [1, 2, 3]
|
|
]);
|
|
|
|
$query_context = $this->prophesize(QueryContext::class);
|
|
$query_context
|
|
->getUnrestrictedFields()
|
|
->willReturn([$public_field]);
|
|
$query_context
|
|
->getPrivateFields()
|
|
->willReturn([$private_field]);
|
|
|
|
$node = new TermNode('baz');
|
|
$node->setConcepts([
|
|
new Concept('/baz'),
|
|
new Concept('/qux'),
|
|
]);
|
|
$query = $node->buildQuery($query_context->reveal());
|
|
|
|
$expected = '{
|
|
"bool": {
|
|
"should": [{
|
|
"multi_match": {
|
|
"fields": ["concept_path.foo"],
|
|
"query": "/baz"
|
|
}
|
|
}, {
|
|
"multi_match": {
|
|
"fields": ["concept_path.foo"],
|
|
"query": "/qux"
|
|
}
|
|
}, {
|
|
"bool": {
|
|
"must": [{
|
|
"terms": {
|
|
"base_id": [1, 2, 3]
|
|
}
|
|
}],
|
|
"should": [{
|
|
"multi_match": {
|
|
"fields": ["concept_path.bar"],
|
|
"query": "/baz"
|
|
}
|
|
}, {
|
|
"multi_match": {
|
|
"fields": ["concept_path.bar"],
|
|
"query": "/qux"
|
|
}
|
|
}]
|
|
}
|
|
}]
|
|
}
|
|
}';
|
|
|
|
$this->assertEquals(json_decode($expected, true), $query);
|
|
}
|
|
}
|