appwrite/tests/e2e/Services/GraphQL/DatabaseServerTest.php

1468 lines
51 KiB
PHP
Raw Normal View History

2022-06-30 12:00:00 +00:00
<?php
namespace Tests\E2E\Services\GraphQL;
use Exception;
use Tests\E2E\Client;
use Tests\E2E\Scopes\ProjectCustom;
use Tests\E2E\Scopes\Scope;
use Tests\E2E\Scopes\SideServer;
2023-03-24 05:08:50 +00:00
use Utopia\Database\Database;
2023-01-16 09:25:40 +00:00
use Utopia\Database\Helpers\ID;
use Utopia\Database\Helpers\Permission;
use Utopia\Database\Helpers\Role;
2022-06-30 12:00:00 +00:00
2022-09-22 08:29:42 +00:00
class DatabaseServerTest extends Scope
2022-06-30 12:00:00 +00:00
{
use ProjectCustom;
use SideServer;
2022-09-22 08:29:42 +00:00
use Base;
2022-06-30 12:00:00 +00:00
2022-07-06 05:12:12 +00:00
public function testCreateDatabase(): array
{
$projectId = $this->getProject()['$id'];
$query = $this->getQuery(self::$CREATE_DATABASE);
$gqlPayload = [
'query' => $query,
'variables' => [
'databaseId' => 'actors',
'name' => 'Actors',
]
];
$database = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertIsArray($database['body']['data']);
$this->assertArrayNotHasKey('errors', $database['body']);
$database = $database['body']['data']['databasesCreate'];
$this->assertEquals('Actors', $database['name']);
return $database;
}
/**
* @depends testCreateDatabase
*/
public function testCreateCollection($database): array
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$CREATE_TABLE);
2022-07-06 05:12:12 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $database['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => 'actors',
2022-07-06 05:12:12 +00:00
'name' => 'Actors',
2022-09-21 08:17:17 +00:00
'documentSecurity' => false,
'permissions' => [
Permission::read(Role::any()),
Permission::create(Role::users()),
Permission::update(Role::users()),
Permission::delete(Role::users()),
],
2022-07-06 05:12:12 +00:00
]
];
$collection = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertIsArray($collection['body']['data']);
$this->assertArrayNotHasKey('errors', $collection['body']);
2025-04-27 08:38:26 +00:00
$collection = $collection['body']['data']['databasesCreateTable'];
2022-07-06 05:12:12 +00:00
$this->assertEquals('Actors', $collection['name']);
2023-03-24 05:08:50 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
'databaseId' => $database['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => 'movies',
2023-03-24 05:08:50 +00:00
'name' => 'Movies',
'documentSecurity' => false,
'permissions' => [
Permission::read(Role::any()),
Permission::create(Role::users()),
Permission::update(Role::users()),
Permission::delete(Role::users()),
],
]
];
2025-04-27 08:38:26 +00:00
$table2 = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
2023-03-24 05:08:50 +00:00
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($table2['body']['data']);
$this->assertArrayNotHasKey('errors', $table2['body']);
$table2 = $table2['body']['data']['databasesCreateTable'];
$this->assertEquals('Movies', $table2['name']);
2023-03-24 05:08:50 +00:00
2022-07-06 05:12:12 +00:00
return [
'database' => $database,
2025-04-27 08:38:26 +00:00
'table' => $collection,
'table2' => $table2,
2022-07-06 05:12:12 +00:00
];
}
/**
* @depends testCreateCollection
* @throws Exception
*/
public function testCreateStringAttribute($data): array
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$CREATE_STRING_COLUMN);
2022-07-06 05:12:12 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2022-07-06 05:12:12 +00:00
'key' => 'name',
'size' => 256,
'required' => true,
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $attribute['body']);
$this->assertIsArray($attribute['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attribute['body']['data']['databasesCreateStringColumn']);
2022-07-06 05:12:12 +00:00
return $data;
}
2023-03-10 13:06:46 +00:00
/**
* @depends testCreateStringAttribute
* @throws Exception
*/
public function testUpdateStringAttribute($data): array
{
// Wait for attributes to be available
2023-03-31 08:29:02 +00:00
sleep(1);
2023-03-10 13:06:46 +00:00
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$UPDATE_STRING_COLUMN);
2023-03-10 13:06:46 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2023-03-10 13:06:46 +00:00
'key' => 'name',
'required' => false,
'default' => 'Default Value',
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertIsArray($attribute['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attribute['body']['data']['databasesUpdateStringColumn']);
$this->assertFalse($attribute['body']['data']['databasesUpdateStringColumn']['required']);
$this->assertEquals('Default Value', $attribute['body']['data']['databasesUpdateStringColumn']['default']);
2023-03-10 13:06:46 +00:00
$this->assertEquals(200, $attribute['headers']['status-code']);
return $data;
}
2022-07-06 05:12:12 +00:00
/**
* @depends testCreateCollection
* @throws Exception
*/
public function testCreateIntegerAttribute($data): array
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$CREATE_INTEGER_COLUMN);
2022-07-06 05:12:12 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2022-07-06 05:12:12 +00:00
'key' => 'age',
'min' => 18,
'max' => 150,
'required' => true,
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $attribute['body']);
$this->assertIsArray($attribute['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attribute['body']['data']['databasesCreateIntegerColumn']);
2022-07-06 05:12:12 +00:00
return $data;
}
2023-03-10 13:06:46 +00:00
/**
* @depends testCreateIntegerAttribute
* @throws Exception
*/
public function testUpdateIntegerAttribute($data): array
{
// Wait for attributes to be available
2023-03-31 08:29:02 +00:00
sleep(1);
2023-03-10 13:06:46 +00:00
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$UPDATE_INTEGER_COLUMN);
2023-03-10 13:06:46 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2023-03-10 13:06:46 +00:00
'key' => 'age',
'required' => false,
'min' => 12,
'max' => 160,
'default' => 50
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertIsArray($attribute['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attribute['body']['data']['databasesUpdateIntegerColumn']);
$this->assertFalse($attribute['body']['data']['databasesUpdateIntegerColumn']['required']);
$this->assertEquals(12, $attribute['body']['data']['databasesUpdateIntegerColumn']['min']);
$this->assertEquals(160, $attribute['body']['data']['databasesUpdateIntegerColumn']['max']);
$this->assertEquals(50, $attribute['body']['data']['databasesUpdateIntegerColumn']['default']);
2023-03-10 13:06:46 +00:00
$this->assertEquals(200, $attribute['headers']['status-code']);
return $data;
}
2022-07-06 05:12:12 +00:00
/**
* @depends testCreateCollection
* @throws Exception
*/
public function testCreateBooleanAttribute($data): array
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$CREATE_BOOLEAN_COLUMN);
2022-07-06 05:12:12 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2022-07-06 05:12:12 +00:00
'key' => 'alive',
'required' => true,
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $attribute['body']);
$this->assertIsArray($attribute['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attribute['body']['data']['databasesCreateBooleanColumn']);
2022-07-06 05:12:12 +00:00
return $data;
}
2023-03-10 13:06:46 +00:00
/**
* @depends testCreateBooleanAttribute
* @throws Exception
*/
public function testUpdateBooleanAttribute($data): array
{
// Wait for attributes to be available
2023-03-31 08:29:02 +00:00
sleep(1);
2023-03-10 13:06:46 +00:00
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$UPDATE_BOOLEAN_COLUMN);
2023-03-10 13:06:46 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2023-03-10 13:06:46 +00:00
'key' => 'alive',
'required' => false,
'default' => true
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertIsArray($attribute['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attribute['body']['data']['databasesUpdateBooleanColumn']);
$this->assertFalse($attribute['body']['data']['databasesUpdateBooleanColumn']['required']);
$this->assertTrue($attribute['body']['data']['databasesUpdateBooleanColumn']['default']);
2023-03-10 13:06:46 +00:00
$this->assertEquals(200, $attribute['headers']['status-code']);
return $data;
}
2022-07-06 05:12:12 +00:00
/**
* @depends testCreateCollection
* @throws Exception
*/
public function testCreateFloatAttribute($data): array
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$CREATE_FLOAT_COLUMN);
2022-07-06 05:12:12 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2022-07-06 05:12:12 +00:00
'key' => 'salary',
'min' => 1000.0,
'max' => 999999.99,
'default' => 1000.0,
'required' => false,
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $attribute['body']);
$this->assertIsArray($attribute['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attribute['body']['data']['databasesCreateFloatColumn']);
2022-07-06 05:12:12 +00:00
return $data;
}
2023-03-10 13:06:46 +00:00
/**
* @depends testCreateFloatAttribute
* @throws Exception
*/
public function testUpdateFloatAttribute($data): array
{
// Wait for attributes to be available
2023-03-31 08:29:02 +00:00
sleep(1);
2023-03-10 13:06:46 +00:00
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$UPDATE_FLOAT_COLUMN);
2023-03-10 13:06:46 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2023-03-10 13:06:46 +00:00
'key' => 'salary',
'required' => false,
'min' => 100.0,
'max' => 1000000.0,
'default' => 2500.0
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertIsArray($attribute['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attribute['body']['data']['databasesUpdateFloatColumn']);
$this->assertFalse($attribute['body']['data']['databasesUpdateFloatColumn']['required']);
$this->assertEquals(100.0, $attribute['body']['data']['databasesUpdateFloatColumn']['min']);
$this->assertEquals(1000000.0, $attribute['body']['data']['databasesUpdateFloatColumn']['max']);
$this->assertEquals(2500.0, $attribute['body']['data']['databasesUpdateFloatColumn']['default']);
2023-03-10 13:06:46 +00:00
$this->assertEquals(200, $attribute['headers']['status-code']);
return $data;
}
2022-07-06 05:12:12 +00:00
/**
* @depends testCreateCollection
* @throws Exception
*/
public function testCreateEmailAttribute($data): array
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$CREATE_EMAIL_COLUMN);
2022-07-06 05:12:12 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2022-07-06 05:12:12 +00:00
'key' => 'email',
'required' => true,
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $attribute['body']);
$this->assertIsArray($attribute['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attribute['body']['data']['databasesCreateEmailColumn']);
2022-07-06 05:12:12 +00:00
return $data;
}
2023-03-10 13:06:46 +00:00
/**
* @depends testCreateEmailAttribute
* @throws Exception
*/
public function testUpdateEmailAttribute($data): array
{
// Wait for attributes to be available
2023-03-31 08:29:02 +00:00
sleep(1);
2023-03-10 13:06:46 +00:00
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$UPDATE_EMAIL_COLUMN);
2023-03-10 13:06:46 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2023-03-10 13:06:46 +00:00
'key' => 'email',
'required' => false,
'default' => 'torsten@appwrite.io',
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertIsArray($attribute['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attribute['body']['data']['databasesUpdateEmailColumn']);
$this->assertFalse($attribute['body']['data']['databasesUpdateEmailColumn']['required']);
$this->assertEquals('torsten@appwrite.io', $attribute['body']['data']['databasesUpdateEmailColumn']['default']);
2023-03-10 13:06:46 +00:00
$this->assertEquals(200, $attribute['headers']['status-code']);
return $data;
}
2022-07-06 05:12:12 +00:00
/**
* @depends testCreateCollection
* @throws Exception
*/
public function testCreateEnumAttribute($data): array
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$CREATE_ENUM_COLUMN);
2022-07-06 05:12:12 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2022-07-06 05:12:12 +00:00
'key' => 'role',
'elements' => [
'crew',
'actor',
'guest',
],
'required' => true,
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $attribute['body']);
$this->assertIsArray($attribute['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attribute['body']['data']['databasesCreateEnumColumn']);
2022-07-06 05:12:12 +00:00
return $data;
}
2023-03-10 13:06:46 +00:00
/**
* @depends testCreateEnumAttribute
* @throws Exception
*/
public function testUpdateEnumAttribute($data): array
{
// Wait for attributes to be available
2023-03-31 08:29:02 +00:00
sleep(1);
2023-03-10 13:06:46 +00:00
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$UPDATE_ENUM_COLUMN);
2023-03-10 13:06:46 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2023-03-10 13:06:46 +00:00
'key' => 'role',
'required' => false,
'elements' => [
'crew',
'tech',
'actor'
],
'default' => 'tech'
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertIsArray($attribute['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attribute['body']['data']['databasesUpdateEnumColumn']);
$this->assertFalse($attribute['body']['data']['databasesUpdateEnumColumn']['required']);
$this->assertEquals('tech', $attribute['body']['data']['databasesUpdateEnumColumn']['default']);
$this->assertContains('tech', $attribute['body']['data']['databasesUpdateEnumColumn']['elements']);
$this->assertNotContains('guest', $attribute['body']['data']['databasesUpdateEnumColumn']['elements']);
2023-03-10 13:06:46 +00:00
$this->assertEquals(200, $attribute['headers']['status-code']);
return $data;
}
2022-09-21 09:08:20 +00:00
/**
* @depends testCreateCollection
* @throws Exception
*/
public function testCreateDatetimeAttribute($data): array
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$CREATE_DATETIME_COLUMN);
2022-09-21 09:08:20 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2022-09-21 09:08:20 +00:00
'key' => 'dob',
'required' => true,
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $attribute['body']);
$this->assertIsArray($attribute['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attribute['body']['data']['databasesCreateDatetimeColumn']);
2022-09-21 09:08:20 +00:00
return $data;
}
2023-03-10 13:06:46 +00:00
/**
* @depends testCreateDatetimeAttribute
* @throws Exception
*/
public function testUpdateDatetimeAttribute($data): array
{
// Wait for attributes to be available
2023-03-31 08:29:02 +00:00
sleep(1);
2023-03-10 13:06:46 +00:00
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$UPDATE_DATETIME_COLUMN);
2023-03-10 13:06:46 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2023-03-10 13:06:46 +00:00
'key' => 'dob',
'required' => false,
'default' => '2000-01-01T00:00:00Z'
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertIsArray($attribute['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attribute['body']['data']['databasesUpdateDatetimeColumn']);
$this->assertFalse($attribute['body']['data']['databasesUpdateDatetimeColumn']['required']);
$this->assertEquals('2000-01-01T00:00:00Z', $attribute['body']['data']['databasesUpdateDatetimeColumn']['default']);
2023-03-10 13:06:46 +00:00
$this->assertEquals(200, $attribute['headers']['status-code']);
return $data;
}
2023-03-24 05:08:50 +00:00
/**
* @depends testCreateCollection
*/
public function testCreateRelationshipAttribute(array $data): array
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$CREATE_RELATIONSHIP_COLUMN);
2023-03-24 05:08:50 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table2']['_id'], // Movies
'relatedTableId' => $data['table']['_id'], // Actors
2023-03-24 05:08:50 +00:00
'type' => Database::RELATION_ONE_TO_MANY,
'twoWay' => true,
'key' => 'actors',
'twoWayKey' => 'movie'
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
2025-04-27 08:38:26 +00:00
2023-03-24 05:08:50 +00:00
$this->assertArrayNotHasKey('errors', $attribute['body']);
$this->assertIsArray($attribute['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attribute['body']['data']['databasesCreateRelationshipColumn']);
2023-03-24 05:08:50 +00:00
return $data;
}
/**
* @depends testCreateRelationshipAttribute
*/
public function testUpdateRelationshipAttribute(array $data): array
{
2023-03-31 08:29:02 +00:00
sleep(1);
2023-03-24 05:08:50 +00:00
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$UPDATE_RELATIONSHIP_COLUMN);
2023-03-24 05:08:50 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table2']['_id'],
2023-03-24 05:08:50 +00:00
'key' => 'actors',
2023-03-31 08:29:02 +00:00
'onDelete' => Database::RELATION_MUTATE_CASCADE,
2023-03-24 05:08:50 +00:00
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $attribute['body']);
$this->assertIsArray($attribute['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attribute['body']['data']['databasesUpdateRelationshipColumn']);
2023-03-24 05:08:50 +00:00
return $data;
}
2022-07-06 05:12:12 +00:00
/**
* @depends testCreateCollection
* @throws Exception
*/
public function testCreateIPAttribute($data): array
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$CREATE_IP_COLUMN);
2022-07-06 05:12:12 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2022-07-06 05:12:12 +00:00
'key' => 'ip',
'required' => false,
'default' => '::1',
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $attribute['body']);
$this->assertIsArray($attribute['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attribute['body']['data']['databasesCreateIpColumn']);
2022-07-06 05:12:12 +00:00
return $data;
}
2023-03-10 13:06:46 +00:00
/**
* @depends testCreateIPAttribute
* @throws Exception
*/
public function testUpdateIPAttribute($data): array
{
// Wait for attributes to be available
sleep(3);
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$UPDATE_IP_COLUMN);
2023-03-10 13:06:46 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2023-03-10 13:06:46 +00:00
'key' => 'ip',
'required' => false,
'default' => '127.0.0.1'
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertIsArray($attribute['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attribute['body']['data']['databasesUpdateIpColumn']);
$this->assertFalse($attribute['body']['data']['databasesUpdateIpColumn']['required']);
$this->assertEquals('127.0.0.1', $attribute['body']['data']['databasesUpdateIpColumn']['default']);
2023-03-10 13:06:46 +00:00
$this->assertEquals(200, $attribute['headers']['status-code']);
return $data;
}
2022-07-06 05:12:12 +00:00
/**
* @depends testCreateCollection
* @throws Exception
*/
public function testCreateURLAttribute($data): array
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$CREATE_URL_COLUMN);
2022-07-06 05:12:12 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2022-07-06 05:12:12 +00:00
'key' => 'url',
'required' => false,
'default' => 'https://appwrite.io',
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $attribute['body']);
$this->assertIsArray($attribute['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attribute['body']['data']['databasesCreateUrlColumn']);
2022-07-06 05:12:12 +00:00
return $data;
}
/**
2023-03-10 13:06:46 +00:00
* @depends testCreateURLAttribute
2022-07-06 05:12:12 +00:00
* @throws Exception
*/
2023-03-10 13:06:46 +00:00
public function testUpdateURLAttribute($data): void
2022-07-06 05:12:12 +00:00
{
// Wait for attributes to be available
2022-09-23 03:53:25 +00:00
sleep(3);
2022-07-06 05:12:12 +00:00
2023-03-10 13:06:46 +00:00
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$UPDATE_URL_COLUMN);
2023-03-10 13:06:46 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2023-03-10 13:06:46 +00:00
'key' => 'url',
'required' => false,
'default' => 'https://cloud.appwrite.io'
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertIsArray($attribute['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attribute['body']['data']['databasesUpdateUrlColumn']);
$this->assertFalse($attribute['body']['data']['databasesUpdateUrlColumn']['required']);
$this->assertEquals('https://cloud.appwrite.io', $attribute['body']['data']['databasesUpdateUrlColumn']['default']);
2023-03-10 13:06:46 +00:00
$this->assertEquals(200, $attribute['headers']['status-code']);
}
/**
* @depends testUpdateStringAttribute
* @depends testUpdateIntegerAttribute
* @throws Exception
*/
public function testCreateIndex($data): array
{
2022-07-06 05:12:12 +00:00
$projectId = $this->getProject()['$id'];
$query = $this->getQuery(self::$CREATE_INDEX);
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2022-07-06 05:12:12 +00:00
'key' => 'index',
'type' => 'key',
2025-04-27 08:38:26 +00:00
'columns' => [
2022-07-06 05:12:12 +00:00
'name',
'age',
],
]
];
$index = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $index['body']);
$this->assertIsArray($index['body']['data']);
$this->assertIsArray($index['body']['data']['databasesCreateIndex']);
return [
'database' => $data['database'],
2025-04-27 08:38:26 +00:00
'table' => $data['table'],
2022-07-06 05:12:12 +00:00
'index' => $index['body']['data']['databasesCreateIndex'],
];
}
/**
2023-03-10 13:06:46 +00:00
* @depends testUpdateStringAttribute
* @depends testUpdateIntegerAttribute
* @depends testUpdateBooleanAttribute
* @depends testUpdateEnumAttribute
2022-07-06 05:12:12 +00:00
* @throws Exception
*/
public function testCreateDocument($data): array
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$CREATE_ROW);
2022-07-06 05:12:12 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
'rowId' => ID::unique(),
2022-07-06 05:12:12 +00:00
'data' => [
'name' => 'John Doe',
'email' => 'example@appwrite.io',
'age' => 30,
'alive' => true,
'salary' => 9999.9,
'role' => 'crew',
2022-09-21 09:08:20 +00:00
'dob' => '2000-01-01T00:00:00Z',
2022-07-06 05:12:12 +00:00
],
2022-09-21 08:17:17 +00:00
'permissions' => [
Permission::read(Role::any()),
Permission::update(Role::any()),
Permission::delete(Role::any()),
],
2022-07-06 05:12:12 +00:00
]
];
2025-04-27 08:38:26 +00:00
$row = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
2022-07-06 05:12:12 +00:00
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
2025-04-27 08:38:26 +00:00
$this->assertArrayNotHasKey('errors', $row['body']);
$this->assertIsArray($row['body']['data']);
2022-07-06 05:12:12 +00:00
2025-04-27 08:38:26 +00:00
$row = $row['body']['data']['databasesCreateRow'];
$this->assertIsArray($row);
2022-07-06 05:12:12 +00:00
return [
'database' => $data['database'],
2025-04-27 08:38:26 +00:00
'table' => $data['table'],
'row' => $row,
2022-07-06 05:12:12 +00:00
];
}
2023-03-10 13:06:46 +00:00
// /**
// * @depends testCreateStringAttribute
// * @depends testCreateIntegerAttribute
// * @depends testCreateBooleanAttribute
// * @depends testCreateFloatAttribute
// * @depends testCreateEmailAttribute
// * @depends testCreateEnumAttribute
// * @depends testCreateDatetimeAttribute
// * @throws Exception
// */
// public function testCreateCustomEntity(): array
// {
// $projectId = $this->getProject()['$id'];
// $query = $this->getQuery(self::$CREATE_CUSTOM_ENTITY);
// $gqlPayload = [
// 'query' => $query,
// 'variables' => [
// 'name' => 'John Doe',
// 'age' => 35,
// 'alive' => true,
// 'salary' => 9999.9,
// 'email' => 'johndoe@appwrite.io',
// 'role' => 'crew',
// 'dob' => '2000-01-01T00:00:00Z',
// ]
// ];
//
// $actor = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
// 'content-type' => 'application/json',
// 'x-appwrite-project' => $projectId,
// ], $this->getHeaders()), $gqlPayload);
//
// $this->assertArrayNotHasKey('errors', $actor['body']);
// $this->assertIsArray($actor['body']['data']);
// $actor = $actor['body']['data']['actorsCreate'];
// $this->assertIsArray($actor);
//
// return $actor;
// }
2022-07-06 05:12:12 +00:00
public function testGetDatabases(): void
{
$projectId = $this->getProject()['$id'];
$query = $this->getQuery(self::$GET_DATABASES);
$gqlPayload = [
'query' => $query,
];
$databases = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $databases['body']);
$this->assertIsArray($databases['body']['data']);
$this->assertIsArray($databases['body']['data']['databasesList']);
}
/**
* @depends testCreateDatabase
* @throws Exception
*/
public function testGetDatabase($database): void
{
$projectId = $this->getProject()['$id'];
$query = $this->getQuery(self::$GET_DATABASE);
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $database['_id'],
2022-07-06 05:12:12 +00:00
]
];
$database = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $database['body']);
$this->assertIsArray($database['body']['data']);
$this->assertIsArray($database['body']['data']['databasesGet']);
}
/**
* @depends testCreateCollection
* @throws Exception
*/
public function testGetCollections($data): void
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$GET_TABLES);
2022-07-06 05:12:12 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2022-07-06 05:12:12 +00:00
]
];
$collections = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $collections['body']);
$this->assertIsArray($collections['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($collections['body']['data']['databasesListTables']);
2022-07-06 05:12:12 +00:00
}
/**
* @depends testCreateCollection
* @throws Exception
*/
public function testGetCollection($data): void
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$GET_TABLE);
2022-07-06 05:12:12 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2022-07-06 05:12:12 +00:00
]
];
$collection = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $collection['body']);
$this->assertIsArray($collection['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($collection['body']['data']['databasesGetTable']);
2022-07-06 05:12:12 +00:00
}
/**
2023-03-10 13:06:46 +00:00
* @depends testUpdateStringAttribute
* @depends testUpdateIntegerAttribute
2022-07-06 05:12:12 +00:00
* @throws Exception
*/
public function testGetAttributes($data): void
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$GET_COLUMNS);
2022-07-06 05:12:12 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2022-07-06 05:12:12 +00:00
]
];
$attributes = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $attributes['body']);
$this->assertIsArray($attributes['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attributes['body']['data']['databasesListColumns']);
2022-07-06 05:12:12 +00:00
}
/**
* @depends testCreateCollection
* @throws Exception
*/
public function testGetAttribute($data): void
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$GET_COLUMN);
2022-07-06 05:12:12 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2022-07-06 05:12:12 +00:00
'key' => 'name',
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $attribute['body']);
$this->assertIsArray($attribute['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($attribute['body']['data']['databasesGetColumn']);
2022-07-06 05:12:12 +00:00
}
/**
* @depends testCreateIndex
* @throws Exception
*/
public function testGetIndexes($data): void
{
$projectId = $this->getProject()['$id'];
$query = $this->getQuery(self::$GET_INDEXES);
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2022-07-06 05:12:12 +00:00
]
];
$indices = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $indices['body']);
$this->assertIsArray($indices['body']['data']);
$this->assertIsArray($indices['body']['data']['databasesListIndexes']);
}
/**
* @depends testCreateIndex
* @throws Exception
*/
public function testGetIndex($data): void
{
$projectId = $this->getProject()['$id'];
$query = $this->getQuery(self::$GET_INDEX);
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2022-07-06 05:12:12 +00:00
'key' => $data['index']['key'],
]
];
$index = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $index['body']);
$this->assertIsArray($index['body']['data']);
$this->assertIsArray($index['body']['data']['databasesGetIndex']);
}
/**
* @depends testCreateCollection
* @throws Exception
*/
public function testGetDocuments($data): void
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$GET_ROWS);
2022-07-06 05:12:12 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2022-07-06 05:12:12 +00:00
]
];
$documents = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $documents['body']);
$this->assertIsArray($documents['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($documents['body']['data']['databasesListRows']);
2022-07-06 05:12:12 +00:00
}
/**
* @depends testCreateDocument
* @throws Exception
*/
public function testGetDocument($data): void
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$GET_ROW);
2022-07-06 05:12:12 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
'rowId' => $data['row']['_id'],
2022-07-06 05:12:12 +00:00
]
];
$document = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $document['body']);
$this->assertIsArray($document['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($document['body']['data']['databasesGetRow']);
2022-07-06 05:12:12 +00:00
}
2023-03-10 13:06:46 +00:00
// /**
// * @depends testCreateCustomEntity
// * @throws Exception
// */
// public function testGetCustomEntities($data)
// {
// $projectId = $this->getProject()['$id'];
// $query = $this->getQuery(self::$GET_CUSTOM_ENTITIES);
// $gqlPayload = [
// 'query' => $query,
// ];
//
// $customEntities = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
// 'content-type' => 'application/json',
// 'x-appwrite-project' => $projectId,
// ], $this->getHeaders()), $gqlPayload);
//
// $this->assertArrayNotHasKey('errors', $customEntities['body']);
// $this->assertIsArray($customEntities['body']['data']);
// $this->assertIsArray($customEntities['body']['data']['actorsList']);
// }
//
// /**
// * @depends testCreateCustomEntity
// * @throws Exception
// */
// public function testGetCustomEntity($data)
// {
// $projectId = $this->getProject()['$id'];
// $query = $this->getQuery(self::$GET_CUSTOM_ENTITY);
// $gqlPayload = [
// 'query' => $query,
// 'variables' => [
// 'id' => $data['id'],
// ]
// ];
//
// $entity = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
// 'content-type' => 'application/json',
// 'x-appwrite-project' => $projectId,
// ], $this->getHeaders()), $gqlPayload);
//
// $this->assertArrayNotHasKey('errors', $entity['body']);
// $this->assertIsArray($entity['body']['data']);
// $this->assertIsArray($entity['body']['data']['actorsGet']);
// }
2022-07-06 05:12:12 +00:00
/**
* @depends testCreateDatabase
* @throws Exception
*/
public function testUpdateDatabase($database)
{
$projectId = $this->getProject()['$id'];
$query = $this->getQuery(self::$UPDATE_DATABASE);
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $database['_id'],
2022-07-06 05:12:12 +00:00
'name' => 'New Database Name',
]
];
$database = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $database['body']);
$this->assertIsArray($database['body']['data']);
$this->assertIsArray($database['body']['data']['databasesUpdate']);
}
/**
* @depends testCreateCollection
* @throws Exception
*/
public function testUpdateCollection($data)
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$UPDATE_TABLE);
2022-07-06 05:12:12 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2022-07-06 05:12:12 +00:00
'name' => 'New Collection Name',
2022-09-21 08:17:17 +00:00
'documentSecurity' => false,
2022-07-06 05:12:12 +00:00
]
];
$collection = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $collection['body']);
$this->assertIsArray($collection['body']['data']);
2025-04-27 08:38:26 +00:00
$this->assertIsArray($collection['body']['data']['databasesUpdateTable']);
2022-07-06 05:12:12 +00:00
}
/**
* @depends testCreateDocument
* @throws Exception
*/
public function testUpdateDocument($data): void
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$UPDATE_ROW);
2022-07-06 05:12:12 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
'rowId' => $data['row']['_id'],
2022-07-06 05:12:12 +00:00
'data' => [
'name' => 'New Document Name',
],
]
];
$document = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
$this->assertArrayNotHasKey('errors', $document['body']);
$this->assertIsArray($document['body']['data']);
2025-04-27 08:38:26 +00:00
$document = $document['body']['data']['databasesUpdateRow'];
2022-07-06 05:12:12 +00:00
$this->assertIsArray($document);
$this->assertStringContainsString('New Document Name', $document['data']);
}
2023-03-10 13:06:46 +00:00
// /**
// * @depends testCreateCustomEntity
// * @throws Exception
// */
// public function testUpdateCustomEntity(array $data)
// {
// $projectId = $this->getProject()['$id'];
// $query = $this->getQuery(self::$UPDATE_CUSTOM_ENTITY);
// $gqlPayload = [
// 'query' => $query,
// 'variables' => [
// 'id' => $data['id'],
// 'name' => 'New Custom Entity Name',
// ]
// ];
//
// $entity = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
// 'content-type' => 'application/json',
// 'x-appwrite-project' => $projectId,
// ], $this->getHeaders()), $gqlPayload);
//
// $this->assertArrayNotHasKey('errors', $entity['body']);
// $this->assertIsArray($entity['body']['data']);
// $entity = $entity['body']['data']['actorsUpdate'];
// $this->assertIsArray($entity);
// $this->assertStringContainsString('New Custom Entity Name', $entity['name']);
// }
2022-09-22 08:29:42 +00:00
2022-07-07 00:53:58 +00:00
/**
* @depends testCreateDocument
* @throws Exception
*/
public function testDeleteDocument($data): void
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$DELETE_ROW);
2022-07-07 00:53:58 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
'rowId' => $data['row']['_id'],
2022-07-07 00:53:58 +00:00
]
];
$document = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
2022-07-18 09:38:13 +00:00
$this->assertIsNotArray($document['body']);
2022-07-13 07:38:44 +00:00
$this->assertEquals(204, $document['headers']['status-code']);
2022-07-07 00:53:58 +00:00
}
2023-03-10 13:06:46 +00:00
// /**
// * @depends testCreateCustomEntity
// * @throws Exception
// */
// public function testDeleteCustomEntity(array $data)
// {
// $projectId = $this->getProject()['$id'];
// $query = $this->getQuery(self::$DELETE_CUSTOM_ENTITY);
// $gqlPayload = [
// 'query' => $query,
// 'variables' => [
// 'id' => $data['id'],
// ]
// ];
//
// $entity = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
// 'content-type' => 'application/json',
// 'x-appwrite-project' => $projectId,
// ], $this->getHeaders()), $gqlPayload);
//
// $this->assertIsNotArray($entity['body']);
// $this->assertEquals(204, $entity['headers']['status-code']);
// }
2022-09-23 01:46:39 +00:00
2022-07-07 00:53:58 +00:00
/**
2023-03-10 13:06:46 +00:00
* @depends testUpdateStringAttribute
2022-07-07 00:53:58 +00:00
* @throws Exception
*/
public function testDeleteAttribute($data): void
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$DELETE_COLUMN);
2022-07-07 00:53:58 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2022-07-07 00:53:58 +00:00
'key' => 'name',
]
];
$attribute = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
2022-07-18 09:38:13 +00:00
$this->assertIsNotArray($attribute['body']);
2022-07-07 00:53:58 +00:00
$this->assertEquals(204, $attribute['headers']['status-code']);
}
/**
* @depends testCreateCollection
* @throws Exception
*/
public function testDeleteCollection($data)
{
$projectId = $this->getProject()['$id'];
2025-04-27 08:38:26 +00:00
$query = $this->getQuery(self::$DELETE_TABLE);
2022-07-07 00:53:58 +00:00
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $data['database']['_id'],
2025-04-27 08:38:26 +00:00
'tableId' => $data['table']['_id'],
2022-07-07 00:53:58 +00:00
]
];
$collection = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
2022-07-18 09:38:13 +00:00
$this->assertIsNotArray($collection['body']);
2022-07-07 00:53:58 +00:00
$this->assertEquals(204, $collection['headers']['status-code']);
}
/**
* @depends testCreateDatabase
* @throws Exception
*/
public function testDeleteDatabase($database)
{
$projectId = $this->getProject()['$id'];
$query = $this->getQuery(self::$DELETE_DATABASE);
$gqlPayload = [
'query' => $query,
'variables' => [
2022-12-08 03:08:57 +00:00
'databaseId' => $database['_id'],
2022-07-07 00:53:58 +00:00
]
];
$database = $this->client->call(Client::METHOD_POST, '/graphql', array_merge([
'content-type' => 'application/json',
'x-appwrite-project' => $projectId,
], $this->getHeaders()), $gqlPayload);
2022-07-18 09:38:13 +00:00
$this->assertIsNotArray($database['body']);
2022-07-07 00:53:58 +00:00
$this->assertEquals(204, $database['headers']['status-code']);
}
2022-07-01 06:58:03 +00:00
}