1
0
Fork 0
mirror of synced 2024-07-05 22:51:24 +12:00
appwrite/tests/unit/Event/EventTest.php

178 lines
7.7 KiB
PHP
Raw Permalink Normal View History

2019-12-26 23:00:29 +13:00
<?php
2022-08-01 22:22:04 +12:00
namespace Tests\Unit\Event;
2019-12-26 23:00:29 +13:00
use Appwrite\Event\Event;
2023-10-11 07:02:24 +13:00
use Appwrite\URL\URL;
2022-03-29 21:30:57 +13:00
use InvalidArgumentException;
2019-12-26 23:00:29 +13:00
use PHPUnit\Framework\TestCase;
2023-10-11 07:02:24 +13:00
use Utopia\DSN\DSN;
use Utopia\Queue;
use Utopia\Queue\Client;
2024-04-02 00:02:47 +13:00
use Utopia\System\System;
2023-10-11 07:02:24 +13:00
require_once __DIR__ . '/../../../app/init.php';
2019-12-26 23:00:29 +13:00
2019-12-26 23:20:09 +13:00
class EventTest extends TestCase
2019-12-26 23:00:29 +13:00
{
2022-08-01 22:22:04 +12:00
protected ?Event $object = null;
protected string $queue = '';
2019-12-26 23:00:29 +13:00
2020-10-01 10:52:28 +13:00
public function setUp(): void
2019-12-26 23:00:29 +13:00
{
2024-04-18 04:12:43 +12:00
$fallbackForRedis = 'redis_main=' . URL::unparse([
2023-10-11 07:02:24 +13:00
'scheme' => 'redis',
2024-04-02 00:02:47 +13:00
'host' => System::getEnv('_APP_REDIS_HOST', 'redis'),
'port' => System::getEnv('_APP_REDIS_PORT', '6379'),
'user' => System::getEnv('_APP_REDIS_USER', ''),
'pass' => System::getEnv('_APP_REDIS_PASS', ''),
2023-10-11 07:02:24 +13:00
]);
2024-04-02 00:02:47 +13:00
$dsn = System::getEnv('_APP_CONNECTIONS_QUEUE', $fallbackForRedis);
2023-10-11 07:02:24 +13:00
$dsn = explode('=', $dsn);
2024-04-18 03:47:55 +12:00
$dsn = $dsn[1] ?? '';
2023-10-11 07:02:24 +13:00
$dsn = new DSN($dsn);
$connection = new Queue\Connection\Redis($dsn->getHost(), $dsn->getPort());
2019-12-26 23:00:29 +13:00
$this->queue = 'v1-tests' . uniqid();
2023-10-11 07:02:24 +13:00
$this->object = new Event($connection);
$this->object->setClass('TestsV1');
$this->object->setQueue($this->queue);
2019-12-26 23:00:29 +13:00
}
2022-08-01 22:22:04 +12:00
public function testQueue(): void
{
$this->assertEquals($this->queue, $this->object->getQueue());
$this->object->setQueue('demo');
$this->assertEquals('demo', $this->object->getQueue());
$this->object->setQueue($this->queue);
}
2022-08-01 22:22:04 +12:00
public function testClass(): void
{
$this->assertEquals('TestsV1', $this->object->getClass());
$this->object->setClass('TestsV2');
$this->assertEquals('TestsV2', $this->object->getClass());
$this->object->setClass('TestsV1');
}
2022-08-01 22:22:04 +12:00
public function testParams(): void
2019-12-26 23:00:29 +13:00
{
2023-10-11 07:02:24 +13:00
2019-12-26 23:00:29 +13:00
$this->object
2020-10-30 11:20:32 +13:00
->setParam('eventKey1', 'eventValue1')
2022-03-29 21:30:57 +13:00
->setParam('eventKey2', 'eventValue2');
2019-12-26 23:00:29 +13:00
$this->object->trigger();
2022-04-19 04:21:45 +12:00
$this->assertEquals('eventValue1', $this->object->getParam('eventKey1'));
$this->assertEquals('eventValue2', $this->object->getParam('eventKey2'));
2020-10-30 11:20:32 +13:00
$this->assertEquals(null, $this->object->getParam('eventKey3'));
2023-10-11 07:02:24 +13:00
global $register;
$pools = $register->get('pools');
$client = new Client($this->object->getQueue(), $pools->get('queue')->pop()->getResource());
$this->assertEquals($client->getQueueSize(), 1);
2023-05-15 12:30:31 +12:00
}
2022-08-01 22:22:04 +12:00
public function testReset(): void
2020-07-05 01:06:23 +12:00
{
$this->object
2020-10-30 11:20:32 +13:00
->setParam('eventKey1', 'eventValue1')
2022-03-29 21:30:57 +13:00
->setParam('eventKey2', 'eventValue2');
2020-07-05 01:06:23 +12:00
2020-10-30 11:20:32 +13:00
$this->assertEquals('eventValue1', $this->object->getParam('eventKey1'));
$this->assertEquals('eventValue2', $this->object->getParam('eventKey2'));
2020-07-05 01:06:23 +12:00
$this->object->reset();
2020-10-30 11:20:32 +13:00
$this->assertEquals(null, $this->object->getParam('eventKey1'));
$this->assertEquals(null, $this->object->getParam('eventKey2'));
$this->assertEquals(null, $this->object->getParam('eventKey3'));
2020-07-05 01:06:23 +12:00
}
2022-03-29 21:30:57 +13:00
2022-08-01 22:22:04 +12:00
public function testGenerateEvents(): void
2022-03-29 21:30:57 +13:00
{
2022-04-04 18:30:07 +12:00
$event = Event::generateEvents('users.[userId].create', [
'userId' => 'torsten'
]);
$this->assertCount(4, $event);
$this->assertContains('users.torsten.create', $event);
$this->assertContains('users.torsten', $event);
$this->assertContains('users.*.create', $event);
$this->assertContains('users.*', $event);
2022-03-29 21:30:57 +13:00
$event = Event::generateEvents('users.[userId].update.email', [
'userId' => 'torsten'
]);
$this->assertCount(6, $event);
$this->assertContains('users.torsten.update.email', $event);
$this->assertContains('users.torsten.update', $event);
$this->assertContains('users.torsten', $event);
$this->assertContains('users.*.update.email', $event);
$this->assertContains('users.*.update', $event);
$this->assertContains('users.*', $event);
$event = Event::generateEvents('collections.[collectionId].documents.[documentId].create', [
'collectionId' => 'chapters',
'documentId' => 'prolog',
]);
2022-04-19 04:21:45 +12:00
$this->assertCount(10, $event);
2022-03-29 21:30:57 +13:00
$this->assertContains('collections.chapters.documents.prolog.create', $event);
$this->assertContains('collections.chapters.documents.prolog', $event);
$this->assertContains('collections.chapters.documents.*.create', $event);
$this->assertContains('collections.chapters.documents.*', $event);
2022-04-19 04:21:45 +12:00
$this->assertContains('collections.chapters', $event);
2022-03-29 21:30:57 +13:00
$this->assertContains('collections.*.documents.prolog.create', $event);
$this->assertContains('collections.*.documents.prolog', $event);
$this->assertContains('collections.*.documents.*.create', $event);
$this->assertContains('collections.*.documents.*', $event);
2022-04-19 04:21:45 +12:00
$this->assertContains('collections.*', $event);
2022-03-29 21:30:57 +13:00
Database layer (#3338) * database response model * database collection config * new database scopes * database service update * database execption codes * remove read write permission from database model * updating tests and fixing some bugs * server side tests are now passing * databases api * tests for database endpoint * composer update * fix error * formatting * formatting fixes * get database test * more updates to events and usage * more usage updates * fix delete type * fix test * delete database * more fixes * databaseId in attributes and indexes * more fixes * fix issues * fix index subquery * fix console scope and index query * updating tests as required * fix phpcs errors and warnings * updates to review suggestions * UI progress * ui updates and cleaning up * fix type * rework database events * update tests * update types * event generation fixed * events config updated * updating context to support multiple * realtime updates * fix ids * update context * validator updates * fix naming conflict * fix tests * fix lint errors * fix wprler and realtime tests * fix webhooks test * fix event validator and other tests * formatting fixes * removing leftover var_dumps * remove leftover comment * update usage params * usage metrics updates * update database usage * fix usage * specs update * updates to usage * fix UI and usage * fix lints * internal id fixes * fixes for internal Id * renaming services and related files * rename tests * rename doc link * rename readme * fix test name * tests: fixes for 0.15.x sync Co-authored-by: Torsten Dittmann <torsten.dittmann@googlemail.com>
2022-06-22 22:51:49 +12:00
$event = Event::generateEvents('databases.[databaseId].collections.[collectionId].documents.[documentId].create', [
'databaseId' => 'chaptersDB',
'collectionId' => 'chapters',
'documentId' => 'prolog',
]);
$this->assertCount(22, $event);
$this->assertContains('databases.chaptersDB.collections.chapters.documents.prolog.create', $event);
$this->assertContains('databases.chaptersDB.collections.chapters.documents.prolog', $event);
$this->assertContains('databases.chaptersDB.collections.chapters.documents.*.create', $event);
$this->assertContains('databases.chaptersDB.collections.chapters.documents.*', $event);
$this->assertContains('databases.chaptersDB.collections.chapters', $event);
$this->assertContains('databases.chaptersDB.collections.*.documents.prolog.create', $event);
$this->assertContains('databases.chaptersDB.collections.*.documents.prolog', $event);
$this->assertContains('databases.chaptersDB.collections.*', $event);
$this->assertContains('databases.chaptersDB', $event);
$this->assertContains('databases.*.collections.chapters.documents.prolog.create', $event);
$this->assertContains('databases.*.collections.chapters.documents.prolog', $event);
$this->assertContains('databases.*.collections.chapters', $event);
$this->assertContains('databases.*.collections.*.documents.*.create', $event);
$this->assertContains('databases.*.collections.*.documents.*', $event);
$this->assertContains('databases.*.collections.*', $event);
$this->assertContains('databases.*', $event);
$this->assertContains('databases.*.collections.*.documents.prolog', $event);
$this->assertContains('databases.*.collections.*.documents.prolog.create', $event);
$this->assertContains('databases.*.collections.chapters.documents.*', $event);
$this->assertContains('databases.*.collections.chapters.documents.*.create', $event);
$this->assertContains('databases.chaptersDB.collections.*.documents.*', $event);
$this->assertContains('databases.chaptersDB.collections.*.documents.*.create', $event);
2022-03-29 21:30:57 +13:00
try {
$event = Event::generateEvents('collections.[collectionId].documents.[documentId].create', [
'collectionId' => 'chapters'
]);
$this->fail();
} catch (\Throwable $th) {
$this->assertInstanceOf(InvalidArgumentException::class, $th, 'An invalid exception was thrown');
}
try {
$event = Event::generateEvents('collections.[collectionId].documents.[documentId].create');
$this->fail();
} catch (\Throwable $th) {
$this->assertInstanceOf(InvalidArgumentException::class, $th, 'An invalid exception was thrown');
}
}
2020-10-01 10:52:28 +13:00
}