-
-
Notifications
You must be signed in to change notification settings - Fork 505
/
Copy pathReadPreferenceTest.php
117 lines (94 loc) · 3.84 KB
/
ReadPreferenceTest.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
<?php
declare(strict_types=1);
namespace Doctrine\ODM\MongoDB\Tests\Functional;
use Doctrine\ODM\MongoDB\Mapping\Annotations as ODM;
use Doctrine\ODM\MongoDB\PersistentCollection\PersistentCollectionInterface;
use Doctrine\ODM\MongoDB\Query\Query;
use Doctrine\ODM\MongoDB\Tests\BaseTest;
use Documents\Group;
use Documents\User;
use MongoDB\Driver\ReadPreference;
use MongoDB\Driver\WriteConcern;
class ReadPreferenceTest extends BaseTest
{
public function setUp(): void
{
parent::setUp();
$user = new User();
$user->addGroup(new Group('Test'));
$this->dm->persist($user);
$this->dm->flush(['writeConcern' => new WriteConcern('majority')]);
$this->dm->clear();
}
public function testHintIsNotSetByDefault()
{
$query = $this->dm->getRepository(User::class)
->createQueryBuilder()
->getQuery();
$this->assertArrayNotHasKey('readPreference', $query->getQuery());
$user = $query->getSingleResult();
$this->assertInstanceOf(User::class, $user);
$this->assertInstanceOf(PersistentCollectionInterface::class, $user->getGroups());
$this->assertArrayNotHasKey(Query::HINT_READ_PREFERENCE, $user->getGroups()->getHints());
}
/**
* @dataProvider provideReadPreferenceHints
*/
public function testHintIsSetOnQuery($readPreference, array $tags = [])
{
$this->skipTestIfSharded(User::class);
$query = $this->dm->getRepository(User::class)
->createQueryBuilder()
->setReadPreference(new ReadPreference($readPreference, $tags))
->getQuery();
$this->assertReadPreferenceHint($readPreference, $query->getQuery()['readPreference'], $tags);
$user = $query->getSingleResult();
$this->assertInstanceOf(User::class, $user);
$this->assertInstanceOf(PersistentCollectionInterface::class, $user->getGroups());
$this->assertReadPreferenceHint($readPreference, $user->getGroups()->getHints()[Query::HINT_READ_PREFERENCE], $tags);
}
public function provideReadPreferenceHints()
{
return [
[ReadPreference::RP_PRIMARY, []],
[ReadPreference::RP_SECONDARY_PREFERRED, []],
[ReadPreference::RP_SECONDARY, [['dc' => 'east'], []]],
];
}
public function testDocumentLevelReadPreferenceIsSetInCollection()
{
$coll = $this->dm->getDocumentCollection(DocumentWithReadPreference::class);
$this->assertSame(ReadPreference::RP_NEAREST, $coll->getReadPreference()->getMode());
$this->assertSame([['dc' => 'east']], $coll->getReadPreference()->getTagSets());
}
public function testDocumentLevelReadPreferenceIsAppliedInQueryBuilder()
{
$query = $this->dm->getRepository(DocumentWithReadPreference::class)
->createQueryBuilder()
->getQuery();
$this->assertReadPreferenceHint(ReadPreference::RP_NEAREST, $query->getQuery()['readPreference'], [['dc' => 'east']]);
}
public function testDocumentLevelReadPreferenceCanBeOverriddenInQueryBuilder()
{
$query = $this->dm->getRepository(DocumentWithReadPreference::class)
->createQueryBuilder()
->setReadPreference(new ReadPreference('secondary', []))
->getQuery();
$this->assertReadPreferenceHint(ReadPreference::RP_SECONDARY, $query->getQuery()['readPreference']);
}
private function assertReadPreferenceHint($mode, $readPreference, array $tags = [])
{
$this->assertInstanceOf(ReadPreference::class, $readPreference);
$this->assertEquals($mode, $readPreference->getMode());
$this->assertEquals($tags, $readPreference->getTagSets());
}
}
/**
* @ODM\Document()
* @ODM\ReadPreference("nearest", tags={ { "dc"="east" } })
*/
class DocumentWithReadPreference
{
/** @ODM\Id() */
public $id;
}