efd25d6a70
# Conflicts: # app/controllers/api/users.php # composer.json # composer.lock # tests/e2e/Services/Storage/StorageBase.php
4219 lines
206 KiB
PHP
4219 lines
206 KiB
PHP
<?php
|
|
|
|
namespace Tests\E2E\Services\Databases;
|
|
|
|
use Appwrite\Extend\Exception;
|
|
use Tests\E2E\Client;
|
|
use Utopia\Database\Database;
|
|
use Utopia\Database\Document;
|
|
use Utopia\Database\DateTime;
|
|
use Utopia\Database\Helpers\ID;
|
|
use Utopia\Database\Helpers\Permission;
|
|
use Utopia\Database\Helpers\Role;
|
|
use Utopia\Database\Query;
|
|
use Utopia\Database\Validator\Datetime as DatetimeValidator;
|
|
|
|
trait DatabasesBase
|
|
{
|
|
public function testCreateDatabase(): array
|
|
{
|
|
/**
|
|
* Test for SUCCESS
|
|
*/
|
|
$database = $this->client->call(Client::METHOD_POST, '/databases', [
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
], [
|
|
'databaseId' => ID::unique(),
|
|
'name' => 'Test Database'
|
|
]);
|
|
|
|
$this->assertNotEmpty($database['body']['$id']);
|
|
$this->assertEquals(201, $database['headers']['status-code']);
|
|
$this->assertEquals('Test Database', $database['body']['name']);
|
|
|
|
return ['databaseId' => $database['body']['$id']];
|
|
}
|
|
|
|
/**
|
|
* @depends testCreateDatabase
|
|
*/
|
|
public function testCreateCollection(array $data): array
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
/**
|
|
* Test for SUCCESS
|
|
*/
|
|
$movies = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'collectionId' => ID::unique(),
|
|
'name' => 'Movies',
|
|
'documentSecurity' => true,
|
|
'permissions' => [
|
|
Permission::create(Role::user($this->getUser()['$id'])),
|
|
],
|
|
]);
|
|
|
|
$this->assertEquals(201, $movies['headers']['status-code']);
|
|
$this->assertEquals($movies['body']['name'], 'Movies');
|
|
|
|
$actors = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'collectionId' => ID::unique(),
|
|
'name' => 'Actors',
|
|
'documentSecurity' => true,
|
|
'permissions' => [
|
|
Permission::create(Role::user($this->getUser()['$id'])),
|
|
],
|
|
]);
|
|
|
|
$this->assertEquals(201, $actors['headers']['status-code']);
|
|
$this->assertEquals($actors['body']['name'], 'Actors');
|
|
|
|
return [
|
|
'databaseId' => $databaseId,
|
|
'moviesId' => $movies['body']['$id'],
|
|
'actorsId' => $actors['body']['$id'],
|
|
];
|
|
}
|
|
|
|
/**
|
|
* @depends testCreateCollection
|
|
*/
|
|
public function testDisableCollection(array $data): void
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
/**
|
|
* Test for SUCCESS
|
|
*/
|
|
$response = $this->client->call(Client::METHOD_PUT, '/databases/' . $databaseId . '/collections/' . $data['moviesId'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'name' => 'Movies',
|
|
'enabled' => false,
|
|
'documentSecurity' => true,
|
|
]);
|
|
|
|
$this->assertEquals(200, $response['headers']['status-code']);
|
|
$this->assertFalse($response['body']['enabled']);
|
|
|
|
if ($this->getSide() === 'client') {
|
|
$responseCreateDocument = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'title' => 'Captain America',
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
Permission::update(Role::user($this->getUser()['$id'])),
|
|
Permission::delete(Role::user($this->getUser()['$id'])),
|
|
],
|
|
]);
|
|
|
|
$this->assertEquals(404, $responseCreateDocument['headers']['status-code']);
|
|
|
|
$responseListDocument = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
$this->assertEquals(404, $responseListDocument['headers']['status-code']);
|
|
|
|
$responseGetDocument = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents/someID', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
$this->assertEquals(404, $responseGetDocument['headers']['status-code']);
|
|
}
|
|
|
|
$response = $this->client->call(Client::METHOD_PUT, '/databases/' . $databaseId . '/collections/' . $data['moviesId'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'name' => 'Movies',
|
|
'enabled' => true,
|
|
'documentSecurity' => true,
|
|
]);
|
|
|
|
$this->assertEquals(200, $response['headers']['status-code']);
|
|
$this->assertTrue($response['body']['enabled']);
|
|
}
|
|
|
|
/**
|
|
* @depends testCreateCollection
|
|
*/
|
|
public function testCreateAttributes(array $data): array
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
|
|
$title = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/attributes/string', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'title',
|
|
'size' => 256,
|
|
'required' => true,
|
|
]);
|
|
|
|
$description = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/attributes/string', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'description',
|
|
'size' => 512,
|
|
'required' => false,
|
|
'default' => '',
|
|
]);
|
|
|
|
$tagline = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/attributes/string', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'tagline',
|
|
'size' => 512,
|
|
'required' => false,
|
|
'default' => '',
|
|
]);
|
|
|
|
$releaseYear = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/attributes/integer', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'releaseYear',
|
|
'required' => true,
|
|
'min' => 1900,
|
|
'max' => 2200,
|
|
]);
|
|
|
|
$duration = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/attributes/integer', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'duration',
|
|
'required' => false,
|
|
'min' => 60,
|
|
]);
|
|
|
|
$actors = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/attributes/string', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'actors',
|
|
'size' => 256,
|
|
'required' => false,
|
|
'array' => true,
|
|
]);
|
|
|
|
$datetime = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/attributes/datetime', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'birthDay',
|
|
'required' => false,
|
|
]);
|
|
|
|
$relationship = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/attributes/relationship', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'relatedCollectionId' => $data['actorsId'],
|
|
'type' => 'oneToMany',
|
|
'twoWay' => true,
|
|
'key' => 'starringActors',
|
|
'twoWayKey' => 'movie'
|
|
]);
|
|
|
|
$this->assertEquals(202, $title['headers']['status-code']);
|
|
$this->assertEquals($title['body']['key'], 'title');
|
|
$this->assertEquals($title['body']['type'], 'string');
|
|
$this->assertEquals($title['body']['size'], 256);
|
|
$this->assertEquals($title['body']['required'], true);
|
|
|
|
$this->assertEquals(202, $description['headers']['status-code']);
|
|
$this->assertEquals($description['body']['key'], 'description');
|
|
$this->assertEquals($description['body']['type'], 'string');
|
|
$this->assertEquals($description['body']['size'], 512);
|
|
$this->assertEquals($description['body']['required'], false);
|
|
$this->assertEquals($description['body']['default'], '');
|
|
|
|
$this->assertEquals(202, $tagline['headers']['status-code']);
|
|
$this->assertEquals($tagline['body']['key'], 'tagline');
|
|
$this->assertEquals($tagline['body']['type'], 'string');
|
|
$this->assertEquals($tagline['body']['size'], 512);
|
|
$this->assertEquals($tagline['body']['required'], false);
|
|
$this->assertEquals($tagline['body']['default'], '');
|
|
|
|
$this->assertEquals(202, $releaseYear['headers']['status-code']);
|
|
$this->assertEquals($releaseYear['body']['key'], 'releaseYear');
|
|
$this->assertEquals($releaseYear['body']['type'], 'integer');
|
|
$this->assertEquals($releaseYear['body']['required'], true);
|
|
|
|
$this->assertEquals(202, $duration['headers']['status-code']);
|
|
$this->assertEquals($duration['body']['key'], 'duration');
|
|
$this->assertEquals($duration['body']['type'], 'integer');
|
|
$this->assertEquals($duration['body']['required'], false);
|
|
|
|
$this->assertEquals(202, $actors['headers']['status-code']);
|
|
$this->assertEquals($actors['body']['key'], 'actors');
|
|
$this->assertEquals($actors['body']['type'], 'string');
|
|
$this->assertEquals($actors['body']['size'], 256);
|
|
$this->assertEquals($actors['body']['required'], false);
|
|
$this->assertEquals($actors['body']['array'], true);
|
|
|
|
$this->assertEquals($datetime['headers']['status-code'], 202);
|
|
$this->assertEquals($datetime['body']['key'], 'birthDay');
|
|
$this->assertEquals($datetime['body']['type'], 'datetime');
|
|
$this->assertEquals($datetime['body']['required'], false);
|
|
|
|
$this->assertEquals($relationship['headers']['status-code'], 202);
|
|
$this->assertEquals($relationship['body']['key'], 'starringActors');
|
|
$this->assertEquals($relationship['body']['type'], 'relationship');
|
|
$this->assertEquals($relationship['body']['relatedCollection'], $data['actorsId']);
|
|
$this->assertEquals($relationship['body']['relationType'], 'oneToMany');
|
|
$this->assertEquals($relationship['body']['twoWay'], true);
|
|
$this->assertEquals($relationship['body']['twoWayKey'], 'movie');
|
|
|
|
// wait for database worker to create attributes
|
|
sleep(2);
|
|
|
|
$movies = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
$this->assertIsArray($movies['body']['attributes']);
|
|
$this->assertCount(8, $movies['body']['attributes']);
|
|
$this->assertEquals($movies['body']['attributes'][0]['key'], $title['body']['key']);
|
|
$this->assertEquals($movies['body']['attributes'][1]['key'], $description['body']['key']);
|
|
$this->assertEquals($movies['body']['attributes'][2]['key'], $tagline['body']['key']);
|
|
$this->assertEquals($movies['body']['attributes'][3]['key'], $releaseYear['body']['key']);
|
|
$this->assertEquals($movies['body']['attributes'][4]['key'], $duration['body']['key']);
|
|
$this->assertEquals($movies['body']['attributes'][5]['key'], $actors['body']['key']);
|
|
$this->assertEquals($movies['body']['attributes'][6]['key'], $datetime['body']['key']);
|
|
$this->assertEquals($movies['body']['attributes'][7]['key'], $relationship['body']['key']);
|
|
|
|
return $data;
|
|
}
|
|
|
|
/**
|
|
* @depends testCreateAttributes
|
|
*/
|
|
public function testListAttributes(array $data): void
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
$response = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/attributes', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey'],
|
|
]), [
|
|
'queries' => ['equal("type", "string")', 'limit(2)', 'cursorAfter(title)'],
|
|
]);
|
|
$this->assertEquals(200, $response['headers']['status-code']);
|
|
$this->assertEquals(2, \count($response['body']['attributes']));
|
|
$response = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/attributes', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey'],
|
|
]), [
|
|
'queries' => ['select(["key"])'],
|
|
]);
|
|
$this->assertEquals(Exception::GENERAL_ARGUMENT_INVALID, $response['body']['type']);
|
|
$this->assertEquals(400, $response['headers']['status-code']);
|
|
}
|
|
|
|
public function testUpdateAttributeEnum(): void
|
|
{
|
|
$database = $this->client->call(Client::METHOD_POST, '/databases', [
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
], [
|
|
'databaseId' => ID::unique(),
|
|
'name' => 'Test Database 2'
|
|
]);
|
|
|
|
$players = $this->client->call(Client::METHOD_POST, '/databases/' . $database['body']['$id'] . '/collections', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'collectionId' => ID::unique(),
|
|
'name' => 'Players',
|
|
'documentSecurity' => true,
|
|
'permissions' => [
|
|
Permission::create(Role::user($this->getUser()['$id'])),
|
|
],
|
|
]);
|
|
|
|
// Create enum attribute
|
|
$attribute = $this->client->call(Client::METHOD_POST, '/databases/' . $database['body']['$id'] . '/collections/' . $players['body']['$id'] . '/attributes/enum', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey'],
|
|
]), [
|
|
'key' => 'position',
|
|
'elements' => ['goalkeeper', 'defender', 'midfielder', 'forward'],
|
|
'required' => true,
|
|
'array' => false,
|
|
]);
|
|
|
|
$this->assertEquals(202, $attribute['headers']['status-code']);
|
|
$this->assertEquals($attribute['body']['key'], 'position');
|
|
$this->assertEquals($attribute['body']['elements'], ['goalkeeper', 'defender', 'midfielder', 'forward']);
|
|
|
|
\sleep(2);
|
|
|
|
// Update enum attribute
|
|
$attribute = $this->client->call(Client::METHOD_PATCH, '/databases/' . $database['body']['$id'] . '/collections/' . $players['body']['$id'] . '/attributes/enum/' . $attribute['body']['key'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey'],
|
|
]), [
|
|
'elements' => ['goalkeeper', 'defender', 'midfielder', 'forward', 'coach'],
|
|
'required' => true,
|
|
'default' => null
|
|
]);
|
|
|
|
$this->assertEquals(200, $attribute['headers']['status-code']);
|
|
$this->assertEquals($attribute['body']['elements'], ['goalkeeper', 'defender', 'midfielder', 'forward', 'coach']);
|
|
}
|
|
|
|
/**
|
|
* @depends testCreateAttributes
|
|
*/
|
|
public function testAttributeResponseModels(array $data): array
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
$collection = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'collectionId' => ID::unique(),
|
|
'name' => 'Response Models',
|
|
// 'permissions' missing on purpose to make sure it's optional
|
|
'documentSecurity' => true,
|
|
]);
|
|
|
|
$this->assertEquals(201, $collection['headers']['status-code']);
|
|
$this->assertEquals($collection['body']['name'], 'Response Models');
|
|
|
|
$collectionId = $collection['body']['$id'];
|
|
|
|
$attributesPath = "/databases/" . $databaseId . "/collections/{$collectionId}/attributes";
|
|
|
|
$string = $this->client->call(Client::METHOD_POST, $attributesPath . '/string', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'string',
|
|
'size' => 16,
|
|
'required' => false,
|
|
'default' => 'default',
|
|
]);
|
|
|
|
$email = $this->client->call(Client::METHOD_POST, $attributesPath . '/email', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'email',
|
|
'required' => false,
|
|
'default' => 'default@example.com',
|
|
]);
|
|
|
|
$enum = $this->client->call(Client::METHOD_POST, $attributesPath . '/enum', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'enum',
|
|
'elements' => ['yes', 'no', 'maybe'],
|
|
'required' => false,
|
|
'default' => 'maybe',
|
|
]);
|
|
|
|
$ip = $this->client->call(Client::METHOD_POST, $attributesPath . '/ip', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'ip',
|
|
'required' => false,
|
|
'default' => '192.0.2.0',
|
|
]);
|
|
|
|
$url = $this->client->call(Client::METHOD_POST, $attributesPath . '/url', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'url',
|
|
'required' => false,
|
|
'default' => 'http://example.com',
|
|
]);
|
|
|
|
$integer = $this->client->call(Client::METHOD_POST, $attributesPath . '/integer', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'integer',
|
|
'required' => false,
|
|
'min' => 1,
|
|
'max' => 5,
|
|
'default' => 3
|
|
]);
|
|
|
|
$float = $this->client->call(Client::METHOD_POST, $attributesPath . '/float', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'float',
|
|
'required' => false,
|
|
'min' => 1.5,
|
|
'max' => 5.5,
|
|
'default' => 3.5
|
|
]);
|
|
|
|
$boolean = $this->client->call(Client::METHOD_POST, $attributesPath . '/boolean', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'boolean',
|
|
'required' => false,
|
|
'default' => true,
|
|
]);
|
|
|
|
$datetime = $this->client->call(Client::METHOD_POST, $attributesPath . '/datetime', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'datetime',
|
|
'required' => false,
|
|
'default' => null,
|
|
]);
|
|
|
|
$relationship = $this->client->call(Client::METHOD_POST, $attributesPath . '/relationship', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'relatedCollectionId' => $data['actorsId'],
|
|
'type' => 'oneToMany',
|
|
'twoWay' => true,
|
|
'key' => 'relationship',
|
|
'twoWayKey' => 'twoWayKey'
|
|
]);
|
|
|
|
$this->assertEquals(202, $string['headers']['status-code']);
|
|
$this->assertEquals('string', $string['body']['key']);
|
|
$this->assertEquals('string', $string['body']['type']);
|
|
$this->assertEquals(false, $string['body']['required']);
|
|
$this->assertEquals(false, $string['body']['array']);
|
|
$this->assertEquals(16, $string['body']['size']);
|
|
$this->assertEquals('default', $string['body']['default']);
|
|
|
|
$this->assertEquals(202, $email['headers']['status-code']);
|
|
$this->assertEquals('email', $email['body']['key']);
|
|
$this->assertEquals('string', $email['body']['type']);
|
|
$this->assertEquals(false, $email['body']['required']);
|
|
$this->assertEquals(false, $email['body']['array']);
|
|
$this->assertEquals('email', $email['body']['format']);
|
|
$this->assertEquals('default@example.com', $email['body']['default']);
|
|
|
|
$this->assertEquals(202, $enum['headers']['status-code']);
|
|
$this->assertEquals('enum', $enum['body']['key']);
|
|
$this->assertEquals('string', $enum['body']['type']);
|
|
$this->assertEquals(false, $enum['body']['required']);
|
|
$this->assertEquals(false, $enum['body']['array']);
|
|
$this->assertEquals('enum', $enum['body']['format']);
|
|
$this->assertEquals('maybe', $enum['body']['default']);
|
|
$this->assertIsArray($enum['body']['elements']);
|
|
$this->assertEquals(['yes', 'no', 'maybe'], $enum['body']['elements']);
|
|
|
|
$this->assertEquals(202, $ip['headers']['status-code']);
|
|
$this->assertEquals('ip', $ip['body']['key']);
|
|
$this->assertEquals('string', $ip['body']['type']);
|
|
$this->assertEquals(false, $ip['body']['required']);
|
|
$this->assertEquals(false, $ip['body']['array']);
|
|
$this->assertEquals('ip', $ip['body']['format']);
|
|
$this->assertEquals('192.0.2.0', $ip['body']['default']);
|
|
|
|
$this->assertEquals(202, $url['headers']['status-code']);
|
|
$this->assertEquals('url', $url['body']['key']);
|
|
$this->assertEquals('string', $url['body']['type']);
|
|
$this->assertEquals(false, $url['body']['required']);
|
|
$this->assertEquals(false, $url['body']['array']);
|
|
$this->assertEquals('url', $url['body']['format']);
|
|
$this->assertEquals('http://example.com', $url['body']['default']);
|
|
|
|
$this->assertEquals(202, $integer['headers']['status-code']);
|
|
$this->assertEquals('integer', $integer['body']['key']);
|
|
$this->assertEquals('integer', $integer['body']['type']);
|
|
$this->assertEquals(false, $integer['body']['required']);
|
|
$this->assertEquals(false, $integer['body']['array']);
|
|
$this->assertEquals(1, $integer['body']['min']);
|
|
$this->assertEquals(5, $integer['body']['max']);
|
|
$this->assertEquals(3, $integer['body']['default']);
|
|
|
|
$this->assertEquals(202, $float['headers']['status-code']);
|
|
$this->assertEquals('float', $float['body']['key']);
|
|
$this->assertEquals('double', $float['body']['type']);
|
|
$this->assertEquals(false, $float['body']['required']);
|
|
$this->assertEquals(false, $float['body']['array']);
|
|
$this->assertEquals(1.5, $float['body']['min']);
|
|
$this->assertEquals(5.5, $float['body']['max']);
|
|
$this->assertEquals(3.5, $float['body']['default']);
|
|
|
|
$this->assertEquals(202, $boolean['headers']['status-code']);
|
|
$this->assertEquals('boolean', $boolean['body']['key']);
|
|
$this->assertEquals('boolean', $boolean['body']['type']);
|
|
$this->assertEquals(false, $boolean['body']['required']);
|
|
$this->assertEquals(false, $boolean['body']['array']);
|
|
$this->assertEquals(true, $boolean['body']['default']);
|
|
|
|
$this->assertEquals(202, $datetime['headers']['status-code']);
|
|
$this->assertEquals('datetime', $datetime['body']['key']);
|
|
$this->assertEquals('datetime', $datetime['body']['type']);
|
|
$this->assertEquals(false, $datetime['body']['required']);
|
|
$this->assertEquals(false, $datetime['body']['array']);
|
|
$this->assertEquals(null, $datetime['body']['default']);
|
|
|
|
$this->assertEquals(202, $relationship['headers']['status-code']);
|
|
$this->assertEquals('relationship', $relationship['body']['key']);
|
|
$this->assertEquals('relationship', $relationship['body']['type']);
|
|
$this->assertEquals(false, $relationship['body']['required']);
|
|
$this->assertEquals(false, $relationship['body']['array']);
|
|
$this->assertEquals($data['actorsId'], $relationship['body']['relatedCollection']);
|
|
$this->assertEquals('oneToMany', $relationship['body']['relationType']);
|
|
$this->assertEquals(true, $relationship['body']['twoWay']);
|
|
$this->assertEquals('twoWayKey', $relationship['body']['twoWayKey']);
|
|
|
|
// Wait for database worker to create attributes
|
|
sleep(5);
|
|
|
|
$stringResponse = $this->client->call(Client::METHOD_GET, $attributesPath . '/' . $string['body']['key'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
$emailResponse = $this->client->call(Client::METHOD_GET, $attributesPath . '/' . $email['body']['key'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
$enumResponse = $this->client->call(Client::METHOD_GET, $attributesPath . '/' . $enum['body']['key'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
$ipResponse = $this->client->call(Client::METHOD_GET, $attributesPath . '/' . $ip['body']['key'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
$urlResponse = $this->client->call(Client::METHOD_GET, $attributesPath . '/' . $url['body']['key'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
$integerResponse = $this->client->call(Client::METHOD_GET, $attributesPath . '/' . $integer['body']['key'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
$floatResponse = $this->client->call(Client::METHOD_GET, $attributesPath . '/' . $float['body']['key'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
$booleanResponse = $this->client->call(Client::METHOD_GET, $attributesPath . '/' . $boolean['body']['key'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
$datetimeResponse = $this->client->call(Client::METHOD_GET, $attributesPath . '/' . $datetime['body']['key'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
$relationshipResponse = $this->client->call(Client::METHOD_GET, $attributesPath . '/' . $relationship['body']['key'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
$this->assertEquals(200, $stringResponse['headers']['status-code']);
|
|
$this->assertEquals($string['body']['key'], $stringResponse['body']['key']);
|
|
$this->assertEquals($string['body']['type'], $stringResponse['body']['type']);
|
|
$this->assertEquals('available', $stringResponse['body']['status']);
|
|
$this->assertEquals($string['body']['required'], $stringResponse['body']['required']);
|
|
$this->assertEquals($string['body']['array'], $stringResponse['body']['array']);
|
|
$this->assertEquals(16, $stringResponse['body']['size']);
|
|
$this->assertEquals($string['body']['default'], $stringResponse['body']['default']);
|
|
|
|
$this->assertEquals(200, $emailResponse['headers']['status-code']);
|
|
$this->assertEquals($email['body']['key'], $emailResponse['body']['key']);
|
|
$this->assertEquals($email['body']['type'], $emailResponse['body']['type']);
|
|
$this->assertEquals('available', $emailResponse['body']['status']);
|
|
$this->assertEquals($email['body']['required'], $emailResponse['body']['required']);
|
|
$this->assertEquals($email['body']['array'], $emailResponse['body']['array']);
|
|
$this->assertEquals($email['body']['format'], $emailResponse['body']['format']);
|
|
$this->assertEquals($email['body']['default'], $emailResponse['body']['default']);
|
|
|
|
$this->assertEquals(200, $enumResponse['headers']['status-code']);
|
|
$this->assertEquals($enum['body']['key'], $enumResponse['body']['key']);
|
|
$this->assertEquals($enum['body']['type'], $enumResponse['body']['type']);
|
|
$this->assertEquals('available', $enumResponse['body']['status']);
|
|
$this->assertEquals($enum['body']['required'], $enumResponse['body']['required']);
|
|
$this->assertEquals($enum['body']['array'], $enumResponse['body']['array']);
|
|
$this->assertEquals($enum['body']['format'], $enumResponse['body']['format']);
|
|
$this->assertEquals($enum['body']['default'], $enumResponse['body']['default']);
|
|
$this->assertEquals($enum['body']['elements'], $enumResponse['body']['elements']);
|
|
|
|
$this->assertEquals(200, $ipResponse['headers']['status-code']);
|
|
$this->assertEquals($ip['body']['key'], $ipResponse['body']['key']);
|
|
$this->assertEquals($ip['body']['type'], $ipResponse['body']['type']);
|
|
$this->assertEquals('available', $ipResponse['body']['status']);
|
|
$this->assertEquals($ip['body']['required'], $ipResponse['body']['required']);
|
|
$this->assertEquals($ip['body']['array'], $ipResponse['body']['array']);
|
|
$this->assertEquals($ip['body']['format'], $ipResponse['body']['format']);
|
|
$this->assertEquals($ip['body']['default'], $ipResponse['body']['default']);
|
|
|
|
$this->assertEquals(200, $urlResponse['headers']['status-code']);
|
|
$this->assertEquals($url['body']['key'], $urlResponse['body']['key']);
|
|
$this->assertEquals($url['body']['type'], $urlResponse['body']['type']);
|
|
$this->assertEquals('available', $urlResponse['body']['status']);
|
|
$this->assertEquals($url['body']['required'], $urlResponse['body']['required']);
|
|
$this->assertEquals($url['body']['array'], $urlResponse['body']['array']);
|
|
$this->assertEquals($url['body']['format'], $urlResponse['body']['format']);
|
|
$this->assertEquals($url['body']['default'], $urlResponse['body']['default']);
|
|
|
|
$this->assertEquals(200, $integerResponse['headers']['status-code']);
|
|
$this->assertEquals($integer['body']['key'], $integerResponse['body']['key']);
|
|
$this->assertEquals($integer['body']['type'], $integerResponse['body']['type']);
|
|
$this->assertEquals('available', $integerResponse['body']['status']);
|
|
$this->assertEquals($integer['body']['required'], $integerResponse['body']['required']);
|
|
$this->assertEquals($integer['body']['array'], $integerResponse['body']['array']);
|
|
$this->assertEquals($integer['body']['min'], $integerResponse['body']['min']);
|
|
$this->assertEquals($integer['body']['max'], $integerResponse['body']['max']);
|
|
$this->assertEquals($integer['body']['default'], $integerResponse['body']['default']);
|
|
|
|
$this->assertEquals(200, $floatResponse['headers']['status-code']);
|
|
$this->assertEquals($float['body']['key'], $floatResponse['body']['key']);
|
|
$this->assertEquals($float['body']['type'], $floatResponse['body']['type']);
|
|
$this->assertEquals('available', $floatResponse['body']['status']);
|
|
$this->assertEquals($float['body']['required'], $floatResponse['body']['required']);
|
|
$this->assertEquals($float['body']['array'], $floatResponse['body']['array']);
|
|
$this->assertEquals($float['body']['min'], $floatResponse['body']['min']);
|
|
$this->assertEquals($float['body']['max'], $floatResponse['body']['max']);
|
|
$this->assertEquals($float['body']['default'], $floatResponse['body']['default']);
|
|
|
|
$this->assertEquals(200, $booleanResponse['headers']['status-code']);
|
|
$this->assertEquals($boolean['body']['key'], $booleanResponse['body']['key']);
|
|
$this->assertEquals($boolean['body']['type'], $booleanResponse['body']['type']);
|
|
$this->assertEquals('available', $booleanResponse['body']['status']);
|
|
$this->assertEquals($boolean['body']['required'], $booleanResponse['body']['required']);
|
|
$this->assertEquals($boolean['body']['array'], $booleanResponse['body']['array']);
|
|
$this->assertEquals($boolean['body']['default'], $booleanResponse['body']['default']);
|
|
|
|
$this->assertEquals(200, $datetimeResponse['headers']['status-code']);
|
|
$this->assertEquals($datetime['body']['key'], $datetimeResponse['body']['key']);
|
|
$this->assertEquals($datetime['body']['type'], $datetimeResponse['body']['type']);
|
|
$this->assertEquals('available', $datetimeResponse['body']['status']);
|
|
$this->assertEquals($datetime['body']['required'], $datetimeResponse['body']['required']);
|
|
$this->assertEquals($datetime['body']['array'], $datetimeResponse['body']['array']);
|
|
$this->assertEquals($datetime['body']['default'], $datetimeResponse['body']['default']);
|
|
|
|
$this->assertEquals(200, $relationshipResponse['headers']['status-code']);
|
|
$this->assertEquals($relationship['body']['key'], $relationshipResponse['body']['key']);
|
|
$this->assertEquals($relationship['body']['type'], $relationshipResponse['body']['type']);
|
|
$this->assertEquals('available', $relationshipResponse['body']['status']);
|
|
$this->assertEquals($relationship['body']['required'], $relationshipResponse['body']['required']);
|
|
$this->assertEquals($relationship['body']['array'], $relationshipResponse['body']['array']);
|
|
$this->assertEquals($relationship['body']['relatedCollection'], $relationshipResponse['body']['relatedCollection']);
|
|
$this->assertEquals($relationship['body']['relationType'], $relationshipResponse['body']['relationType']);
|
|
$this->assertEquals($relationship['body']['twoWay'], $relationshipResponse['body']['twoWay']);
|
|
$this->assertEquals($relationship['body']['twoWayKey'], $relationshipResponse['body']['twoWayKey']);
|
|
|
|
$attributes = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
$this->assertEquals(200, $attributes['headers']['status-code']);
|
|
$this->assertEquals(10, $attributes['body']['total']);
|
|
|
|
$attributes = $attributes['body']['attributes'];
|
|
$this->assertIsArray($attributes);
|
|
$this->assertCount(10, $attributes);
|
|
|
|
$this->assertEquals($stringResponse['body']['key'], $attributes[0]['key']);
|
|
$this->assertEquals($stringResponse['body']['type'], $attributes[0]['type']);
|
|
$this->assertEquals($stringResponse['body']['status'], $attributes[0]['status']);
|
|
$this->assertEquals($stringResponse['body']['required'], $attributes[0]['required']);
|
|
$this->assertEquals($stringResponse['body']['array'], $attributes[0]['array']);
|
|
$this->assertEquals($stringResponse['body']['size'], $attributes[0]['size']);
|
|
$this->assertEquals($stringResponse['body']['default'], $attributes[0]['default']);
|
|
|
|
$this->assertEquals($emailResponse['body']['key'], $attributes[1]['key']);
|
|
$this->assertEquals($emailResponse['body']['type'], $attributes[1]['type']);
|
|
$this->assertEquals($emailResponse['body']['status'], $attributes[1]['status']);
|
|
$this->assertEquals($emailResponse['body']['required'], $attributes[1]['required']);
|
|
$this->assertEquals($emailResponse['body']['array'], $attributes[1]['array']);
|
|
$this->assertEquals($emailResponse['body']['default'], $attributes[1]['default']);
|
|
$this->assertEquals($emailResponse['body']['format'], $attributes[1]['format']);
|
|
|
|
$this->assertEquals($enumResponse['body']['key'], $attributes[2]['key']);
|
|
$this->assertEquals($enumResponse['body']['type'], $attributes[2]['type']);
|
|
$this->assertEquals($enumResponse['body']['status'], $attributes[2]['status']);
|
|
$this->assertEquals($enumResponse['body']['required'], $attributes[2]['required']);
|
|
$this->assertEquals($enumResponse['body']['array'], $attributes[2]['array']);
|
|
$this->assertEquals($enumResponse['body']['default'], $attributes[2]['default']);
|
|
$this->assertEquals($enumResponse['body']['format'], $attributes[2]['format']);
|
|
$this->assertEquals($enumResponse['body']['elements'], $attributes[2]['elements']);
|
|
|
|
$this->assertEquals($ipResponse['body']['key'], $attributes[3]['key']);
|
|
$this->assertEquals($ipResponse['body']['type'], $attributes[3]['type']);
|
|
$this->assertEquals($ipResponse['body']['status'], $attributes[3]['status']);
|
|
$this->assertEquals($ipResponse['body']['required'], $attributes[3]['required']);
|
|
$this->assertEquals($ipResponse['body']['array'], $attributes[3]['array']);
|
|
$this->assertEquals($ipResponse['body']['default'], $attributes[3]['default']);
|
|
$this->assertEquals($ipResponse['body']['format'], $attributes[3]['format']);
|
|
|
|
$this->assertEquals($urlResponse['body']['key'], $attributes[4]['key']);
|
|
$this->assertEquals($urlResponse['body']['type'], $attributes[4]['type']);
|
|
$this->assertEquals($urlResponse['body']['status'], $attributes[4]['status']);
|
|
$this->assertEquals($urlResponse['body']['required'], $attributes[4]['required']);
|
|
$this->assertEquals($urlResponse['body']['array'], $attributes[4]['array']);
|
|
$this->assertEquals($urlResponse['body']['default'], $attributes[4]['default']);
|
|
$this->assertEquals($urlResponse['body']['format'], $attributes[4]['format']);
|
|
|
|
$this->assertEquals($integerResponse['body']['key'], $attributes[5]['key']);
|
|
$this->assertEquals($integerResponse['body']['type'], $attributes[5]['type']);
|
|
$this->assertEquals($integerResponse['body']['status'], $attributes[5]['status']);
|
|
$this->assertEquals($integerResponse['body']['required'], $attributes[5]['required']);
|
|
$this->assertEquals($integerResponse['body']['array'], $attributes[5]['array']);
|
|
$this->assertEquals($integerResponse['body']['default'], $attributes[5]['default']);
|
|
$this->assertEquals($integerResponse['body']['min'], $attributes[5]['min']);
|
|
$this->assertEquals($integerResponse['body']['max'], $attributes[5]['max']);
|
|
|
|
$this->assertEquals($floatResponse['body']['key'], $attributes[6]['key']);
|
|
$this->assertEquals($floatResponse['body']['type'], $attributes[6]['type']);
|
|
$this->assertEquals($floatResponse['body']['status'], $attributes[6]['status']);
|
|
$this->assertEquals($floatResponse['body']['required'], $attributes[6]['required']);
|
|
$this->assertEquals($floatResponse['body']['array'], $attributes[6]['array']);
|
|
$this->assertEquals($floatResponse['body']['default'], $attributes[6]['default']);
|
|
$this->assertEquals($floatResponse['body']['min'], $attributes[6]['min']);
|
|
$this->assertEquals($floatResponse['body']['max'], $attributes[6]['max']);
|
|
|
|
$this->assertEquals($booleanResponse['body']['key'], $attributes[7]['key']);
|
|
$this->assertEquals($booleanResponse['body']['type'], $attributes[7]['type']);
|
|
$this->assertEquals($booleanResponse['body']['status'], $attributes[7]['status']);
|
|
$this->assertEquals($booleanResponse['body']['required'], $attributes[7]['required']);
|
|
$this->assertEquals($booleanResponse['body']['array'], $attributes[7]['array']);
|
|
$this->assertEquals($booleanResponse['body']['default'], $attributes[7]['default']);
|
|
|
|
$this->assertEquals($datetimeResponse['body']['key'], $attributes[8]['key']);
|
|
$this->assertEquals($datetimeResponse['body']['type'], $attributes[8]['type']);
|
|
$this->assertEquals($datetimeResponse['body']['status'], $attributes[8]['status']);
|
|
$this->assertEquals($datetimeResponse['body']['required'], $attributes[8]['required']);
|
|
$this->assertEquals($datetimeResponse['body']['array'], $attributes[8]['array']);
|
|
$this->assertEquals($datetimeResponse['body']['default'], $attributes[8]['default']);
|
|
|
|
$this->assertEquals($relationshipResponse['body']['key'], $attributes[9]['key']);
|
|
$this->assertEquals($relationshipResponse['body']['type'], $attributes[9]['type']);
|
|
$this->assertEquals($relationshipResponse['body']['status'], $attributes[9]['status']);
|
|
$this->assertEquals($relationshipResponse['body']['required'], $attributes[9]['required']);
|
|
$this->assertEquals($relationshipResponse['body']['array'], $attributes[9]['array']);
|
|
$this->assertEquals($relationshipResponse['body']['relatedCollection'], $attributes[9]['relatedCollection']);
|
|
$this->assertEquals($relationshipResponse['body']['relationType'], $attributes[9]['relationType']);
|
|
$this->assertEquals($relationshipResponse['body']['twoWay'], $attributes[9]['twoWay']);
|
|
$this->assertEquals($relationshipResponse['body']['twoWayKey'], $attributes[9]['twoWayKey']);
|
|
|
|
$collection = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $collectionId, array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
$this->assertEquals(200, $collection['headers']['status-code']);
|
|
|
|
$attributes = $collection['body']['attributes'];
|
|
|
|
$this->assertIsArray($attributes);
|
|
$this->assertCount(10, $attributes);
|
|
|
|
$this->assertEquals($stringResponse['body']['key'], $attributes[0]['key']);
|
|
$this->assertEquals($stringResponse['body']['type'], $attributes[0]['type']);
|
|
$this->assertEquals($stringResponse['body']['status'], $attributes[0]['status']);
|
|
$this->assertEquals($stringResponse['body']['required'], $attributes[0]['required']);
|
|
$this->assertEquals($stringResponse['body']['array'], $attributes[0]['array']);
|
|
$this->assertEquals($stringResponse['body']['size'], $attributes[0]['size']);
|
|
$this->assertEquals($stringResponse['body']['default'], $attributes[0]['default']);
|
|
|
|
$this->assertEquals($emailResponse['body']['key'], $attributes[1]['key']);
|
|
$this->assertEquals($emailResponse['body']['type'], $attributes[1]['type']);
|
|
$this->assertEquals($emailResponse['body']['status'], $attributes[1]['status']);
|
|
$this->assertEquals($emailResponse['body']['required'], $attributes[1]['required']);
|
|
$this->assertEquals($emailResponse['body']['array'], $attributes[1]['array']);
|
|
$this->assertEquals($emailResponse['body']['default'], $attributes[1]['default']);
|
|
$this->assertEquals($emailResponse['body']['format'], $attributes[1]['format']);
|
|
|
|
$this->assertEquals($enumResponse['body']['key'], $attributes[2]['key']);
|
|
$this->assertEquals($enumResponse['body']['type'], $attributes[2]['type']);
|
|
$this->assertEquals($enumResponse['body']['status'], $attributes[2]['status']);
|
|
$this->assertEquals($enumResponse['body']['required'], $attributes[2]['required']);
|
|
$this->assertEquals($enumResponse['body']['array'], $attributes[2]['array']);
|
|
$this->assertEquals($enumResponse['body']['default'], $attributes[2]['default']);
|
|
$this->assertEquals($enumResponse['body']['format'], $attributes[2]['format']);
|
|
$this->assertEquals($enumResponse['body']['elements'], $attributes[2]['elements']);
|
|
|
|
$this->assertEquals($ipResponse['body']['key'], $attributes[3]['key']);
|
|
$this->assertEquals($ipResponse['body']['type'], $attributes[3]['type']);
|
|
$this->assertEquals($ipResponse['body']['status'], $attributes[3]['status']);
|
|
$this->assertEquals($ipResponse['body']['required'], $attributes[3]['required']);
|
|
$this->assertEquals($ipResponse['body']['array'], $attributes[3]['array']);
|
|
$this->assertEquals($ipResponse['body']['default'], $attributes[3]['default']);
|
|
$this->assertEquals($ipResponse['body']['format'], $attributes[3]['format']);
|
|
|
|
$this->assertEquals($urlResponse['body']['key'], $attributes[4]['key']);
|
|
$this->assertEquals($urlResponse['body']['type'], $attributes[4]['type']);
|
|
$this->assertEquals($urlResponse['body']['status'], $attributes[4]['status']);
|
|
$this->assertEquals($urlResponse['body']['required'], $attributes[4]['required']);
|
|
$this->assertEquals($urlResponse['body']['array'], $attributes[4]['array']);
|
|
$this->assertEquals($urlResponse['body']['default'], $attributes[4]['default']);
|
|
$this->assertEquals($urlResponse['body']['format'], $attributes[4]['format']);
|
|
|
|
$this->assertEquals($integerResponse['body']['key'], $attributes[5]['key']);
|
|
$this->assertEquals($integerResponse['body']['type'], $attributes[5]['type']);
|
|
$this->assertEquals($integerResponse['body']['status'], $attributes[5]['status']);
|
|
$this->assertEquals($integerResponse['body']['required'], $attributes[5]['required']);
|
|
$this->assertEquals($integerResponse['body']['array'], $attributes[5]['array']);
|
|
$this->assertEquals($integerResponse['body']['default'], $attributes[5]['default']);
|
|
$this->assertEquals($integerResponse['body']['min'], $attributes[5]['min']);
|
|
$this->assertEquals($integerResponse['body']['max'], $attributes[5]['max']);
|
|
|
|
$this->assertEquals($floatResponse['body']['key'], $attributes[6]['key']);
|
|
$this->assertEquals($floatResponse['body']['type'], $attributes[6]['type']);
|
|
$this->assertEquals($floatResponse['body']['status'], $attributes[6]['status']);
|
|
$this->assertEquals($floatResponse['body']['required'], $attributes[6]['required']);
|
|
$this->assertEquals($floatResponse['body']['array'], $attributes[6]['array']);
|
|
$this->assertEquals($floatResponse['body']['default'], $attributes[6]['default']);
|
|
$this->assertEquals($floatResponse['body']['min'], $attributes[6]['min']);
|
|
$this->assertEquals($floatResponse['body']['max'], $attributes[6]['max']);
|
|
|
|
$this->assertEquals($booleanResponse['body']['key'], $attributes[7]['key']);
|
|
$this->assertEquals($booleanResponse['body']['type'], $attributes[7]['type']);
|
|
$this->assertEquals($booleanResponse['body']['status'], $attributes[7]['status']);
|
|
$this->assertEquals($booleanResponse['body']['required'], $attributes[7]['required']);
|
|
$this->assertEquals($booleanResponse['body']['array'], $attributes[7]['array']);
|
|
$this->assertEquals($booleanResponse['body']['default'], $attributes[7]['default']);
|
|
|
|
$this->assertEquals($datetimeResponse['body']['key'], $attributes[8]['key']);
|
|
$this->assertEquals($datetimeResponse['body']['type'], $attributes[8]['type']);
|
|
$this->assertEquals($datetimeResponse['body']['status'], $attributes[8]['status']);
|
|
$this->assertEquals($datetimeResponse['body']['required'], $attributes[8]['required']);
|
|
$this->assertEquals($datetimeResponse['body']['array'], $attributes[8]['array']);
|
|
$this->assertEquals($datetimeResponse['body']['default'], $attributes[8]['default']);
|
|
|
|
$this->assertEquals($relationshipResponse['body']['key'], $attributes[9]['key']);
|
|
$this->assertEquals($relationshipResponse['body']['type'], $attributes[9]['type']);
|
|
$this->assertEquals($relationshipResponse['body']['status'], $attributes[9]['status']);
|
|
$this->assertEquals($relationshipResponse['body']['required'], $attributes[9]['required']);
|
|
$this->assertEquals($relationshipResponse['body']['array'], $attributes[9]['array']);
|
|
$this->assertEquals($relationshipResponse['body']['relatedCollection'], $attributes[9]['relatedCollection']);
|
|
$this->assertEquals($relationshipResponse['body']['relationType'], $attributes[9]['relationType']);
|
|
$this->assertEquals($relationshipResponse['body']['twoWay'], $attributes[9]['twoWay']);
|
|
$this->assertEquals($relationshipResponse['body']['twoWayKey'], $attributes[9]['twoWayKey']);
|
|
|
|
/**
|
|
* Test for FAILURE
|
|
*/
|
|
$badEnum = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes/enum', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'enum',
|
|
'elements' => ['yes', 'no', ''],
|
|
'required' => false,
|
|
'default' => 'maybe',
|
|
]);
|
|
|
|
$this->assertEquals(400, $badEnum['headers']['status-code']);
|
|
$this->assertEquals('Each enum element must not be empty', $badEnum['body']['message']);
|
|
|
|
return $data;
|
|
}
|
|
|
|
/**
|
|
* @depends testCreateAttributes
|
|
*/
|
|
public function testCreateIndexes(array $data): array
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
|
|
$titleIndex = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/indexes', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'titleIndex',
|
|
'type' => 'fulltext',
|
|
'attributes' => ['title'],
|
|
]);
|
|
|
|
$this->assertEquals(202, $titleIndex['headers']['status-code']);
|
|
$this->assertEquals('titleIndex', $titleIndex['body']['key']);
|
|
$this->assertEquals('fulltext', $titleIndex['body']['type']);
|
|
$this->assertCount(1, $titleIndex['body']['attributes']);
|
|
$this->assertEquals('title', $titleIndex['body']['attributes'][0]);
|
|
|
|
$releaseYearIndex = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/indexes', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'releaseYear',
|
|
'type' => 'key',
|
|
'attributes' => ['releaseYear'],
|
|
]);
|
|
|
|
$this->assertEquals(202, $releaseYearIndex['headers']['status-code']);
|
|
$this->assertEquals('releaseYear', $releaseYearIndex['body']['key']);
|
|
$this->assertEquals('key', $releaseYearIndex['body']['type']);
|
|
$this->assertCount(1, $releaseYearIndex['body']['attributes']);
|
|
$this->assertEquals('releaseYear', $releaseYearIndex['body']['attributes'][0]);
|
|
|
|
$releaseWithDate = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/indexes', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'releaseYearDated',
|
|
'type' => 'key',
|
|
'attributes' => ['releaseYear', '$createdAt', '$updatedAt'],
|
|
]);
|
|
|
|
$this->assertEquals(202, $releaseWithDate['headers']['status-code']);
|
|
$this->assertEquals('releaseYearDated', $releaseWithDate['body']['key']);
|
|
$this->assertEquals('key', $releaseWithDate['body']['type']);
|
|
$this->assertCount(3, $releaseWithDate['body']['attributes']);
|
|
$this->assertEquals('releaseYear', $releaseWithDate['body']['attributes'][0]);
|
|
$this->assertEquals('$createdAt', $releaseWithDate['body']['attributes'][1]);
|
|
$this->assertEquals('$updatedAt', $releaseWithDate['body']['attributes'][2]);
|
|
|
|
// wait for database worker to create index
|
|
sleep(2);
|
|
|
|
$movies = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), []);
|
|
|
|
$this->assertIsArray($movies['body']['indexes']);
|
|
$this->assertCount(3, $movies['body']['indexes']);
|
|
$this->assertEquals($titleIndex['body']['key'], $movies['body']['indexes'][0]['key']);
|
|
$this->assertEquals($releaseYearIndex['body']['key'], $movies['body']['indexes'][1]['key']);
|
|
$this->assertEquals($releaseWithDate['body']['key'], $movies['body']['indexes'][2]['key']);
|
|
$this->assertEquals('available', $movies['body']['indexes'][0]['status']);
|
|
$this->assertEquals('available', $movies['body']['indexes'][1]['status']);
|
|
$this->assertEquals('available', $movies['body']['indexes'][2]['status']);
|
|
|
|
$releaseWithDate = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/indexes', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'birthDay',
|
|
'type' => 'key',
|
|
'attributes' => ['birthDay'],
|
|
]);
|
|
|
|
$this->assertEquals(202, $releaseWithDate['headers']['status-code']);
|
|
$this->assertEquals('birthDay', $releaseWithDate['body']['key']);
|
|
$this->assertEquals('key', $releaseWithDate['body']['type']);
|
|
$this->assertCount(1, $releaseWithDate['body']['attributes']);
|
|
$this->assertEquals('birthDay', $releaseWithDate['body']['attributes'][0]);
|
|
|
|
// Test for failure
|
|
$fulltextReleaseYear = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/indexes', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'releaseYearDated',
|
|
'type' => 'fulltext',
|
|
'attributes' => ['releaseYear'],
|
|
]);
|
|
|
|
$this->assertEquals(400, $fulltextReleaseYear['headers']['status-code']);
|
|
$this->assertEquals($fulltextReleaseYear['body']['message'], 'Attribute "releaseYear" cannot be part of a FULLTEXT index, must be of type string');
|
|
|
|
$noAttributes = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/indexes', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'none',
|
|
'type' => 'key',
|
|
'attributes' => [],
|
|
]);
|
|
|
|
$this->assertEquals(400, $noAttributes['headers']['status-code']);
|
|
$this->assertEquals($noAttributes['body']['message'], 'No attributes provided for index');
|
|
|
|
$duplicates = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/indexes', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'duplicate',
|
|
'type' => 'fulltext',
|
|
'attributes' => ['releaseYear', 'releaseYear'],
|
|
]);
|
|
|
|
$this->assertEquals(400, $duplicates['headers']['status-code']);
|
|
$this->assertEquals($duplicates['body']['message'], 'Duplicate attributes provided');
|
|
|
|
$tooLong = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/indexes', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey'],
|
|
]), [
|
|
'key' => 'tooLong',
|
|
'type' => 'key',
|
|
'attributes' => ['description', 'tagline'],
|
|
]);
|
|
|
|
$this->assertEquals(400, $tooLong['headers']['status-code']);
|
|
$this->assertStringContainsString('Index length is longer than the maximum', $tooLong['body']['message']);
|
|
|
|
return $data;
|
|
}
|
|
|
|
/**
|
|
* @depends testCreateIndexes
|
|
*/
|
|
public function testListIndexes(array $data): void
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
$response = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/indexes', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey'],
|
|
]), [
|
|
'queries' => ['equal("type", "key")', 'limit(2)'],
|
|
]);
|
|
$this->assertEquals(200, $response['headers']['status-code']);
|
|
$this->assertEquals(2, \count($response['body']['indexes']));
|
|
$response = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/indexes', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey'],
|
|
]), [
|
|
'queries' => ['select(["key"])'],
|
|
]);
|
|
$this->assertEquals(Exception::GENERAL_ARGUMENT_INVALID, $response['body']['type']);
|
|
$this->assertEquals(400, $response['headers']['status-code']);
|
|
}
|
|
|
|
/**
|
|
* @depends testCreateIndexes
|
|
*/
|
|
public function testCreateDocument(array $data): array
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
$document1 = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'title' => 'Captain America',
|
|
'releaseYear' => 1944,
|
|
'birthDay' => '1975-06-12 14:12:55+02:00',
|
|
'actors' => [
|
|
'Chris Evans',
|
|
'Samuel Jackson',
|
|
]
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
Permission::update(Role::user($this->getUser()['$id'])),
|
|
Permission::delete(Role::user($this->getUser()['$id'])),
|
|
]
|
|
]);
|
|
|
|
$document2 = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'title' => 'Spider-Man: Far From Home',
|
|
'releaseYear' => 2019,
|
|
'birthDay' => null,
|
|
'actors' => [
|
|
'Tom Holland',
|
|
'Zendaya Maree Stoermer',
|
|
'Samuel Jackson',
|
|
]
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
Permission::update(Role::user($this->getUser()['$id'])),
|
|
Permission::delete(Role::user($this->getUser()['$id'])),
|
|
]
|
|
]);
|
|
|
|
$document3 = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'title' => 'Spider-Man: Homecoming',
|
|
'releaseYear' => 2017,
|
|
'birthDay' => '1975-06-12 14:12:55 America/New_York',
|
|
'duration' => 65,
|
|
'actors' => [
|
|
'Tom Holland',
|
|
'Zendaya Maree Stoermer',
|
|
],
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
Permission::update(Role::user($this->getUser()['$id'])),
|
|
Permission::delete(Role::user($this->getUser()['$id'])),
|
|
]
|
|
]);
|
|
|
|
$document4 = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'releaseYear' => 2020, // Missing title, expect an 400 error
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
Permission::update(Role::user($this->getUser()['$id'])),
|
|
Permission::delete(Role::user($this->getUser()['$id'])),
|
|
]
|
|
]);
|
|
|
|
$this->assertEquals(201, $document1['headers']['status-code']);
|
|
$this->assertEquals($data['moviesId'], $document1['body']['$collectionId']);
|
|
$this->assertArrayNotHasKey('$collection', $document1['body']);
|
|
$this->assertEquals($databaseId, $document1['body']['$databaseId']);
|
|
$this->assertEquals($document1['body']['title'], 'Captain America');
|
|
$this->assertEquals($document1['body']['releaseYear'], 1944);
|
|
$this->assertIsArray($document1['body']['$permissions']);
|
|
$this->assertCount(3, $document1['body']['$permissions']);
|
|
$this->assertCount(2, $document1['body']['actors']);
|
|
$this->assertEquals($document1['body']['actors'][0], 'Chris Evans');
|
|
$this->assertEquals($document1['body']['actors'][1], 'Samuel Jackson');
|
|
$this->assertEquals($document1['body']['birthDay'], '1975-06-12T12:12:55.000+00:00');
|
|
|
|
$this->assertEquals(201, $document2['headers']['status-code']);
|
|
$this->assertEquals($data['moviesId'], $document2['body']['$collectionId']);
|
|
$this->assertArrayNotHasKey('$collection', $document2['body']);
|
|
$this->assertEquals($databaseId, $document2['body']['$databaseId']);
|
|
$this->assertEquals($document2['body']['title'], 'Spider-Man: Far From Home');
|
|
$this->assertEquals($document2['body']['releaseYear'], 2019);
|
|
$this->assertEquals($document2['body']['duration'], null);
|
|
$this->assertIsArray($document2['body']['$permissions']);
|
|
$this->assertCount(3, $document2['body']['$permissions']);
|
|
$this->assertCount(3, $document2['body']['actors']);
|
|
$this->assertEquals($document2['body']['actors'][0], 'Tom Holland');
|
|
$this->assertEquals($document2['body']['actors'][1], 'Zendaya Maree Stoermer');
|
|
$this->assertEquals($document2['body']['actors'][2], 'Samuel Jackson');
|
|
$this->assertEquals($document2['body']['birthDay'], null);
|
|
|
|
$this->assertEquals(201, $document3['headers']['status-code']);
|
|
$this->assertEquals($data['moviesId'], $document3['body']['$collectionId']);
|
|
$this->assertArrayNotHasKey('$collection', $document3['body']);
|
|
$this->assertEquals($databaseId, $document3['body']['$databaseId']);
|
|
$this->assertEquals($document3['body']['title'], 'Spider-Man: Homecoming');
|
|
$this->assertEquals($document3['body']['releaseYear'], 2017);
|
|
$this->assertEquals($document3['body']['duration'], 65);
|
|
$this->assertIsArray($document3['body']['$permissions']);
|
|
$this->assertCount(3, $document3['body']['$permissions']);
|
|
$this->assertCount(2, $document3['body']['actors']);
|
|
$this->assertEquals($document3['body']['actors'][0], 'Tom Holland');
|
|
$this->assertEquals($document3['body']['actors'][1], 'Zendaya Maree Stoermer');
|
|
$this->assertEquals($document3['body']['birthDay'], '1975-06-12T18:12:55.000+00:00'); // UTC for NY
|
|
|
|
$this->assertEquals(400, $document4['headers']['status-code']);
|
|
|
|
// Delete document 4 with incomplete path
|
|
$this->assertEquals(404, $this->client->call(Client::METHOD_DELETE, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents/', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()))['headers']['status-code']);
|
|
|
|
return $data;
|
|
}
|
|
|
|
/**
|
|
* @depends testCreateDocument
|
|
*/
|
|
public function testListDocuments(array $data): array
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['orderAsc("releaseYear")'],
|
|
]);
|
|
|
|
$this->assertEquals(200, $documents['headers']['status-code']);
|
|
$this->assertEquals(1944, $documents['body']['documents'][0]['releaseYear']);
|
|
$this->assertEquals(2017, $documents['body']['documents'][1]['releaseYear']);
|
|
$this->assertEquals(2019, $documents['body']['documents'][2]['releaseYear']);
|
|
$this->assertFalse(array_key_exists('$internalId', $documents['body']['documents'][0]));
|
|
$this->assertFalse(array_key_exists('$internalId', $documents['body']['documents'][1]));
|
|
$this->assertFalse(array_key_exists('$internalId', $documents['body']['documents'][2]));
|
|
$this->assertCount(3, $documents['body']['documents']);
|
|
|
|
foreach ($documents['body']['documents'] as $document) {
|
|
$this->assertEquals($data['moviesId'], $document['$collectionId']);
|
|
$this->assertArrayNotHasKey('$collection', $document);
|
|
$this->assertEquals($databaseId, $document['$databaseId']);
|
|
}
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['orderDesc("releaseYear")'],
|
|
]);
|
|
|
|
$this->assertEquals(200, $documents['headers']['status-code']);
|
|
$this->assertEquals(1944, $documents['body']['documents'][2]['releaseYear']);
|
|
$this->assertEquals(2017, $documents['body']['documents'][1]['releaseYear']);
|
|
$this->assertEquals(2019, $documents['body']['documents'][0]['releaseYear']);
|
|
$this->assertCount(3, $documents['body']['documents']);
|
|
|
|
return ['documents' => $documents['body']['documents'], 'databaseId' => $databaseId];
|
|
}
|
|
|
|
/**
|
|
* @depends testListDocuments
|
|
*/
|
|
public function testGetDocument(array $data): void
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
foreach ($data['documents'] as $document) {
|
|
$response = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $document['$collectionId'] . '/documents/' . $document['$id'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
$this->assertEquals(200, $response['headers']['status-code']);
|
|
$this->assertEquals($response['body']['$id'], $document['$id']);
|
|
$this->assertEquals($document['$collectionId'], $response['body']['$collectionId']);
|
|
$this->assertArrayNotHasKey('$collection', $response['body']);
|
|
$this->assertEquals($document['$databaseId'], $response['body']['$databaseId']);
|
|
$this->assertEquals($response['body']['title'], $document['title']);
|
|
$this->assertEquals($response['body']['releaseYear'], $document['releaseYear']);
|
|
$this->assertEquals($response['body']['$permissions'], $document['$permissions']);
|
|
$this->assertEquals($response['body']['birthDay'], $document['birthDay']);
|
|
$this->assertFalse(array_key_exists('$internalId', $response['body']));
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @depends testListDocuments
|
|
*/
|
|
public function testGetDocumentWithQueries(array $data): void
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
$document = $data['documents'][0];
|
|
|
|
$response = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $document['$collectionId'] . '/documents/' . $document['$id'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => [
|
|
'select(["title", "releaseYear", "$id"])',
|
|
],
|
|
]);
|
|
|
|
$this->assertEquals(200, $response['headers']['status-code']);
|
|
$this->assertEquals($document['title'], $response['body']['title']);
|
|
$this->assertEquals($document['releaseYear'], $response['body']['releaseYear']);
|
|
$this->assertArrayNotHasKey('birthDay', $response['body']);
|
|
}
|
|
|
|
/**
|
|
* @depends testCreateDocument
|
|
*/
|
|
public function testListDocumentsAfterPagination(array $data): array
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
/**
|
|
* Test after without order.
|
|
*/
|
|
$base = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
$this->assertEquals(200, $base['headers']['status-code']);
|
|
$this->assertEquals('Captain America', $base['body']['documents'][0]['title']);
|
|
$this->assertEquals('Spider-Man: Far From Home', $base['body']['documents'][1]['title']);
|
|
$this->assertEquals('Spider-Man: Homecoming', $base['body']['documents'][2]['title']);
|
|
$this->assertCount(3, $base['body']['documents']);
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['cursorAfter("' . $base['body']['documents'][0]['$id'] . '")'],
|
|
]);
|
|
|
|
$this->assertEquals(200, $documents['headers']['status-code']);
|
|
$this->assertEquals($base['body']['documents'][1]['$id'], $documents['body']['documents'][0]['$id']);
|
|
$this->assertEquals($base['body']['documents'][2]['$id'], $documents['body']['documents'][1]['$id']);
|
|
$this->assertCount(2, $documents['body']['documents']);
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['cursorAfter("' . $base['body']['documents'][2]['$id'] . '")'],
|
|
]);
|
|
|
|
$this->assertEquals(200, $documents['headers']['status-code']);
|
|
$this->assertEmpty($documents['body']['documents']);
|
|
|
|
/**
|
|
* Test with ASC order and after.
|
|
*/
|
|
$base = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['orderAsc("releaseYear")'],
|
|
]);
|
|
|
|
$this->assertEquals(200, $base['headers']['status-code']);
|
|
$this->assertEquals(1944, $base['body']['documents'][0]['releaseYear']);
|
|
$this->assertEquals(2017, $base['body']['documents'][1]['releaseYear']);
|
|
$this->assertEquals(2019, $base['body']['documents'][2]['releaseYear']);
|
|
$this->assertCount(3, $base['body']['documents']);
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['cursorAfter("' . $base['body']['documents'][1]['$id'] . '")', 'orderAsc("releaseYear")'],
|
|
]);
|
|
|
|
$this->assertEquals(200, $documents['headers']['status-code']);
|
|
$this->assertEquals($base['body']['documents'][2]['$id'], $documents['body']['documents'][0]['$id']);
|
|
$this->assertCount(1, $documents['body']['documents']);
|
|
|
|
/**
|
|
* Test with DESC order and after.
|
|
*/
|
|
$base = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['orderDesc("releaseYear")'],
|
|
]);
|
|
|
|
$this->assertEquals(200, $base['headers']['status-code']);
|
|
$this->assertEquals(1944, $base['body']['documents'][2]['releaseYear']);
|
|
$this->assertEquals(2017, $base['body']['documents'][1]['releaseYear']);
|
|
$this->assertEquals(2019, $base['body']['documents'][0]['releaseYear']);
|
|
$this->assertCount(3, $base['body']['documents']);
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['cursorAfter("' . $base['body']['documents'][1]['$id'] . '")', 'orderDesc("releaseYear")'],
|
|
]);
|
|
|
|
$this->assertEquals(200, $documents['headers']['status-code']);
|
|
$this->assertEquals($base['body']['documents'][2]['$id'], $documents['body']['documents'][0]['$id']);
|
|
$this->assertCount(1, $documents['body']['documents']);
|
|
|
|
/**
|
|
* Test after with unknown document.
|
|
*/
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['cursorAfter("unknown")'],
|
|
]);
|
|
|
|
$this->assertEquals(400, $documents['headers']['status-code']);
|
|
|
|
return [];
|
|
}
|
|
|
|
/**
|
|
* @depends testCreateDocument
|
|
*/
|
|
public function testListDocumentsBeforePagination(array $data): array
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
/**
|
|
* Test before without order.
|
|
*/
|
|
$base = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
$this->assertEquals(200, $base['headers']['status-code']);
|
|
$this->assertEquals('Captain America', $base['body']['documents'][0]['title']);
|
|
$this->assertEquals('Spider-Man: Far From Home', $base['body']['documents'][1]['title']);
|
|
$this->assertEquals('Spider-Man: Homecoming', $base['body']['documents'][2]['title']);
|
|
$this->assertCount(3, $base['body']['documents']);
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['cursorBefore("' . $base['body']['documents'][2]['$id'] . '")'],
|
|
]);
|
|
|
|
$this->assertEquals(200, $documents['headers']['status-code']);
|
|
$this->assertEquals($base['body']['documents'][0]['$id'], $documents['body']['documents'][0]['$id']);
|
|
$this->assertEquals($base['body']['documents'][1]['$id'], $documents['body']['documents'][1]['$id']);
|
|
$this->assertCount(2, $documents['body']['documents']);
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['cursorBefore("' . $base['body']['documents'][0]['$id'] . '")'],
|
|
]);
|
|
|
|
$this->assertEquals(200, $documents['headers']['status-code']);
|
|
$this->assertEmpty($documents['body']['documents']);
|
|
|
|
/**
|
|
* Test with ASC order and after.
|
|
*/
|
|
$base = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['orderAsc("releaseYear")'],
|
|
]);
|
|
|
|
$this->assertEquals(200, $base['headers']['status-code']);
|
|
$this->assertEquals(1944, $base['body']['documents'][0]['releaseYear']);
|
|
$this->assertEquals(2017, $base['body']['documents'][1]['releaseYear']);
|
|
$this->assertEquals(2019, $base['body']['documents'][2]['releaseYear']);
|
|
$this->assertCount(3, $base['body']['documents']);
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['cursorBefore("' . $base['body']['documents'][1]['$id'] . '")', 'orderAsc("releaseYear")'],
|
|
]);
|
|
|
|
$this->assertEquals(200, $documents['headers']['status-code']);
|
|
$this->assertEquals($base['body']['documents'][0]['$id'], $documents['body']['documents'][0]['$id']);
|
|
$this->assertCount(1, $documents['body']['documents']);
|
|
|
|
/**
|
|
* Test with DESC order and after.
|
|
*/
|
|
$base = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['orderDesc("releaseYear")'],
|
|
]);
|
|
|
|
$this->assertEquals(200, $base['headers']['status-code']);
|
|
$this->assertEquals(1944, $base['body']['documents'][2]['releaseYear']);
|
|
$this->assertEquals(2017, $base['body']['documents'][1]['releaseYear']);
|
|
$this->assertEquals(2019, $base['body']['documents'][0]['releaseYear']);
|
|
$this->assertCount(3, $base['body']['documents']);
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['cursorBefore("' . $base['body']['documents'][1]['$id'] . '")', 'orderDesc("releaseYear")'],
|
|
]);
|
|
|
|
$this->assertEquals(200, $documents['headers']['status-code']);
|
|
$this->assertEquals($base['body']['documents'][0]['$id'], $documents['body']['documents'][0]['$id']);
|
|
$this->assertCount(1, $documents['body']['documents']);
|
|
|
|
return [];
|
|
}
|
|
|
|
/**
|
|
* @depends testCreateDocument
|
|
*/
|
|
public function testListDocumentsLimitAndOffset(array $data): array
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['limit(1)', 'orderAsc("releaseYear")'],
|
|
]);
|
|
|
|
$this->assertEquals(200, $documents['headers']['status-code']);
|
|
$this->assertEquals(1944, $documents['body']['documents'][0]['releaseYear']);
|
|
$this->assertCount(1, $documents['body']['documents']);
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['limit(2)', 'offset(1)', 'orderAsc("releaseYear")'],
|
|
]);
|
|
|
|
$this->assertEquals(200, $documents['headers']['status-code']);
|
|
$this->assertEquals(2017, $documents['body']['documents'][0]['releaseYear']);
|
|
$this->assertEquals(2019, $documents['body']['documents'][1]['releaseYear']);
|
|
$this->assertCount(2, $documents['body']['documents']);
|
|
|
|
return [];
|
|
}
|
|
|
|
/**
|
|
* @depends testCreateDocument
|
|
*/
|
|
public function testDocumentsListQueries(array $data): array
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['search("title", "Captain America")'],
|
|
]);
|
|
|
|
$this->assertEquals(200, $documents['headers']['status-code']);
|
|
$this->assertEquals(1944, $documents['body']['documents'][0]['releaseYear']);
|
|
$this->assertCount(1, $documents['body']['documents']);
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['equal("$id", "' . $documents['body']['documents'][0]['$id'] . '")'],
|
|
]);
|
|
|
|
$this->assertEquals(200, $documents['headers']['status-code']);
|
|
$this->assertEquals(1944, $documents['body']['documents'][0]['releaseYear']);
|
|
$this->assertCount(1, $documents['body']['documents']);
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['search("title", "Homecoming")'],
|
|
]);
|
|
|
|
$this->assertEquals(200, $documents['headers']['status-code']);
|
|
$this->assertEquals(2017, $documents['body']['documents'][0]['releaseYear']);
|
|
$this->assertCount(1, $documents['body']['documents']);
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['search("title", "spider")'],
|
|
]);
|
|
|
|
$this->assertEquals(200, $documents['headers']['status-code']);
|
|
$this->assertEquals(2019, $documents['body']['documents'][0]['releaseYear']);
|
|
$this->assertEquals(2017, $documents['body']['documents'][1]['releaseYear']);
|
|
$this->assertCount(2, $documents['body']['documents']);
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['equal("releaseYear", 1944)'],
|
|
]);
|
|
|
|
$this->assertCount(1, $documents['body']['documents']);
|
|
$this->assertEquals('Captain America', $documents['body']['documents'][0]['title']);
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['notEqual("releaseYear", 1944)'],
|
|
]);
|
|
|
|
$this->assertCount(2, $documents['body']['documents']);
|
|
$this->assertEquals('Spider-Man: Far From Home', $documents['body']['documents'][0]['title']);
|
|
$this->assertEquals('Spider-Man: Homecoming', $documents['body']['documents'][1]['title']);
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['greaterThan("$createdAt", "1976-06-12")'],
|
|
]);
|
|
|
|
$this->assertCount(3, $documents['body']['documents']);
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['lessThan("$createdAt", "1976-06-12")'],
|
|
]);
|
|
|
|
$this->assertCount(0, $documents['body']['documents']);
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['equal("actors", "Tom Holland")'],
|
|
]);
|
|
$this->assertEquals(200, $documents['headers']['status-code']);
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['greaterThan("birthDay", "1960-01-01 10:10:10+02:30")'],
|
|
]);
|
|
|
|
$this->assertEquals(200, $documents['headers']['status-code']);
|
|
$this->assertEquals('1975-06-12T12:12:55.000+00:00', $documents['body']['documents'][0]['birthDay']);
|
|
$this->assertEquals('1975-06-12T18:12:55.000+00:00', $documents['body']['documents'][1]['birthDay']);
|
|
$this->assertCount(2, $documents['body']['documents']);
|
|
|
|
/**
|
|
* Test for Failure
|
|
*/
|
|
$conditions = [];
|
|
|
|
for ($i = 0; $i < 101; $i++) {
|
|
$conditions[] = $i;
|
|
}
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['equal("releaseYear", [' . implode(',', $conditions) . '])'],
|
|
]);
|
|
|
|
$this->assertEquals(400, $documents['headers']['status-code']);
|
|
|
|
$conditions = [];
|
|
|
|
for ($i = 0; $i < 101; $i++) {
|
|
$conditions[] = "[" . $i . "] Too long title to cross 2k chars query limit";
|
|
}
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['search("title", ' . implode(',', $conditions) . ')'],
|
|
]);
|
|
|
|
$this->assertEquals(400, $documents['headers']['status-code']);
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => ['search("actors", "Tom")'],
|
|
]);
|
|
$this->assertEquals(400, $documents['headers']['status-code']);
|
|
$this->assertEquals('Searching by attribute "actors" requires a fulltext index.', $documents['body']['message']);
|
|
|
|
return [];
|
|
}
|
|
|
|
/**
|
|
* @depends testCreateDocument
|
|
*/
|
|
public function testUpdateDocument(array $data): array
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
$document = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'title' => 'Thor: Ragnaroc',
|
|
'releaseYear' => 2017,
|
|
'birthDay' => '1976-06-12 14:12:55',
|
|
'actors' => [],
|
|
'$createdAt' => 5 // Should be ignored
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
Permission::update(Role::user($this->getUser()['$id'])),
|
|
Permission::delete(Role::user($this->getUser()['$id'])),
|
|
],
|
|
]);
|
|
|
|
$id = $document['body']['$id'];
|
|
|
|
$this->assertEquals(201, $document['headers']['status-code']);
|
|
$this->assertEquals($data['moviesId'], $document['body']['$collectionId']);
|
|
$this->assertArrayNotHasKey('$collection', $document['body']);
|
|
$this->assertEquals($databaseId, $document['body']['$databaseId']);
|
|
$this->assertEquals($document['body']['title'], 'Thor: Ragnaroc');
|
|
$this->assertEquals($document['body']['releaseYear'], 2017);
|
|
$dateValidator = new DatetimeValidator();
|
|
$this->assertEquals(true, $dateValidator->isValid($document['body']['$createdAt']));
|
|
$this->assertEquals(true, $dateValidator->isValid($document['body']['birthDay']));
|
|
$this->assertContains(Permission::read(Role::user($this->getUser()['$id'])), $document['body']['$permissions']);
|
|
$this->assertContains(Permission::update(Role::user($this->getUser()['$id'])), $document['body']['$permissions']);
|
|
$this->assertContains(Permission::delete(Role::user($this->getUser()['$id'])), $document['body']['$permissions']);
|
|
|
|
$document = $this->client->call(Client::METHOD_PATCH, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents/' . $id, array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'data' => [
|
|
'title' => 'Thor: Ragnarok',
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::users()),
|
|
Permission::update(Role::users()),
|
|
Permission::delete(Role::users()),
|
|
],
|
|
]);
|
|
|
|
$this->assertEquals(200, $document['headers']['status-code']);
|
|
$this->assertEquals($document['body']['$id'], $id);
|
|
$this->assertEquals($data['moviesId'], $document['body']['$collectionId']);
|
|
$this->assertArrayNotHasKey('$collection', $document['body']);
|
|
$this->assertEquals($databaseId, $document['body']['$databaseId']);
|
|
$this->assertEquals($document['body']['title'], 'Thor: Ragnarok');
|
|
$this->assertEquals($document['body']['releaseYear'], 2017);
|
|
$this->assertContains(Permission::read(Role::users()), $document['body']['$permissions']);
|
|
$this->assertContains(Permission::update(Role::users()), $document['body']['$permissions']);
|
|
$this->assertContains(Permission::delete(Role::users()), $document['body']['$permissions']);
|
|
|
|
$document = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents/' . $id, array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
$id = $document['body']['$id'];
|
|
|
|
$this->assertEquals(200, $document['headers']['status-code']);
|
|
$this->assertEquals($data['moviesId'], $document['body']['$collectionId']);
|
|
$this->assertArrayNotHasKey('$collection', $document['body']);
|
|
$this->assertEquals($databaseId, $document['body']['$databaseId']);
|
|
$this->assertEquals($document['body']['title'], 'Thor: Ragnarok');
|
|
$this->assertEquals($document['body']['releaseYear'], 2017);
|
|
|
|
$response = $this->client->call(Client::METHOD_PATCH, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents/' . $id, array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-timestamp' => DateTime::formatTz(DateTime::now()),
|
|
], $this->getHeaders()), [
|
|
'data' => [
|
|
'title' => 'Thor: Ragnarok',
|
|
],
|
|
]);
|
|
|
|
$this->assertEquals(200, $response['headers']['status-code']);
|
|
|
|
/**
|
|
* Test for failure
|
|
*/
|
|
|
|
$response = $this->client->call(Client::METHOD_PATCH, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents/' . $id, array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-timestamp' => 'invalid',
|
|
], $this->getHeaders()), [
|
|
'data' => [
|
|
'title' => 'Thor: Ragnarok',
|
|
],
|
|
]);
|
|
|
|
$this->assertEquals(400, $response['headers']['status-code']);
|
|
$this->assertEquals('Invalid X-Appwrite-Timestamp header value', $response['body']['message']);
|
|
$this->assertEquals(Exception::GENERAL_ARGUMENT_INVALID, $response['body']['type']);
|
|
|
|
$response = $this->client->call(Client::METHOD_PATCH, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents/' . $id, array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-timestamp' => DateTime::formatTz(DateTime::addSeconds(new \DateTime(), -1000)),
|
|
], $this->getHeaders()), [
|
|
'data' => [
|
|
'title' => 'Thor: Ragnarok',
|
|
],
|
|
]);
|
|
|
|
$this->assertEquals(409, $response['headers']['status-code']);
|
|
$this->assertEquals('Remote document is newer than local.', $response['body']['message']);
|
|
$this->assertEquals(Exception::DOCUMENT_UPDATE_CONFLICT, $response['body']['type']);
|
|
|
|
return [];
|
|
}
|
|
|
|
/**
|
|
* @depends testCreateDocument
|
|
*/
|
|
public function testDeleteDocument(array $data): array
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
$document = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'title' => 'Thor: Ragnarok',
|
|
'releaseYear' => 2017,
|
|
'birthDay' => '1975-06-12 14:12:55',
|
|
'actors' => [],
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
Permission::update(Role::user($this->getUser()['$id'])),
|
|
Permission::delete(Role::user($this->getUser()['$id'])),
|
|
]
|
|
]);
|
|
|
|
$id = $document['body']['$id'];
|
|
|
|
$this->assertEquals(201, $document['headers']['status-code']);
|
|
|
|
$document = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents/' . $id, array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
$this->assertEquals(200, $document['headers']['status-code']);
|
|
|
|
$document = $this->client->call(Client::METHOD_DELETE, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents/' . $id, array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
$this->assertEquals(204, $document['headers']['status-code']);
|
|
|
|
$document = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents/' . $id, array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
$this->assertEquals(404, $document['headers']['status-code']);
|
|
|
|
return $data;
|
|
}
|
|
|
|
public function testInvalidDocumentStructure()
|
|
{
|
|
$database = $this->client->call(Client::METHOD_POST, '/databases', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'databaseId' => ID::unique(),
|
|
'name' => 'InvalidDocumentDatabase',
|
|
]);
|
|
$this->assertEquals(201, $database['headers']['status-code']);
|
|
$this->assertEquals('InvalidDocumentDatabase', $database['body']['name']);
|
|
|
|
$databaseId = $database['body']['$id'];
|
|
$collection = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'collectionId' => ID::unique(),
|
|
'name' => 'invalidDocumentStructure',
|
|
'permissions' => [
|
|
Permission::create(Role::any()),
|
|
Permission::read(Role::any()),
|
|
],
|
|
'documentSecurity' => true,
|
|
]);
|
|
|
|
$this->assertEquals(201, $collection['headers']['status-code']);
|
|
$this->assertEquals('invalidDocumentStructure', $collection['body']['name']);
|
|
|
|
$collectionId = $collection['body']['$id'];
|
|
|
|
$email = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes/email', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'email',
|
|
'required' => false,
|
|
]);
|
|
|
|
$enum = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes/enum', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'enum',
|
|
'elements' => ['yes', 'no', 'maybe'],
|
|
'required' => false,
|
|
]);
|
|
|
|
$ip = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes/ip', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'ip',
|
|
'required' => false,
|
|
]);
|
|
|
|
$url = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes/url', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'url',
|
|
'size' => 256,
|
|
'required' => false,
|
|
]);
|
|
|
|
$range = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes/integer', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'range',
|
|
'required' => false,
|
|
'min' => 1,
|
|
'max' => 10,
|
|
]);
|
|
|
|
// TODO@kodumbeats min and max are rounded in error message
|
|
$floatRange = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes/float', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'floatRange',
|
|
'required' => false,
|
|
'min' => 1.1,
|
|
'max' => 1.4,
|
|
]);
|
|
|
|
$probability = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes/float', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'probability',
|
|
'required' => false,
|
|
'default' => 0,
|
|
'min' => 0,
|
|
'max' => 1,
|
|
]);
|
|
|
|
$upperBound = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes/integer', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'upperBound',
|
|
'required' => false,
|
|
'max' => 10,
|
|
]);
|
|
|
|
$lowerBound = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes/integer', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'lowerBound',
|
|
'required' => false,
|
|
'min' => 5,
|
|
]);
|
|
|
|
/**
|
|
* Test for failure
|
|
*/
|
|
|
|
$invalidRange = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes/integer', array_merge([
|
|
'content-type' => 'application/json', 'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'invalidRange',
|
|
'required' => false,
|
|
'min' => 4,
|
|
'max' => 3,
|
|
]);
|
|
|
|
$defaultArray = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes/integer', array_merge([
|
|
'content-type' => 'application/json', 'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'defaultArray',
|
|
'required' => false,
|
|
'default' => 42,
|
|
'array' => true,
|
|
]);
|
|
|
|
$defaultRequired = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes/integer', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'attributeId' => ID::custom('defaultRequired'),
|
|
'required' => true,
|
|
'default' => 12
|
|
]);
|
|
|
|
$enumDefault = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes/enum', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'attributeId' => ID::custom('enumDefault'),
|
|
'elements' => ['north', 'west'],
|
|
'default' => 'south'
|
|
]);
|
|
|
|
$enumDefaultStrict = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes/enum', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'attributeId' => ID::custom('enumDefault'),
|
|
'elements' => ['north', 'west'],
|
|
'default' => 'NORTH'
|
|
]);
|
|
|
|
$goodDatetime = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes/datetime', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'birthDay',
|
|
'required' => false,
|
|
'default' => null
|
|
]);
|
|
|
|
$datetimeDefault = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes/datetime', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'badBirthDay',
|
|
'required' => false,
|
|
'default' => 'bad'
|
|
]);
|
|
|
|
$this->assertEquals(202, $email['headers']['status-code']);
|
|
$this->assertEquals(202, $ip['headers']['status-code']);
|
|
$this->assertEquals(202, $url['headers']['status-code']);
|
|
$this->assertEquals(202, $range['headers']['status-code']);
|
|
$this->assertEquals(202, $floatRange['headers']['status-code']);
|
|
$this->assertEquals(202, $probability['headers']['status-code']);
|
|
$this->assertEquals(202, $upperBound['headers']['status-code']);
|
|
$this->assertEquals(202, $lowerBound['headers']['status-code']);
|
|
$this->assertEquals(202, $enum['headers']['status-code']);
|
|
$this->assertEquals(202, $goodDatetime['headers']['status-code']);
|
|
$this->assertEquals(400, $invalidRange['headers']['status-code']);
|
|
$this->assertEquals(400, $defaultArray['headers']['status-code']);
|
|
$this->assertEquals(400, $defaultRequired['headers']['status-code']);
|
|
$this->assertEquals(400, $enumDefault['headers']['status-code']);
|
|
$this->assertEquals(400, $enumDefaultStrict['headers']['status-code']);
|
|
$this->assertEquals('Minimum value must be lesser than maximum value', $invalidRange['body']['message']);
|
|
$this->assertEquals('Cannot set default value for array attributes', $defaultArray['body']['message']);
|
|
$this->assertEquals(400, $datetimeDefault['headers']['status-code']);
|
|
// wait for worker to add attributes
|
|
sleep(3);
|
|
|
|
$collection = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $collectionId, array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey'],
|
|
]), []);
|
|
|
|
$this->assertCount(10, $collection['body']['attributes']);
|
|
|
|
/**
|
|
* Test for successful validation
|
|
*/
|
|
|
|
$goodEmail = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'email' => 'user@example.com',
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$goodEnum = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'enum' => 'yes',
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$goodIp = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'ip' => '1.1.1.1',
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$goodUrl = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'url' => 'http://www.example.com',
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$goodRange = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'range' => 3,
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$goodFloatRange = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'floatRange' => 1.4,
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$goodProbability = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'probability' => 0.99999,
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$notTooHigh = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'upperBound' => 8,
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$notTooLow = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'lowerBound' => 8,
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$this->assertEquals(201, $goodEmail['headers']['status-code']);
|
|
$this->assertEquals(201, $goodEnum['headers']['status-code']);
|
|
$this->assertEquals(201, $goodIp['headers']['status-code']);
|
|
$this->assertEquals(201, $goodUrl['headers']['status-code']);
|
|
$this->assertEquals(201, $goodRange['headers']['status-code']);
|
|
$this->assertEquals(201, $goodFloatRange['headers']['status-code']);
|
|
$this->assertEquals(201, $goodProbability['headers']['status-code']);
|
|
$this->assertEquals(201, $notTooHigh['headers']['status-code']);
|
|
$this->assertEquals(201, $notTooLow['headers']['status-code']);
|
|
|
|
/*
|
|
* Test that custom validators reject documents
|
|
*/
|
|
|
|
$badEmail = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'email' => 'user@@example.com',
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$badEnum = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'enum' => 'badEnum',
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$badIp = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'ip' => '1.1.1.1.1',
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$badUrl = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'url' => 'example...com',
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$badRange = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'range' => 11,
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$badFloatRange = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'floatRange' => 2.5,
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$badProbability = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'probability' => 1.1,
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$tooHigh = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'upperBound' => 11,
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$tooLow = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'lowerBound' => 3,
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$badTime = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => 'unique()',
|
|
'data' => [
|
|
'birthDay' => '2020-10-10 27:30:10+01:00',
|
|
],
|
|
'read' => ['user:' . $this->getUser()['$id']],
|
|
'write' => ['user:' . $this->getUser()['$id']],
|
|
]);
|
|
|
|
$this->assertEquals(400, $badEmail['headers']['status-code']);
|
|
$this->assertEquals(400, $badEnum['headers']['status-code']);
|
|
$this->assertEquals(400, $badIp['headers']['status-code']);
|
|
$this->assertEquals(400, $badUrl['headers']['status-code']);
|
|
$this->assertEquals(400, $badRange['headers']['status-code']);
|
|
$this->assertEquals(400, $badFloatRange['headers']['status-code']);
|
|
$this->assertEquals(400, $badProbability['headers']['status-code']);
|
|
$this->assertEquals(400, $tooHigh['headers']['status-code']);
|
|
$this->assertEquals(400, $tooLow['headers']['status-code']);
|
|
$this->assertEquals(400, $badTime['headers']['status-code']);
|
|
$this->assertEquals('Invalid document structure: Attribute "email" has invalid format. Value must be a valid email address', $badEmail['body']['message']);
|
|
$this->assertEquals('Invalid document structure: Attribute "enum" has invalid format. Value must be one of (yes, no, maybe)', $badEnum['body']['message']);
|
|
$this->assertEquals('Invalid document structure: Attribute "ip" has invalid format. Value must be a valid IP address', $badIp['body']['message']);
|
|
$this->assertEquals('Invalid document structure: Attribute "url" has invalid format. Value must be a valid URL', $badUrl['body']['message']);
|
|
$this->assertEquals('Invalid document structure: Attribute "range" has invalid format. Value must be a valid range between 1 and 10', $badRange['body']['message']);
|
|
$this->assertEquals('Invalid document structure: Attribute "floatRange" has invalid format. Value must be a valid range between 1 and 1', $badFloatRange['body']['message']);
|
|
$this->assertEquals('Invalid document structure: Attribute "probability" has invalid format. Value must be a valid range between 0 and 1', $badProbability['body']['message']);
|
|
$this->assertEquals('Invalid document structure: Attribute "upperBound" has invalid format. Value must be a valid range between -9,223,372,036,854,775,808 and 10', $tooHigh['body']['message']);
|
|
$this->assertEquals('Invalid document structure: Attribute "lowerBound" has invalid format. Value must be a valid range between 5 and 9,223,372,036,854,775,808', $tooLow['body']['message']);
|
|
}
|
|
|
|
/**
|
|
* @depends testDeleteDocument
|
|
*/
|
|
public function testDefaultPermissions(array $data): array
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
$document = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'title' => 'Captain America',
|
|
'releaseYear' => 1944,
|
|
'actors' => [],
|
|
],
|
|
]);
|
|
|
|
$id = $document['body']['$id'];
|
|
|
|
$this->assertEquals(201, $document['headers']['status-code']);
|
|
$this->assertEquals($document['body']['title'], 'Captain America');
|
|
$this->assertEquals($document['body']['releaseYear'], 1944);
|
|
$this->assertIsArray($document['body']['$permissions']);
|
|
|
|
if ($this->getSide() == 'client') {
|
|
$this->assertCount(3, $document['body']['$permissions']);
|
|
$this->assertContains(Permission::read(Role::user($this->getUser()['$id'])), $document['body']['$permissions']);
|
|
$this->assertContains(Permission::update(Role::user($this->getUser()['$id'])), $document['body']['$permissions']);
|
|
$this->assertContains(Permission::delete(Role::user($this->getUser()['$id'])), $document['body']['$permissions']);
|
|
}
|
|
|
|
if ($this->getSide() == 'server') {
|
|
$this->assertCount(0, $document['body']['$permissions']);
|
|
$this->assertEquals([], $document['body']['$permissions']);
|
|
}
|
|
|
|
// Updated Permissions
|
|
|
|
$document = $this->client->call(Client::METHOD_PATCH, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents/' . $id, array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'data' => [
|
|
'title' => 'Captain America 2',
|
|
'releaseYear' => 1945,
|
|
'actors' => [],
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
Permission::update(Role::user($this->getUser()['$id']))
|
|
],
|
|
]);
|
|
|
|
$this->assertEquals(200, $document['headers']['status-code']);
|
|
$this->assertEquals($document['body']['title'], 'Captain America 2');
|
|
$this->assertEquals($document['body']['releaseYear'], 1945);
|
|
|
|
// This differs from the old permissions model because we don't inherit
|
|
// existing document permissions on update, unless none were supplied,
|
|
// so that specific types can be removed if wanted.
|
|
$this->assertCount(2, $document['body']['$permissions']);
|
|
$this->assertEquals([
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
Permission::update(Role::user($this->getUser()['$id'])),
|
|
], $document['body']['$permissions']);
|
|
|
|
$document = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents/' . $id, array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
$this->assertEquals(200, $document['headers']['status-code']);
|
|
$this->assertEquals($document['body']['title'], 'Captain America 2');
|
|
$this->assertEquals($document['body']['releaseYear'], 1945);
|
|
|
|
$this->assertCount(2, $document['body']['$permissions']);
|
|
$this->assertEquals([
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
Permission::update(Role::user($this->getUser()['$id'])),
|
|
], $document['body']['$permissions']);
|
|
|
|
// Reset Permissions
|
|
|
|
$document = $this->client->call(Client::METHOD_PATCH, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents/' . $id, array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'data' => [
|
|
'title' => 'Captain America 3',
|
|
'releaseYear' => 1946,
|
|
'actors' => [],
|
|
],
|
|
'permissions' => [],
|
|
]);
|
|
|
|
$this->assertEquals(200, $document['headers']['status-code']);
|
|
$this->assertEquals($document['body']['title'], 'Captain America 3');
|
|
$this->assertEquals($document['body']['releaseYear'], 1946);
|
|
$this->assertCount(0, $document['body']['$permissions']);
|
|
$this->assertEquals([], $document['body']['$permissions']);
|
|
|
|
// Check client side can no longer read the document.
|
|
$document = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents/' . $id, array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
switch ($this->getSide()) {
|
|
case 'client':
|
|
$this->assertEquals(404, $document['headers']['status-code']);
|
|
break;
|
|
case 'server':
|
|
$this->assertEquals(200, $document['headers']['status-code']);
|
|
break;
|
|
}
|
|
|
|
return $data;
|
|
}
|
|
|
|
public function testEnforceCollectionAndDocumentPermissions(): void
|
|
{
|
|
$database = $this->client->call(Client::METHOD_POST, '/databases', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'databaseId' => ID::unique(),
|
|
'name' => 'EnforceCollectionAndDocumentPermissions',
|
|
]);
|
|
$this->assertEquals(201, $database['headers']['status-code']);
|
|
$this->assertEquals('EnforceCollectionAndDocumentPermissions', $database['body']['name']);
|
|
|
|
$databaseId = $database['body']['$id'];
|
|
$user = $this->getUser()['$id'];
|
|
$collection = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'collectionId' => ID::unique(),
|
|
'name' => 'enforceCollectionAndDocumentPermissions',
|
|
'documentSecurity' => true,
|
|
'permissions' => [
|
|
Permission::read(Role::user($user)),
|
|
Permission::create(Role::user($user)),
|
|
Permission::update(Role::user($user)),
|
|
Permission::delete(Role::user($user)),
|
|
],
|
|
]);
|
|
|
|
$this->assertEquals(201, $collection['headers']['status-code']);
|
|
$this->assertEquals($collection['body']['name'], 'enforceCollectionAndDocumentPermissions');
|
|
$this->assertEquals($collection['body']['documentSecurity'], true);
|
|
|
|
$collectionId = $collection['body']['$id'];
|
|
|
|
sleep(2);
|
|
|
|
$attribute = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes/string', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'attribute',
|
|
'size' => 64,
|
|
'required' => true,
|
|
]);
|
|
|
|
$this->assertEquals(202, $attribute['headers']['status-code'], 202);
|
|
$this->assertEquals('attribute', $attribute['body']['key']);
|
|
|
|
// wait for db to add attribute
|
|
sleep(2);
|
|
|
|
$index = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/indexes', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'key_attribute',
|
|
'type' => 'key',
|
|
'attributes' => [$attribute['body']['key']],
|
|
]);
|
|
|
|
$this->assertEquals(202, $index['headers']['status-code']);
|
|
$this->assertEquals('key_attribute', $index['body']['key']);
|
|
|
|
// wait for db to add attribute
|
|
sleep(2);
|
|
|
|
$document1 = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'attribute' => 'one',
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user($user)),
|
|
Permission::update(Role::user($user)),
|
|
Permission::delete(Role::user($user)),
|
|
]
|
|
]);
|
|
|
|
$this->assertEquals(201, $document1['headers']['status-code']);
|
|
|
|
$document2 = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'attribute' => 'one',
|
|
],
|
|
'permissions' => [
|
|
Permission::update(Role::user($user)),
|
|
Permission::delete(Role::user($user)),
|
|
]
|
|
]);
|
|
|
|
$this->assertEquals(201, $document2['headers']['status-code']);
|
|
|
|
$document3 = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', [
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
], [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'attribute' => 'one',
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom('other'))),
|
|
Permission::update(Role::user(ID::custom('other'))),
|
|
],
|
|
]);
|
|
|
|
$this->assertEquals(201, $document3['headers']['status-code']);
|
|
|
|
$documentsUser1 = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
// Current user has read permission on the collection so can get any document
|
|
$this->assertEquals(3, $documentsUser1['body']['total']);
|
|
$this->assertCount(3, $documentsUser1['body']['documents']);
|
|
|
|
$document3GetWithCollectionRead = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents/' . $document3['body']['$id'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
// Current user has read permission on the collection so can get any document
|
|
$this->assertEquals(200, $document3GetWithCollectionRead['headers']['status-code']);
|
|
|
|
$email = uniqid() . 'user@localhost.test';
|
|
$password = 'password';
|
|
$name = 'User Name';
|
|
$this->client->call(Client::METHOD_POST, '/account', [
|
|
'origin' => 'http://localhost',
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], [
|
|
'userId' => ID::custom('other'),
|
|
'email' => $email,
|
|
'password' => $password,
|
|
'name' => $name,
|
|
]);
|
|
$session2 = $this->client->call(Client::METHOD_POST, '/account/sessions/email', [
|
|
'origin' => 'http://localhost',
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], [
|
|
'email' => $email,
|
|
'password' => $password,
|
|
]);
|
|
$session2 = $this->client->parseCookie((string)$session2['headers']['set-cookie'])['a_session_' . $this->getProject()['$id']];
|
|
|
|
$document3GetWithDocumentRead = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents/' . $document3['body']['$id'], [
|
|
'origin' => 'http://localhost',
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'cookie' => 'a_session_' . $this->getProject()['$id'] . '=' . $session2,
|
|
]);
|
|
|
|
// Current user has no collection permissions but has read permission for this document
|
|
$this->assertEquals(200, $document3GetWithDocumentRead['headers']['status-code']);
|
|
|
|
$document2GetFailure = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents/' . $document2['body']['$id'], [
|
|
'origin' => 'http://localhost',
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'cookie' => 'a_session_' . $this->getProject()['$id'] . '=' . $session2,
|
|
]);
|
|
|
|
// Current user has no collection or document permissions for this document
|
|
$this->assertEquals(404, $document2GetFailure['headers']['status-code']);
|
|
|
|
$documentsUser2 = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', [
|
|
'origin' => 'http://localhost',
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'cookie' => 'a_session_' . $this->getProject()['$id'] . '=' . $session2,
|
|
]);
|
|
|
|
// Current user has no collection permissions but has read permission for one document
|
|
$this->assertEquals(1, $documentsUser2['body']['total']);
|
|
$this->assertCount(1, $documentsUser2['body']['documents']);
|
|
}
|
|
|
|
public function testEnforceCollectionPermissions()
|
|
{
|
|
$database = $this->client->call(Client::METHOD_POST, '/databases', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'databaseId' => ID::unique(),
|
|
'name' => 'EnforceCollectionPermissions',
|
|
]);
|
|
$this->assertEquals(201, $database['headers']['status-code']);
|
|
$this->assertEquals('EnforceCollectionPermissions', $database['body']['name']);
|
|
|
|
$databaseId = $database['body']['$id'];
|
|
$user = $this->getUser()['$id'];
|
|
$collection = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'collectionId' => ID::unique(),
|
|
'name' => 'enforceCollectionPermissions',
|
|
'permissions' => [
|
|
Permission::read(Role::user($user)),
|
|
Permission::create(Role::user($user)),
|
|
Permission::update(Role::user($user)),
|
|
Permission::delete(Role::user($user)),
|
|
],
|
|
]);
|
|
|
|
$this->assertEquals(201, $collection['headers']['status-code']);
|
|
$this->assertEquals($collection['body']['name'], 'enforceCollectionPermissions');
|
|
$this->assertEquals($collection['body']['documentSecurity'], false);
|
|
|
|
$collectionId = $collection['body']['$id'];
|
|
|
|
$attribute = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes/string', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'attribute',
|
|
'size' => 64,
|
|
'required' => true,
|
|
]);
|
|
|
|
$this->assertEquals(202, $attribute['headers']['status-code'], 202);
|
|
$this->assertEquals('attribute', $attribute['body']['key']);
|
|
|
|
\sleep(2);
|
|
|
|
$index = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/indexes', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'key_attribute',
|
|
'type' => 'key',
|
|
'attributes' => [$attribute['body']['key']],
|
|
]);
|
|
|
|
$this->assertEquals(202, $index['headers']['status-code']);
|
|
$this->assertEquals('key_attribute', $index['body']['key']);
|
|
|
|
\sleep(2);
|
|
|
|
$document1 = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'attribute' => 'one',
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user($user)),
|
|
Permission::update(Role::user($user)),
|
|
Permission::delete(Role::user($user)),
|
|
]
|
|
]);
|
|
|
|
$this->assertEquals(201, $document1['headers']['status-code']);
|
|
|
|
$document2 = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'attribute' => 'one',
|
|
],
|
|
'permissions' => [
|
|
Permission::update(Role::user($user)),
|
|
Permission::delete(Role::user($user)),
|
|
]
|
|
]);
|
|
|
|
$this->assertEquals(201, $document2['headers']['status-code']);
|
|
|
|
$document3 = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', [
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
], [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'attribute' => 'one',
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom('other2'))),
|
|
Permission::update(Role::user(ID::custom('other2'))),
|
|
],
|
|
]);
|
|
|
|
$this->assertEquals(201, $document3['headers']['status-code']);
|
|
|
|
$documentsUser1 = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
// Current user has read permission on the collection so can get any document
|
|
$this->assertEquals(3, $documentsUser1['body']['total']);
|
|
$this->assertCount(3, $documentsUser1['body']['documents']);
|
|
|
|
$document3GetWithCollectionRead = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents/' . $document3['body']['$id'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
// Current user has read permission on the collection so can get any document
|
|
$this->assertEquals(200, $document3GetWithCollectionRead['headers']['status-code']);
|
|
|
|
$email = uniqid() . 'user2@localhost.test';
|
|
$password = 'password';
|
|
$name = 'User Name';
|
|
$this->client->call(Client::METHOD_POST, '/account', [
|
|
'origin' => 'http://localhost',
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], [
|
|
'userId' => ID::custom('other2'),
|
|
'email' => $email,
|
|
'password' => $password,
|
|
'name' => $name,
|
|
]);
|
|
$session2 = $this->client->call(Client::METHOD_POST, '/account/sessions/email', [
|
|
'origin' => 'http://localhost',
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], [
|
|
'email' => $email,
|
|
'password' => $password,
|
|
]);
|
|
$session2 = $this->client->parseCookie((string)$session2['headers']['set-cookie'])['a_session_' . $this->getProject()['$id']];
|
|
|
|
$document3GetWithDocumentRead = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents/' . $document3['body']['$id'], [
|
|
'origin' => 'http://localhost',
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'cookie' => 'a_session_' . $this->getProject()['$id'] . '=' . $session2,
|
|
]);
|
|
|
|
// other2 has no collection permissions and document permissions are disabled
|
|
$this->assertEquals(404, $document3GetWithDocumentRead['headers']['status-code']);
|
|
|
|
$documentsUser2 = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', [
|
|
'origin' => 'http://localhost',
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'cookie' => 'a_session_' . $this->getProject()['$id'] . '=' . $session2,
|
|
]);
|
|
|
|
// other2 has no collection permissions and document permissions are disabled
|
|
$this->assertEquals(401, $documentsUser2['headers']['status-code']);
|
|
|
|
// Enable document permissions
|
|
$collection = $this->client->call(CLient::METHOD_PUT, '/databases/' . $databaseId . '/collections/' . $collectionId, [
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
], [
|
|
'name' => $collection['body']['name'],
|
|
'documentSecurity' => true,
|
|
]);
|
|
|
|
$documentsUser2 = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $collectionId . '/documents', [
|
|
'origin' => 'http://localhost',
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'cookie' => 'a_session_' . $this->getProject()['$id'] . '=' . $session2,
|
|
]);
|
|
|
|
// Current user has no collection permissions read access to one document
|
|
$this->assertEquals(1, $documentsUser2['body']['total']);
|
|
$this->assertCount(1, $documentsUser2['body']['documents']);
|
|
}
|
|
|
|
/**
|
|
* @depends testDefaultPermissions
|
|
*/
|
|
public function testUniqueIndexDuplicate(array $data): array
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
$uniqueIndex = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/indexes', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'unique_title',
|
|
'type' => 'unique',
|
|
'attributes' => ['title'],
|
|
]);
|
|
|
|
$this->assertEquals(202, $uniqueIndex['headers']['status-code']);
|
|
|
|
sleep(2);
|
|
|
|
// test for failure
|
|
$duplicate = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'title' => 'Captain America',
|
|
'releaseYear' => 1944,
|
|
'actors' => [
|
|
'Chris Evans',
|
|
'Samuel Jackson',
|
|
]
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$this->assertEquals(409, $duplicate['headers']['status-code']);
|
|
|
|
// Test for exception when updating document to conflict
|
|
$document = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'title' => 'Captain America 5',
|
|
'releaseYear' => 1944,
|
|
'actors' => [
|
|
'Chris Evans',
|
|
'Samuel Jackson',
|
|
]
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$this->assertEquals(201, $document['headers']['status-code']);
|
|
|
|
// Test for exception when updating document to conflict
|
|
$duplicate = $this->client->call(Client::METHOD_PATCH, '/databases/' . $databaseId . '/collections/' . $data['moviesId'] . '/documents/' . $document['body']['$id'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'title' => 'Captain America',
|
|
'releaseYear' => 1944,
|
|
'actors' => [
|
|
'Chris Evans',
|
|
'Samuel Jackson',
|
|
]
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$this->assertEquals(409, $duplicate['headers']['status-code']);
|
|
|
|
return $data;
|
|
}
|
|
|
|
/**
|
|
* @depends testUniqueIndexDuplicate
|
|
*/
|
|
public function testPersistantCreatedAt(array $data): array
|
|
{
|
|
$headers = $this->getSide() === 'client' ? array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()) : [
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
];
|
|
|
|
$document = $this->client->call(Client::METHOD_POST, '/databases/' . $data['databaseId'] . '/collections/' . $data['moviesId'] . '/documents', $headers, [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'title' => 'Creation Date Test',
|
|
'releaseYear' => 2000
|
|
]
|
|
]);
|
|
|
|
$this->assertEquals($document['body']['title'], 'Creation Date Test');
|
|
|
|
$documentId = $document['body']['$id'];
|
|
$createdAt = $document['body']['$createdAt'];
|
|
$updatedAt = $document['body']['$updatedAt'];
|
|
|
|
\sleep(1);
|
|
|
|
$document = $this->client->call(Client::METHOD_PATCH, '/databases/' . $data['databaseId'] . '/collections/' . $data['moviesId'] . '/documents/' . $documentId, $headers, [
|
|
'data' => [
|
|
'title' => 'Updated Date Test',
|
|
]
|
|
]);
|
|
|
|
$updatedAtSecond = $document['body']['$updatedAt'];
|
|
|
|
$this->assertEquals($document['body']['title'], 'Updated Date Test');
|
|
$this->assertEquals($document['body']['$createdAt'], $createdAt);
|
|
$this->assertNotEquals($document['body']['$updatedAt'], $updatedAt);
|
|
|
|
\sleep(1);
|
|
|
|
$document = $this->client->call(Client::METHOD_PATCH, '/databases/' . $data['databaseId'] . '/collections/' . $data['moviesId'] . '/documents/' . $documentId, $headers, [
|
|
'data' => [
|
|
'title' => 'Again Updated Date Test',
|
|
'$createdAt' => '2022-08-01 13:09:23.040', // $createdAt is not updatable
|
|
'$updatedAt' => '2022-08-01 13:09:23.050' // system will update it not api
|
|
]
|
|
]);
|
|
|
|
$this->assertEquals($document['body']['title'], 'Again Updated Date Test');
|
|
$this->assertEquals($document['body']['$createdAt'], $createdAt);
|
|
$this->assertNotEquals($document['body']['$createdAt'], '2022-08-01 13:09:23.040');
|
|
$this->assertNotEquals($document['body']['$updatedAt'], $updatedAt);
|
|
$this->assertNotEquals($document['body']['$updatedAt'], $updatedAtSecond);
|
|
$this->assertNotEquals($document['body']['$updatedAt'], '2022-08-01 13:09:23.050');
|
|
|
|
return $data;
|
|
}
|
|
|
|
public function testUpdatePermissionsWithEmptyPayload(): array
|
|
{
|
|
// Create Database
|
|
$database = $this->client->call(Client::METHOD_POST, '/databases', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'databaseId' => ID::unique(),
|
|
'name' => 'Empty Permissions',
|
|
]);
|
|
$this->assertEquals(201, $database['headers']['status-code']);
|
|
|
|
$databaseId = $database['body']['$id'];
|
|
|
|
// Create collection
|
|
$movies = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'collectionId' => ID::unique(),
|
|
'name' => 'Movies',
|
|
'permissions' => [
|
|
Permission::create(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
],
|
|
'documentSecurity' => true,
|
|
]);
|
|
|
|
$this->assertEquals(201, $movies['headers']['status-code']);
|
|
$this->assertEquals($movies['body']['name'], 'Movies');
|
|
|
|
$moviesId = $movies['body']['$id'];
|
|
|
|
// create attribute
|
|
$title = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $moviesId . '/attributes/string', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'title',
|
|
'size' => 256,
|
|
'required' => true,
|
|
]);
|
|
|
|
$this->assertEquals(202, $title['headers']['status-code']);
|
|
|
|
// wait for database worker to create attributes
|
|
sleep(2);
|
|
|
|
// add document
|
|
$document = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $moviesId . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'title' => 'Captain America',
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::any()),
|
|
Permission::update(Role::any()),
|
|
Permission::delete(Role::any()),
|
|
],
|
|
]);
|
|
|
|
$id = $document['body']['$id'];
|
|
|
|
$this->assertEquals(201, $document['headers']['status-code']);
|
|
$this->assertCount(3, $document['body']['$permissions']);
|
|
$this->assertContains(Permission::read(Role::any()), $document['body']['$permissions']);
|
|
$this->assertContains(Permission::update(Role::any()), $document['body']['$permissions']);
|
|
$this->assertContains(Permission::delete(Role::any()), $document['body']['$permissions']);
|
|
|
|
// Send only read permission
|
|
$document = $this->client->call(Client::METHOD_PATCH, '/databases/' . $databaseId . '/collections/' . $moviesId . '/documents/' . $id, array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'permissions' => [
|
|
Permission::read(Role::user(ID::custom($this->getUser()['$id']))),
|
|
]
|
|
]);
|
|
|
|
$this->assertEquals(200, $document['headers']['status-code']);
|
|
$this->assertCount(1, $document['body']['$permissions']);
|
|
|
|
// Send only mutation permissions
|
|
$document = $this->client->call(Client::METHOD_PATCH, '/databases/' . $databaseId . '/collections/' . $moviesId . '/documents/' . $id, array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'permissions' => [
|
|
Permission::update(Role::user(ID::custom($this->getUser()['$id']))),
|
|
Permission::delete(Role::user(ID::custom($this->getUser()['$id']))),
|
|
],
|
|
]);
|
|
|
|
if ($this->getSide() == 'server') {
|
|
$this->assertEquals(200, $document['headers']['status-code']);
|
|
$this->assertCount(2, $document['body']['$permissions']);
|
|
$this->assertContains(Permission::update(Role::user($this->getUser()['$id'])), $document['body']['$permissions']);
|
|
$this->assertContains(Permission::delete(Role::user($this->getUser()['$id'])), $document['body']['$permissions']);
|
|
}
|
|
|
|
// remove collection
|
|
$this->client->call(Client::METHOD_DELETE, '/databases/' . $databaseId . '/collections/' . $moviesId, array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
return [];
|
|
}
|
|
|
|
/**
|
|
* @depends testCreateDatabase
|
|
*/
|
|
public function testAttributeBooleanDefault(array $data): void
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
|
|
/**
|
|
* Test for SUCCESS
|
|
*/
|
|
$collection = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'collectionId' => ID::unique(),
|
|
'name' => 'Boolean'
|
|
]);
|
|
|
|
$this->assertEquals(201, $collection['headers']['status-code']);
|
|
|
|
$collectionId = $collection['body']['$id'];
|
|
|
|
$true = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes/boolean', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'true',
|
|
'required' => false,
|
|
'default' => true
|
|
]);
|
|
|
|
$this->assertEquals(202, $true['headers']['status-code']);
|
|
|
|
$false = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collectionId . '/attributes/boolean', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'false',
|
|
'required' => false,
|
|
'default' => false
|
|
]);
|
|
|
|
$this->assertEquals(202, $false['headers']['status-code']);
|
|
}
|
|
|
|
/**
|
|
* @depends testCreateDatabase
|
|
*/
|
|
public function testOneToOneRelationship(array $data): array
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
|
|
$person = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'collectionId' => 'person',
|
|
'name' => 'person',
|
|
'permissions' => [
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
Permission::update(Role::user($this->getUser()['$id'])),
|
|
Permission::delete(Role::user($this->getUser()['$id'])),
|
|
Permission::create(Role::user($this->getUser()['$id'])),
|
|
],
|
|
'documentSecurity' => true,
|
|
]);
|
|
|
|
$this->assertEquals(201, $person['headers']['status-code']);
|
|
|
|
$library = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'collectionId' => 'library',
|
|
'name' => 'library',
|
|
'permissions' => [
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
Permission::update(Role::user($this->getUser()['$id'])),
|
|
Permission::create(Role::user($this->getUser()['$id'])),
|
|
],
|
|
'documentSecurity' => true,
|
|
]);
|
|
|
|
$this->assertEquals(201, $library['headers']['status-code']);
|
|
|
|
$this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $person['body']['$id'] . '/attributes/string', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'fullName',
|
|
'size' => 255,
|
|
'required' => false,
|
|
]);
|
|
|
|
sleep(1); // Wait for worker
|
|
|
|
$relation = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $person['body']['$id'] . '/attributes/relationship', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'relatedCollectionId' => 'library',
|
|
'type' => Database::RELATION_ONE_TO_ONE,
|
|
'key' => 'library',
|
|
'twoWay' => true,
|
|
'onDelete' => Database::RELATION_MUTATE_CASCADE,
|
|
]);
|
|
|
|
sleep(1); // Wait for worker
|
|
|
|
$libraryName = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $library['body']['$id'] . '/attributes/string', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'libraryName',
|
|
'size' => 255,
|
|
'required' => true,
|
|
]);
|
|
|
|
sleep(1); // Wait for worker
|
|
|
|
$this->assertEquals(202, $libraryName['headers']['status-code']);
|
|
$this->assertEquals(202, $relation['headers']['status-code']);
|
|
$this->assertEquals('library', $relation['body']['key']);
|
|
$this->assertEquals('relationship', $relation['body']['type']);
|
|
$this->assertEquals('processing', $relation['body']['status']);
|
|
|
|
$attributes = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $person['body']['$id'] . '/attributes', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
$this->assertEquals(200, $attributes['headers']['status-code']);
|
|
$this->assertEquals(2, $attributes['body']['total']);
|
|
$attributes = $attributes['body']['attributes'];
|
|
$this->assertEquals('library', $attributes[1]['relatedCollection']);
|
|
$this->assertEquals('oneToOne', $attributes[1]['relationType']);
|
|
$this->assertEquals(true, $attributes[1]['twoWay']);
|
|
$this->assertEquals('person', $attributes[1]['twoWayKey']);
|
|
$this->assertEquals(Database::RELATION_MUTATE_CASCADE, $attributes[1]['onDelete']);
|
|
|
|
$attribute = $this->client->call(Client::METHOD_GET, "/databases/{$databaseId}/collections/{$person['body']['$id']}/attributes/library", array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
$this->assertEquals(200, $attribute['headers']['status-code']);
|
|
$this->assertEquals('available', $attribute['body']['status']);
|
|
$this->assertEquals('library', $attribute['body']['key']);
|
|
$this->assertEquals('relationship', $attribute['body']['type']);
|
|
$this->assertEquals(false, $attribute['body']['required']);
|
|
$this->assertEquals(false, $attribute['body']['array']);
|
|
$this->assertEquals('oneToOne', $attribute['body']['relationType']);
|
|
$this->assertEquals(true, $attribute['body']['twoWay']);
|
|
$this->assertEquals('person', $attribute['body']['twoWayKey']);
|
|
$this->assertEquals(Database::RELATION_MUTATE_CASCADE, $attribute['body']['onDelete']);
|
|
|
|
$person1 = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $person['body']['$id'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'library' => [
|
|
'$id' => 'library1',
|
|
'$permissions' => [
|
|
Permission::read(Role::any()),
|
|
],
|
|
'libraryName' => 'Library 1',
|
|
],
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
Permission::update(Role::user($this->getUser()['$id'])),
|
|
Permission::delete(Role::user($this->getUser()['$id'])),
|
|
]
|
|
]);
|
|
|
|
$this->assertEquals('Library 1', $person1['body']['library']['libraryName']);
|
|
|
|
// Create without nested ID
|
|
$person2 = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $person['body']['$id'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'library' => [
|
|
'libraryName' => 'Library 2',
|
|
],
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
Permission::update(Role::user($this->getUser()['$id'])),
|
|
Permission::delete(Role::user($this->getUser()['$id'])),
|
|
]
|
|
]);
|
|
|
|
$this->assertEquals('Library 2', $person2['body']['library']['libraryName']);
|
|
|
|
// Ensure IDs were set and internal IDs removed
|
|
$this->assertEquals($databaseId, $person1['body']['$databaseId']);
|
|
$this->assertEquals($databaseId, $person1['body']['library']['$databaseId']);
|
|
|
|
$this->assertEquals($person['body']['$id'], $person1['body']['$collectionId']);
|
|
$this->assertEquals($library['body']['$id'], $person1['body']['library']['$collectionId']);
|
|
|
|
$this->assertArrayNotHasKey('$collection', $person1['body']);
|
|
$this->assertArrayNotHasKey('$collection', $person1['body']['library']);
|
|
$this->assertArrayNotHasKey('$internalId', $person1['body']);
|
|
$this->assertArrayNotHasKey('$internalId', $person1['body']['library']);
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $person['body']['$id'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => [
|
|
'equal("library", "library1")',
|
|
'select(["fullName","library.*"])'
|
|
]
|
|
]);
|
|
|
|
$this->assertEquals(1, $documents['body']['total']);
|
|
$this->assertEquals('Library 1', $documents['body']['documents'][0]['library']['libraryName']);
|
|
$this->assertArrayHasKey('fullName', $documents['body']['documents'][0]);
|
|
|
|
$documents = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $person['body']['$id'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => [
|
|
'equal("library.libraryName", ["Library 1"])',
|
|
],
|
|
]);
|
|
|
|
$this->assertEquals(400, $documents['headers']['status-code']);
|
|
$this->assertEquals('Invalid query: Cannot query nested attribute on: library', $documents['body']['message']);
|
|
|
|
$response = $this->client->call(Client::METHOD_DELETE, '/databases/' . $databaseId . '/collections/' . $person['body']['$id'] . '/attributes/library', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
sleep(2);
|
|
|
|
$this->assertEquals(204, $response['headers']['status-code']);
|
|
|
|
$attribute = $this->client->call(Client::METHOD_GET, "/databases/{$databaseId}/collections/{$person['body']['$id']}/attributes/library", array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
$this->assertEquals(404, $attribute['headers']['status-code']);
|
|
|
|
$person1 = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $person['body']['$id'] . '/documents/' . $person1['body']['$id'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
$this->assertArrayNotHasKey('library', $person1['body']);
|
|
|
|
//Test Deletion of related twoKey
|
|
$attributes = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $library['body']['$id'] . '/attributes', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
$this->assertEquals(200, $attributes['headers']['status-code']);
|
|
$this->assertEquals(1, $attributes['body']['total']);
|
|
$this->assertEquals('libraryName', $attributes['body']['attributes'][0]['key']);
|
|
|
|
return [
|
|
'databaseId' => $databaseId,
|
|
'personCollection' => $person['body']['$id'],
|
|
'libraryCollection' => $library['body']['$id'],
|
|
];
|
|
}
|
|
|
|
/**
|
|
* @depends testOneToOneRelationship
|
|
*/
|
|
public function testOneToManyRelationship(array $data): array
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
$personCollection = $data['personCollection'];
|
|
$libraryCollection = $data['libraryCollection'];
|
|
|
|
// One person can own several libraries
|
|
$this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $personCollection . '/attributes/relationship', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'relatedCollectionId' => 'library',
|
|
'type' => Database::RELATION_ONE_TO_MANY,
|
|
'twoWay' => true,
|
|
'key' => 'libraries',
|
|
'twoWayKey' => 'person_one_to_many',
|
|
]);
|
|
|
|
sleep(1);
|
|
|
|
$libraryAttributesResponse = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $libraryCollection . '/attributes', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
$this->assertIsArray($libraryAttributesResponse['body']['attributes']);
|
|
$this->assertEquals(2, $libraryAttributesResponse['body']['total']);
|
|
$this->assertEquals('person_one_to_many', $libraryAttributesResponse['body']['attributes'][1]['key']);
|
|
|
|
$libraryCollectionResponse = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $libraryCollection, array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
$this->assertIsArray($libraryCollectionResponse['body']['attributes']);
|
|
$this->assertCount(2, $libraryCollectionResponse['body']['attributes']);
|
|
|
|
$attribute = $this->client->call(Client::METHOD_GET, "/databases/{$databaseId}/collections/{$personCollection}/attributes/libraries", array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
$this->assertEquals(200, $attribute['headers']['status-code']);
|
|
$this->assertEquals('available', $attribute['body']['status']);
|
|
$this->assertEquals('libraries', $attribute['body']['key']);
|
|
$this->assertEquals('relationship', $attribute['body']['type']);
|
|
$this->assertEquals(false, $attribute['body']['required']);
|
|
$this->assertEquals(false, $attribute['body']['array']);
|
|
$this->assertEquals('oneToMany', $attribute['body']['relationType']);
|
|
$this->assertEquals(true, $attribute['body']['twoWay']);
|
|
$this->assertEquals('person_one_to_many', $attribute['body']['twoWayKey']);
|
|
$this->assertEquals('restrict', $attribute['body']['onDelete']);
|
|
|
|
$person2 = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $personCollection . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => 'person10',
|
|
'data' => [
|
|
'fullName' => 'Stevie Wonder',
|
|
'libraries' => [
|
|
[
|
|
'$id' => 'library10',
|
|
'$permissions' => [
|
|
Permission::read(Role::any()),
|
|
Permission::update(Role::any()),
|
|
Permission::delete(Role::any()),
|
|
],
|
|
'libraryName' => 'Library 10',
|
|
],
|
|
[
|
|
'$id' => 'library11',
|
|
'$permissions' => [
|
|
Permission::read(Role::any()),
|
|
Permission::update(Role::any()),
|
|
Permission::delete(Role::any()),
|
|
],
|
|
'libraryName' => 'Library 11',
|
|
]
|
|
],
|
|
],
|
|
'permissions' => [
|
|
Permission::read(Role::any()),
|
|
Permission::update(Role::any()),
|
|
Permission::delete(Role::any()),
|
|
]
|
|
]);
|
|
|
|
$this->assertEquals(201, $person2['headers']['status-code']);
|
|
$this->assertArrayHasKey('libraries', $person2['body']);
|
|
$this->assertEquals(2, count($person2['body']['libraries']));
|
|
|
|
$response = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $personCollection . '/documents/' . $person2['body']['$id'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
$this->assertEquals(200, $response['headers']['status-code']);
|
|
$this->assertArrayNotHasKey('$collection', $response['body']);
|
|
$this->assertArrayHasKey('libraries', $response['body']);
|
|
$this->assertEquals(2, count($response['body']['libraries']));
|
|
|
|
$response = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $libraryCollection . '/documents/library11', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
$this->assertEquals(200, $response['headers']['status-code']);
|
|
$this->assertArrayHasKey('person_one_to_many', $response['body']);
|
|
$this->assertEquals('person10', $response['body']['person_one_to_many']['$id']);
|
|
|
|
$response = $this->client->call(Client::METHOD_PATCH, '/databases/' . $databaseId . '/collections/' . $personCollection . '/attributes/libraries/relationship', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'onDelete' => Database::RELATION_MUTATE_CASCADE,
|
|
]);
|
|
|
|
$this->assertEquals(200, $response['headers']['status-code']);
|
|
|
|
$attribute = $this->client->call(Client::METHOD_GET, "/databases/{$databaseId}/collections/{$personCollection}/attributes/libraries", array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]));
|
|
|
|
$this->assertEquals(200, $attribute['headers']['status-code']);
|
|
$this->assertEquals('available', $attribute['body']['status']);
|
|
$this->assertEquals('libraries', $attribute['body']['key']);
|
|
$this->assertEquals('relationship', $attribute['body']['type']);
|
|
$this->assertEquals(false, $attribute['body']['required']);
|
|
$this->assertEquals(false, $attribute['body']['array']);
|
|
$this->assertEquals('oneToMany', $attribute['body']['relationType']);
|
|
$this->assertEquals(true, $attribute['body']['twoWay']);
|
|
$this->assertEquals(Database::RELATION_MUTATE_CASCADE, $attribute['body']['onDelete']);
|
|
|
|
return ['databaseId' => $databaseId, 'personCollection' => $personCollection];
|
|
}
|
|
|
|
/**
|
|
* @depends testCreateDatabase
|
|
*/
|
|
public function testManyToOneRelationship(array $data): array
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
|
|
// Create album collection
|
|
$albums = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'collectionId' => ID::unique(),
|
|
'name' => 'Albums',
|
|
'documentSecurity' => true,
|
|
'permissions' => [
|
|
Permission::create(Role::user($this->getUser()['$id'])),
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
],
|
|
]);
|
|
|
|
// Create album name attribute
|
|
$this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $albums['body']['$id'] . '/attributes/string', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'name',
|
|
'size' => 255,
|
|
'required' => true,
|
|
]);
|
|
|
|
// Create artist collection
|
|
$artists = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'collectionId' => ID::unique(),
|
|
'name' => 'Artists',
|
|
'documentSecurity' => true,
|
|
'permissions' => [
|
|
Permission::create(Role::user($this->getUser()['$id'])),
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
],
|
|
]);
|
|
|
|
// Create artist name attribute
|
|
$this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $artists['body']['$id'] . '/attributes/string', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'name',
|
|
'size' => 255,
|
|
'required' => true,
|
|
]);
|
|
|
|
// Create relationship
|
|
$response = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $albums['body']['$id'] . '/attributes/relationship', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'relatedCollectionId' => $artists['body']['$id'],
|
|
'type' => Database::RELATION_MANY_TO_ONE,
|
|
'twoWay' => true,
|
|
'key' => 'artist',
|
|
'twoWayKey' => 'albums',
|
|
]);
|
|
$this->assertEquals(202, $response['headers']['status-code']);
|
|
$this->assertEquals('artist', $response['body']['key']);
|
|
$this->assertEquals('relationship', $response['body']['type']);
|
|
$this->assertEquals(false, $response['body']['required']);
|
|
$this->assertEquals(false, $response['body']['array']);
|
|
$this->assertEquals('manyToOne', $response['body']['relationType']);
|
|
$this->assertEquals(true, $response['body']['twoWay']);
|
|
$this->assertEquals('albums', $response['body']['twoWayKey']);
|
|
$this->assertEquals('restrict', $response['body']['onDelete']);
|
|
|
|
sleep(1); // Wait for worker
|
|
|
|
$permissions = [
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
Permission::update(Role::user($this->getUser()['$id'])),
|
|
Permission::delete(Role::user($this->getUser()['$id'])),
|
|
];
|
|
|
|
// Create album
|
|
$album = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $albums['body']['$id'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => 'album1',
|
|
'permissions' => $permissions,
|
|
'data' => [
|
|
'name' => 'Album 1',
|
|
'artist' => [
|
|
'$id' => ID::unique(),
|
|
'name' => 'Artist 1',
|
|
],
|
|
],
|
|
]);
|
|
|
|
$this->assertEquals(201, $album['headers']['status-code']);
|
|
$this->assertEquals('album1', $album['body']['$id']);
|
|
$this->assertEquals('Album 1', $album['body']['name']);
|
|
$this->assertEquals('Artist 1', $album['body']['artist']['name']);
|
|
$this->assertEquals($permissions, $album['body']['$permissions']);
|
|
$this->assertEquals($permissions, $album['body']['artist']['$permissions']);
|
|
|
|
$album = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $albums['body']['$id'] . '/documents/album1', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
$this->assertEquals(200, $album['headers']['status-code']);
|
|
$this->assertEquals('album1', $album['body']['$id']);
|
|
$this->assertEquals('Album 1', $album['body']['name']);
|
|
$this->assertEquals('Artist 1', $album['body']['artist']['name']);
|
|
$this->assertEquals($permissions, $album['body']['$permissions']);
|
|
$this->assertEquals($permissions, $album['body']['artist']['$permissions']);
|
|
|
|
$artist = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $artists['body']['$id'] . '/documents/' . $album['body']['artist']['$id'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
$this->assertEquals(200, $artist['headers']['status-code']);
|
|
$this->assertEquals('Artist 1', $artist['body']['name']);
|
|
$this->assertEquals($permissions, $artist['body']['$permissions']);
|
|
$this->assertEquals(1, count($artist['body']['albums']));
|
|
$this->assertEquals('album1', $artist['body']['albums'][0]['$id']);
|
|
$this->assertEquals('Album 1', $artist['body']['albums'][0]['name']);
|
|
$this->assertEquals($permissions, $artist['body']['albums'][0]['$permissions']);
|
|
|
|
return [
|
|
'databaseId' => $databaseId,
|
|
'albumsCollection' => $albums['body']['$id'],
|
|
'artistsCollection' => $artists['body']['$id'],
|
|
];
|
|
}
|
|
|
|
/**
|
|
* @depends testCreateDatabase
|
|
*/
|
|
public function testManyToManyRelationship(array $data): array
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
|
|
// Create sports collection
|
|
$sports = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'collectionId' => ID::unique(),
|
|
'name' => 'Sports',
|
|
'documentSecurity' => true,
|
|
'permissions' => [
|
|
Permission::create(Role::user($this->getUser()['$id'])),
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
],
|
|
]);
|
|
|
|
// Create sport name attribute
|
|
$this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $sports['body']['$id'] . '/attributes/string', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'name',
|
|
'size' => 255,
|
|
'required' => true,
|
|
]);
|
|
|
|
// Create player collection
|
|
$players = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'collectionId' => ID::unique(),
|
|
'name' => 'Players',
|
|
'documentSecurity' => true,
|
|
'permissions' => [
|
|
Permission::create(Role::user($this->getUser()['$id'])),
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
],
|
|
]);
|
|
|
|
// Create player name attribute
|
|
$this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $players['body']['$id'] . '/attributes/string', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'name',
|
|
'size' => 255,
|
|
'required' => true,
|
|
]);
|
|
|
|
// Create relationship
|
|
$response = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $sports['body']['$id'] . '/attributes/relationship', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'relatedCollectionId' => $players['body']['$id'],
|
|
'type' => Database::RELATION_MANY_TO_MANY,
|
|
'twoWay' => true,
|
|
'key' => 'players',
|
|
'twoWayKey' => 'sports',
|
|
'onDelete' => Database::RELATION_MUTATE_SET_NULL,
|
|
]);
|
|
|
|
$this->assertEquals(202, $response['headers']['status-code']);
|
|
$this->assertEquals('players', $response['body']['key']);
|
|
$this->assertEquals('relationship', $response['body']['type']);
|
|
$this->assertEquals(false, $response['body']['required']);
|
|
$this->assertEquals(false, $response['body']['array']);
|
|
$this->assertEquals('manyToMany', $response['body']['relationType']);
|
|
$this->assertEquals(true, $response['body']['twoWay']);
|
|
$this->assertEquals('sports', $response['body']['twoWayKey']);
|
|
$this->assertEquals('setNull', $response['body']['onDelete']);
|
|
|
|
sleep(1); // Wait for worker
|
|
|
|
$permissions = [
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
Permission::update(Role::user($this->getUser()['$id'])),
|
|
];
|
|
|
|
// Create sport
|
|
$sport = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $sports['body']['$id'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'documentId' => 'sport1',
|
|
'permissions' => $permissions,
|
|
'data' => [
|
|
'name' => 'Sport 1',
|
|
'players' => [
|
|
[
|
|
'$id' => 'player1',
|
|
'name' => 'Player 1',
|
|
],
|
|
[
|
|
'$id' => 'player2',
|
|
'name' => 'Player 2',
|
|
]
|
|
],
|
|
],
|
|
]);
|
|
|
|
$this->assertEquals(201, $sport['headers']['status-code']);
|
|
$this->assertEquals('sport1', $sport['body']['$id']);
|
|
$this->assertEquals('Sport 1', $sport['body']['name']);
|
|
$this->assertEquals('Player 1', $sport['body']['players'][0]['name']);
|
|
$this->assertEquals('Player 2', $sport['body']['players'][1]['name']);
|
|
$this->assertEquals($permissions, $sport['body']['$permissions']);
|
|
$this->assertEquals($permissions, $sport['body']['players'][0]['$permissions']);
|
|
$this->assertEquals($permissions, $sport['body']['players'][1]['$permissions']);
|
|
|
|
$sport = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $sports['body']['$id'] . '/documents/sport1', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
$this->assertEquals(200, $sport['headers']['status-code']);
|
|
$this->assertEquals('sport1', $sport['body']['$id']);
|
|
$this->assertEquals('Sport 1', $sport['body']['name']);
|
|
$this->assertEquals('Player 1', $sport['body']['players'][0]['name']);
|
|
$this->assertEquals('Player 2', $sport['body']['players'][1]['name']);
|
|
$this->assertEquals($permissions, $sport['body']['$permissions']);
|
|
$this->assertEquals($permissions, $sport['body']['players'][0]['$permissions']);
|
|
$this->assertEquals($permissions, $sport['body']['players'][1]['$permissions']);
|
|
|
|
$player = $this->client->call(Client::METHOD_GET, '/databases/' . $databaseId . '/collections/' . $players['body']['$id'] . '/documents/' . $sport['body']['players'][0]['$id'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()));
|
|
|
|
$this->assertEquals(200, $player['headers']['status-code']);
|
|
$this->assertEquals('Player 1', $player['body']['name']);
|
|
$this->assertEquals($permissions, $player['body']['$permissions']);
|
|
$this->assertEquals(1, count($player['body']['sports']));
|
|
$this->assertEquals('sport1', $player['body']['sports'][0]['$id']);
|
|
$this->assertEquals('Sport 1', $player['body']['sports'][0]['name']);
|
|
$this->assertEquals($permissions, $player['body']['sports'][0]['$permissions']);
|
|
|
|
return [
|
|
'databaseId' => $databaseId,
|
|
'sportsCollection' => $sports['body']['$id'],
|
|
'playersCollection' => $players['body']['$id'],
|
|
];
|
|
}
|
|
|
|
/**
|
|
* @depends testOneToManyRelationship
|
|
*/
|
|
public function testValidateOperators(array $data): void
|
|
{
|
|
$response = $this->client->call(Client::METHOD_GET, '/databases/' . $data['databaseId'] . '/collections/' . $data['personCollection'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => [
|
|
'isNotNull("$id")',
|
|
'startsWith("fullName", "Stevie")',
|
|
'endsWith("fullName", "Wonder")',
|
|
'between("$createdAt", "1975-12-06", "2050-12-06")',
|
|
],
|
|
]);
|
|
|
|
$this->assertEquals(200, $response['headers']['status-code']);
|
|
$this->assertEquals(1, count($response['body']['documents']));
|
|
$this->assertEquals('person10', $response['body']['documents'][0]['$id']);
|
|
$this->assertEquals('Stevie Wonder', $response['body']['documents'][0]['fullName']);
|
|
$this->assertEquals(2, count($response['body']['documents'][0]['libraries']));
|
|
|
|
$response = $this->client->call(Client::METHOD_GET, '/databases/' . $data['databaseId'] . '/collections/' . $data['personCollection'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => [
|
|
'isNotNull("$id")',
|
|
'isNull("fullName")',
|
|
'select(["fullName"])'
|
|
],
|
|
]);
|
|
|
|
$this->assertEquals(200, $response['headers']['status-code']);
|
|
$this->assertEquals(2, count($response['body']['documents']));
|
|
$this->assertEquals(null, $response['body']['documents'][0]['fullName']);
|
|
$this->assertArrayNotHasKey("libraries", $response['body']['documents'][0]);
|
|
}
|
|
|
|
/**
|
|
* @depends testOneToManyRelationship
|
|
*/
|
|
public function testSelectsQueries(array $data): void
|
|
{
|
|
$response = $this->client->call(Client::METHOD_GET, '/databases/' . $data['databaseId'] . '/collections/' . $data['personCollection'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => [
|
|
'equal("fullName", "Stevie Wonder")',
|
|
'select(["fullName"])'
|
|
],
|
|
]);
|
|
|
|
$this->assertEquals(200, $response['headers']['status-code']);
|
|
$this->assertArrayNotHasKey('libraries', $response['body']['documents'][0]);
|
|
|
|
$response = $this->client->call(Client::METHOD_GET, '/databases/' . $data['databaseId'] . '/collections/' . $data['personCollection'] . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => [
|
|
'select(["libraries.*", "$id"])',
|
|
],
|
|
]);
|
|
$document = $response['body']['documents'][0];
|
|
$this->assertEquals(200, $response['headers']['status-code']);
|
|
$this->assertArrayHasKey('libraries', $document);
|
|
|
|
$response = $this->client->call(Client::METHOD_GET, '/databases/' . $data['databaseId'] . '/collections/' . $data['personCollection'] . '/documents/' . $document['$id'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
], $this->getHeaders()), [
|
|
'queries' => [
|
|
'select(["fullName", "$id"])'
|
|
],
|
|
]);
|
|
|
|
$this->assertEquals(200, $response['headers']['status-code']);
|
|
$this->assertArrayHasKey('fullName', $response['body']);
|
|
$this->assertArrayNotHasKey('libraries', $response['body']);
|
|
}
|
|
|
|
/**
|
|
* @depends testCreateDatabase
|
|
* @param array $data
|
|
* @return void
|
|
* @throws \Exception
|
|
*/
|
|
public function testUpdateWithExistingRelationships(array $data): void
|
|
{
|
|
$databaseId = $data['databaseId'];
|
|
|
|
$collection1 = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'collectionId' => ID::unique(),
|
|
'name' => 'Collection1',
|
|
'documentSecurity' => true,
|
|
'permissions' => [
|
|
Permission::create(Role::user($this->getUser()['$id'])),
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
],
|
|
]);
|
|
|
|
$collection2 = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'collectionId' => ID::unique(),
|
|
'name' => 'Collection2',
|
|
'documentSecurity' => true,
|
|
'permissions' => [
|
|
Permission::create(Role::user($this->getUser()['$id'])),
|
|
Permission::read(Role::user($this->getUser()['$id'])),
|
|
],
|
|
]);
|
|
|
|
$collection1 = $collection1['body']['$id'];
|
|
$collection2 = $collection2['body']['$id'];
|
|
|
|
$this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collection1 . '/attributes/string', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'name',
|
|
'size' => '49',
|
|
'required' => true,
|
|
]);
|
|
|
|
$this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collection2 . '/attributes/string', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'key' => 'name',
|
|
'size' => '49',
|
|
'required' => true,
|
|
]);
|
|
|
|
$this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collection1 . '/attributes/relationship', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id'],
|
|
'x-appwrite-key' => $this->getProject()['apiKey']
|
|
]), [
|
|
'relatedCollectionId' => $collection2,
|
|
'type' => Database::RELATION_ONE_TO_MANY,
|
|
'twoWay' => true,
|
|
'key' => 'collection2'
|
|
]);
|
|
|
|
sleep(1);
|
|
|
|
$document = $this->client->call(Client::METHOD_POST, '/databases/' . $databaseId . '/collections/' . $collection1 . '/documents', array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id']
|
|
], $this->getHeaders()), [
|
|
'documentId' => ID::unique(),
|
|
'data' => [
|
|
'name' => 'Document 1',
|
|
'collection2' => [
|
|
[
|
|
'name' => 'Document 2',
|
|
],
|
|
],
|
|
],
|
|
]);
|
|
|
|
$update = $this->client->call(Client::METHOD_PATCH, '/databases/' . $databaseId . '/collections/' . $collection1 . '/documents/' . $document['body']['$id'], array_merge([
|
|
'content-type' => 'application/json',
|
|
'x-appwrite-project' => $this->getProject()['$id']
|
|
], $this->getHeaders()), [
|
|
'data' => [
|
|
'name' => 'Document 1 Updated',
|
|
],
|
|
]);
|
|
|
|
$this->assertEquals(200, $update['headers']['status-code']);
|
|
}
|
|
}
|