route(new Request(new Http('http://test.com')))); } public function testGetSet() : void { $router = new Router(); self::assertFalse($router->importFromFile(__Dir__ . '/invalidFile.php')); self::assertTrue($router->importFromFile(__Dir__ . '/routerTestFile.php')); self::assertEquals( [['dest' => '\Modules\Admin\Controller:viewSettingsGeneral']], $router->route(new Request(new Http('http://test.com/backend/admin/settings/general/something?test'))) ); self::assertNotEquals( [['dest' => '\Modules\Admin\Controller:viewSettingsGeneral']], $router->route(new Request(new Http('http://test.com/backend/admin/settings/general/something?test')), RouteVerb::PUT) ); self::assertNotEquals( [['dest' => '\Modules\Admin\Controller:viewSettingsGeneral']], $router->route(new Request(new Http('http://test.com/backends/admin/settings/general/something?test'))) ); $router->add('^.*/backends/admin/settings/general.*$', 'Controller:test', RouteVerb::GET | RouteVerb::SET); self::assertEquals( [['dest' => 'Controller:test']], $router->route(new Request(new Http('http://test.com/backends/admin/settings/general/something?test')), RouteVerb::ANY) ); self::assertEquals( [['dest' => 'Controller:test']], $router->route(new Request(new Http('http://test.com/backends/admin/settings/general/something?test')), RouteVerb::SET) ); self::assertEquals( [['dest' => 'Controller:test']], $router->route(new Request(new Http('http://test.com/backends/admin/settings/general/something?test')), RouteVerb::GET) ); } public function testWithPermissions() : void { $router = new Router(); self::assertTrue($router->importFromFile(__Dir__ . '/routerTestFilePermission.php')); $perm = new class( null, null, BackendController::MODULE_NAME, 0, PermissionState::SETTINGS, null, null, PermissionType::READ ) extends PermissionAbstract {}; $account = new Account(); $account->addPermission($perm); self::assertEquals( [['dest' => '\Modules\Admin\Controller:viewSettingsGeneral']], $router->route( new Request(new Http('http://test.com/backend/admin/settings/general/something?test')), RouteVerb::GET, null, null, $account ) ); $perm2 = new class( null, null, BackendController::MODULE_NAME, 0, PermissionState::SETTINGS, null, null, PermissionType::CREATE ) extends PermissionAbstract {}; $perm3 = new class( null, null, 'InvalidModule', 0, PermissionState::SETTINGS, null, null, PermissionType::READ ) extends PermissionAbstract {}; $perm4 = new class( null, null, BackendController::MODULE_NAME, 0, 99, null, null, PermissionType::READ ) extends PermissionAbstract {}; $account2 = new Account(); $account2->addPermission($perm2); $account2->addPermission($perm3); $account2->addPermission($perm4); self::assertNotEquals( [['dest' => '\Modules\Admin\Controller:viewSettingsGeneral']], $router->route( new Request(new Http('http://test.com/backend/admin/settings/general/something?test')), RouteVerb::GET, null, null, $account2 ) ); } }