/* * SonarQube * Copyright (C) 2009-2025 SonarSource SA * mailto:info AT sonarsource DOT com * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 3 of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program; if not, write to the Free Software Foundation, * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ package org.sonar.db.user; import java.time.ZoneId; import java.time.ZonedDateTime; import org.junit.jupiter.api.Test; import static org.apache.commons.lang3.RandomStringUtils.secure; import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThatThrownBy; class UserTokenDtoTest { @Test void fail_if_token_hash_is_longer_than_255_characters() { assertThatThrownBy(() -> new UserTokenDto().setTokenHash(secure().nextAlphabetic(256))) .isInstanceOf(IllegalStateException.class) .hasMessage("Token hash length (256) is longer than the maximum authorized (255)"); } @Test void token_isExpired_is_properly_calculated() { UserTokenDto tokenWithNoExpirationDate = new UserTokenDto(); UserTokenDto expiredToken = new UserTokenDto().setExpirationDate(0L); UserTokenDto nonExpiredToken = new UserTokenDto().setExpirationDate(ZonedDateTime.now(ZoneId.systemDefault()).plusDays(10).toInstant().toEpochMilli()); assertThat(tokenWithNoExpirationDate.isExpired()).isFalse(); assertThat(expiredToken.isExpired()).isTrue(); assertThat(nonExpiredToken.isExpired()).isFalse(); } }