requestMockClass = $class; $this->buildRequestMock(); } /** * Configure the user model that the request mock should return with. */ public function setRequestUserModel(User $user = null): void { $this->request->shouldReceive('user')->andReturn($user); } /** * Generates a new request user model and also returns the generated model. */ public function generateRequestUserModel(array $args = []): User { /** @var \Pterodactyl\Models\User $user */ $user = User::factory()->make($args); $this->setRequestUserModel($user); return $user; } /** * Set a request attribute on the mock object. */ public function setRequestAttribute(string $attribute, mixed $value): void { $this->request->attributes->set($attribute, $value); } /** * Set the request route name. */ public function setRequestRouteName(string $name): void { $this->request->shouldReceive('route->getName')->andReturn($name); } /** * Set the active request object to be an instance of a mocked request. */ protected function buildRequestMock(): void { $this->request = m::mock($this->requestMockClass); if (!$this->request instanceof Request) { throw new InvalidArgumentException('Request mock class must be an instance of ' . Request::class . ' when mocked.'); } $this->request->attributes = new ParameterBag(); } /** * Sets the mocked request user. If a user model is not provided, a factory model * will be created and returned. * * @deprecated */ protected function setRequestUser(User $user = null): User { $user = $user instanceof User ? $user : User::factory()->make(); $this->request->shouldReceive('user')->withNoArgs()->andReturn($user); return $user; } }