app = new class() extends ApplicationAbstract { protected string $appName = 'Api'; protected int $appId = 1; }; $this->app->dbPool = $GLOBALS['dbpool']; $this->app->unitId = 1; $this->app->accountManager = new AccountManager($GLOBALS['session']); $this->app->appSettings = new CoreSettings(); $this->app->moduleManager = new ModuleManager($this->app, __DIR__ . '/../../../../Modules/'); $this->app->dispatcher = new Dispatcher($this->app); $this->app->eventManager = new EventManager($this->app->dispatcher); $this->app->eventManager->importFromFile(__DIR__ . '/../../../../Web/Api/Hooks.php'); $this->app->sessionManager = new HttpSession(36000); $this->app->l11nManager = new L11nManager(); $account = new Account(); TestUtils::setMember($account, 'id', 1); $permission = new AccountPermission(); $permission->unit = 1; $permission->app = 1; $permission->setPermission( PermissionType::READ | PermissionType::CREATE | PermissionType::MODIFY | PermissionType::DELETE | PermissionType::PERMISSION ); $account->addPermission($permission); $this->app->accountManager->add($account); $this->app->router = new WebRouter(); $this->module = $this->app->moduleManager->get('HumanResourceTimeRecording'); TestUtils::setMember($this->module, 'app', $this->app); } #[\PHPUnit\Framework\Attributes\Group('module')] public function testApiSessionCR() : void { if (($profile = ProfileMapper::get()->where('account', 1)->limit(1)->execute())->id === 0) { $profile = new Profile(); $profile->account = AccountMapper::get()->where('id', 1)->execute(); $profile->birthday = new \DateTime('now'); ProfileMapper::create()->execute($profile); } if ((EmployeeMapper::get()->with('profile')->where('profile/account', 1)->limit(1)->execute())->id === 0) { $employee = new Employee($profile); EmployeeMapper::create()->execute($employee); } $response = new HttpResponse(); $request = new HttpRequest(); $request->header->account = 1; $this->module->apiSessionCreate($request, $response); self::assertGreaterThan(0, $sId = $response->getDataArray('')['response']->id); $response = new HttpResponse(); $request = new HttpRequest(); $request->header->account = 1; $request->setData('session', (string) $sId); $request->setData('status', ClockingStatus::END); $this->module->apiSessionElementCreate($request, $response); self::assertGreaterThan(0, $response->getDataArray('')['response']->id); } #[\PHPUnit\Framework\Attributes\Group('module')] public function testApiSessionCreateInvalidPermission() : void { $response = new HttpResponse(); $request = new HttpRequest(); $request->header->account = 9999; $request->setData('account', 2); $this->module->apiSessionCreate($request, $response); self::assertEquals(RequestStatusCode::R_403, $response->header->status); } #[\PHPUnit\Framework\Attributes\Group('module')] public function testApiSessionCreateInvalidDataEmployee() : void { $response = new HttpResponse(); $request = new HttpRequest(); $request->header->account = 1; $request->setData('account', 9999); $this->module->apiSessionCreate($request, $response); self::assertEquals(RequestStatusCode::R_400, $response->header->status); } #[\PHPUnit\Framework\Attributes\Group('module')] public function testApiSessionElementCreateInvalidSessionId() : void { $response = new HttpResponse(); $request = new HttpRequest(); $request->header->account = 1; $request->setData('session', 99999); $request->setData('status', ClockingStatus::CONTINUE); $this->module->apiSessionElementCreate($request, $response); self::assertEquals(RequestStatusCode::R_400, $response->header->status); } #[\PHPUnit\Framework\Attributes\Group('module')] public function testApiSessionElementCreateInvalidPermission() : void { $response = new HttpResponse(); $request = new HttpRequest(); $request->header->account = 9999; $request->setData('session', 1); $request->setData('account', 1); $this->module->apiSessionElementCreate($request, $response); self::assertEquals(RequestStatusCode::R_403, $response->header->status); } }