Refactor member tests to use dataproviders
This commit is contained in:
parent
46c3ce7a15
commit
d3745c0b40
|
@ -13,66 +13,63 @@ class DatabasePermissionsMemberTest extends Scope
|
||||||
use SideClient;
|
use SideClient;
|
||||||
use DatabasePermissionsScope;
|
use DatabasePermissionsScope;
|
||||||
|
|
||||||
public array $mockPermissions = [
|
public array $collections = [];
|
||||||
[
|
|
||||||
'read' => ['role:all'],
|
|
||||||
'write' => []
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'read' => ['role:member'],
|
|
||||||
'write' => []
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'read' => ['user:random'],
|
|
||||||
'write' => []
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'read' => ['user:lorem'],
|
|
||||||
'write' => ['user:lorem']
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'read' => ['user:dolor'],
|
|
||||||
'write' => ['user:dolor']
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'read' => ['user:dolor', 'user:lorem'],
|
|
||||||
'write' => ['user:dolor']
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'read' => [],
|
|
||||||
'write' => ['role:all']
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'read' => ['role:all'],
|
|
||||||
'write' => ['role:all']
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'read' => ['role:member'],
|
|
||||||
'write' => ['role:member']
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'read' => ['role:all'],
|
|
||||||
'write' => ['role:member']
|
|
||||||
]
|
|
||||||
];
|
|
||||||
|
|
||||||
public function createCollections(): array
|
public function createUsers(): array
|
||||||
{
|
{
|
||||||
$movies = $this->client->call(Client::METHOD_POST, '/database/collections', $this->getServerHeader(), [
|
return [
|
||||||
|
'user1' => $this->createUser('user1', 'lorem@ipsum.com'),
|
||||||
|
'user2' => $this->createUser('user2', 'dolor@ipsum.com'),
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* [string[] $read, string[] $write]
|
||||||
|
*/
|
||||||
|
public function readDocumentsProvider()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
[['role:all'], []],
|
||||||
|
[['role:member'], []],
|
||||||
|
[['user:random'], []],
|
||||||
|
[['user:lorem'] ,['user:lorem']],
|
||||||
|
[['user:dolor'] ,['user:dolor']],
|
||||||
|
[['user:dolor', 'user:lorem'] ,['user:dolor']],
|
||||||
|
[[], ['role:all']],
|
||||||
|
[['role:all'], ['role:all']],
|
||||||
|
[['role:member'], ['role:member']],
|
||||||
|
[['role:all'], ['role:member']],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Setup database
|
||||||
|
*
|
||||||
|
* Data providers lose object state
|
||||||
|
* so explicitly pass [$users, $collections] to each iteration
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function testSetupDatabase(): array
|
||||||
|
{
|
||||||
|
$this->createUsers();
|
||||||
|
|
||||||
|
$public = $this->client->call(Client::METHOD_POST, '/database/collections', $this->getServerHeader(), [
|
||||||
'collectionId' => 'unique()',
|
'collectionId' => 'unique()',
|
||||||
'name' => 'Movies',
|
'name' => 'Movies',
|
||||||
'read' => ['role:all'],
|
'read' => ['role:all'],
|
||||||
'write' => ['role:all'],
|
'write' => ['role:all'],
|
||||||
'permission' => 'document',
|
'permission' => 'document',
|
||||||
]);
|
]);
|
||||||
|
$this->assertEquals(201, $public['headers']['status-code']);
|
||||||
|
|
||||||
$collections = ['public' => $movies['body']['$id']];
|
$this->collections = ['public' => $public['body']['$id']];
|
||||||
|
|
||||||
$this->client->call(Client::METHOD_POST, '/database/collections/' . $collections['public'] . '/attributes/string', $this->getServerHeader(), [
|
$response = $this->client->call(Client::METHOD_POST, '/database/collections/' . $this->collections['public'] . '/attributes/string', $this->getServerHeader(), [
|
||||||
'attributeId' => 'title',
|
'attributeId' => 'title',
|
||||||
'size' => 256,
|
'size' => 256,
|
||||||
'required' => true,
|
'required' => true,
|
||||||
]);
|
]);
|
||||||
|
$this->assertEquals(201, $response['headers']['status-code']);
|
||||||
|
|
||||||
$private = $this->client->call(Client::METHOD_POST, '/database/collections', $this->getServerHeader(), [
|
$private = $this->client->call(Client::METHOD_POST, '/database/collections', $this->getServerHeader(), [
|
||||||
'collectionId' => 'unique()',
|
'collectionId' => 'unique()',
|
||||||
|
@ -81,50 +78,54 @@ class DatabasePermissionsMemberTest extends Scope
|
||||||
'write' => ['role:member'],
|
'write' => ['role:member'],
|
||||||
'permission' => 'document',
|
'permission' => 'document',
|
||||||
]);
|
]);
|
||||||
|
$this->assertEquals(201, $private['headers']['status-code']);
|
||||||
|
|
||||||
$collections['private'] = $private['body']['$id'];
|
$this->collections['private'] = $private['body']['$id'];
|
||||||
|
|
||||||
$this->client->call(Client::METHOD_POST, '/database/collections/' . $collections['private'] . '/attributes/string', $this->getServerHeader(), [
|
$this->client->call(Client::METHOD_POST, '/database/collections/' . $this->collections['private'] . '/attributes/string', $this->getServerHeader(), [
|
||||||
'attributeId' => 'title',
|
'attributeId' => 'title',
|
||||||
'size' => 256,
|
'size' => 256,
|
||||||
'required' => true,
|
'required' => true,
|
||||||
]);
|
]);
|
||||||
|
$this->assertEquals(201, $response['headers']['status-code']);
|
||||||
|
|
||||||
sleep(2);
|
sleep(2);
|
||||||
|
|
||||||
return $collections;
|
return [
|
||||||
|
'users' => $this->users,
|
||||||
|
'collections' => $this->collections
|
||||||
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testReadDocuments()
|
/**
|
||||||
|
* Data provider params are passed before test dependencies
|
||||||
|
* @dataProvider readDocumentsProvider
|
||||||
|
* @depends testSetupDatabase
|
||||||
|
*/
|
||||||
|
public function testReadDocuments($read, $write, $data)
|
||||||
{
|
{
|
||||||
$user1 = $this->createUser('lorem', 'lorem@ipsum.com');
|
$users = $data['users'];
|
||||||
$user2 = $this->createUser('dolor', 'dolor@ipsum.com');
|
$collections = $data['collections'];
|
||||||
|
|
||||||
$collections = $this->createCollections();
|
$response = $this->client->call(Client::METHOD_POST, '/database/collections/' . $collections['public'] . '/documents', $this->getServerHeader(), [
|
||||||
|
'documentId' => 'unique()',
|
||||||
|
'data' => [
|
||||||
|
'title' => 'Lorem',
|
||||||
|
],
|
||||||
|
'read' => $read,
|
||||||
|
'write' => $write,
|
||||||
|
]);
|
||||||
|
$this->assertEquals(201, $response['headers']['status-code']);
|
||||||
|
|
||||||
foreach ($this->mockPermissions as $permissions) {
|
$response = $this->client->call(Client::METHOD_POST, '/database/collections/' . $collections['private'] . '/documents', $this->getServerHeader(), [
|
||||||
$response = $this->client->call(Client::METHOD_POST, '/database/collections/' . $collections['public'] . '/documents', $this->getServerHeader(), [
|
'documentId' => 'unique()',
|
||||||
'documentId' => 'unique()',
|
'data' => [
|
||||||
'data' => [
|
'title' => 'Lorem',
|
||||||
'title' => 'Lorem',
|
],
|
||||||
],
|
'read' => $read,
|
||||||
'read' => $permissions['read'],
|
'write' => $write,
|
||||||
'write' => $permissions['write'],
|
]);
|
||||||
]);
|
$this->assertEquals(201, $response['headers']['status-code']);
|
||||||
$this->assertEquals(201, $response['headers']['status-code']);
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach ($this->mockPermissions as $permissions) {
|
|
||||||
$response = $this->client->call(Client::METHOD_POST, '/database/collections/' . $collections['private'] . '/documents', $this->getServerHeader(), [
|
|
||||||
'documentId' => 'unique()',
|
|
||||||
'data' => [
|
|
||||||
'title' => 'Lorem',
|
|
||||||
],
|
|
||||||
'read' => $permissions['read'],
|
|
||||||
'write' => $permissions['write'],
|
|
||||||
]);
|
|
||||||
$this->assertEquals(201, $response['headers']['status-code']);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Check role:all collection
|
* Check role:all collection
|
||||||
|
@ -133,11 +134,11 @@ class DatabasePermissionsMemberTest extends Scope
|
||||||
'origin' => 'http://localhost',
|
'origin' => 'http://localhost',
|
||||||
'content-type' => 'application/json',
|
'content-type' => 'application/json',
|
||||||
'x-appwrite-project' => $this->getProject()['$id'],
|
'x-appwrite-project' => $this->getProject()['$id'],
|
||||||
'cookie' => 'a_session_' . $this->getProject()['$id'] . '=' . $user1['session'],
|
'cookie' => 'a_session_' . $this->getProject()['$id'] . '=' . $users['user1']['session'],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
foreach ($documents['body']['documents'] as $document) {
|
foreach ($documents['body']['documents'] as $document) {
|
||||||
$hasPermissions = \array_reduce(['role:all', 'role:member', 'user:' . $user1['$id']], function ($carry, $item) use ($document) {
|
$hasPermissions = \array_reduce(['role:all', 'role:member', 'user:' . $users['user1']['$id']], function ($carry, $item) use ($document) {
|
||||||
return $carry ? true : \in_array($item, $document['$read']);
|
return $carry ? true : \in_array($item, $document['$read']);
|
||||||
}, false);
|
}, false);
|
||||||
$this->assertTrue($hasPermissions);
|
$this->assertTrue($hasPermissions);
|
||||||
|
@ -150,16 +151,15 @@ class DatabasePermissionsMemberTest extends Scope
|
||||||
'origin' => 'http://localhost',
|
'origin' => 'http://localhost',
|
||||||
'content-type' => 'application/json',
|
'content-type' => 'application/json',
|
||||||
'x-appwrite-project' => $this->getProject()['$id'],
|
'x-appwrite-project' => $this->getProject()['$id'],
|
||||||
'cookie' => 'a_session_' . $this->getProject()['$id'] . '=' . $user1['session'],
|
'cookie' => 'a_session_' . $this->getProject()['$id'] . '=' . $users['user1']['session'],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
foreach ($documents['body']['documents'] as $document) {
|
foreach ($documents['body']['documents'] as $document) {
|
||||||
$hasPermissions = \array_reduce(['role:all', 'role:member', 'user:' . $user1['$id']], function ($carry, $item) use ($document) {
|
$hasPermissions = \array_reduce(['role:all', 'role:member', 'user:' . $users['user1']['$id']], function ($carry, $item) use ($document) {
|
||||||
return $carry ? true : \in_array($item, $document['$read']);
|
return $carry ? true : \in_array($item, $document['$read']);
|
||||||
}, false);
|
}, false);
|
||||||
$this->assertTrue($hasPermissions);
|
$this->assertTrue($hasPermissions);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue