function it_does_not_get_the_user_because_the_remember_password_token_is_expired(UserRepository $repository, UserOfRememberPasswordTokenQuery $query, User $user)
 {
     $query->rememberPasswordToken()->shouldBeCalled()->willReturn('remember-password-token');
     $token = new UserToken('remember-password-token');
     $repository->userOfRememberPasswordToken($token)->shouldBeCalled()->willReturn($user);
     $user->isRememberPasswordTokenExpired()->shouldBeCalled()->willReturn(true);
     $this->shouldThrow(UserTokenExpiredException::class)->during__invoke($query);
 }
 /**
  * Handles the given query.
  *
  * @param UserOfRememberPasswordTokenQuery $aQuery The query
  *
  * @throws UserDoesNotExistException when the user does not exist
  * @throws UserTokenExpiredException when the token is expired
  *
  * @return mixed
  */
 public function __invoke(UserOfRememberPasswordTokenQuery $aQuery)
 {
     $user = $this->repository->userOfRememberPasswordToken(new UserToken($aQuery->rememberPasswordToken()));
     if (null === $user) {
         throw new UserDoesNotExistException();
     }
     if ($user->isRememberPasswordTokenExpired()) {
         throw new UserTokenExpiredException();
     }
     $this->dataTransformer->write($user);
     return $this->dataTransformer->read();
 }