|
25 | 25 |
|
26 | 26 | import java.nio.file.Files; |
27 | 27 | import java.nio.file.Path; |
| 28 | +import java.util.Date; |
28 | 29 | import java.util.List; |
29 | 30 | import java.util.Map; |
30 | 31 | import java.util.function.Consumer; |
@@ -79,6 +80,40 @@ public void testGetContentType() { |
79 | 80 | assertEquals("application/entity-statement+jwt", generator.getContentType()); |
80 | 81 | } |
81 | 82 |
|
| 83 | + @Test |
| 84 | + public void testShouldNotInitializeAgainWhenAlreadyInitializedAndNotExpired() throws Exception { |
| 85 | + val jwksFile = tmp.resolve("not-expired.jwks"); |
| 86 | + federation.getJwks().setJwksResource(new FileSystemResource(jwksFile.toFile())); |
| 87 | + val generator = newGenerator(); |
| 88 | + |
| 89 | + val firstEntityStatement = generator.generateEntityStatement(); |
| 90 | + assertEquals(1, generator.getNbAttempts()); |
| 91 | + |
| 92 | + generator.setExpirationDate(new Date(System.currentTimeMillis() + 60_000L)); |
| 93 | + assertFalse(generator.shouldInitialize(false)); |
| 94 | + |
| 95 | + val secondEntityStatement = generator.generateEntityStatement(); |
| 96 | + assertEquals(firstEntityStatement, secondEntityStatement); |
| 97 | + assertEquals(1, generator.getNbAttempts()); |
| 98 | + } |
| 99 | + |
| 100 | + @Test |
| 101 | + public void testShouldInitializeAgainWhenAlreadyInitializedAndExpired() throws Exception { |
| 102 | + val jwksFile = tmp.resolve("expired.jwks"); |
| 103 | + federation.getJwks().setJwksResource(new FileSystemResource(jwksFile.toFile())); |
| 104 | + val generator = newGenerator(); |
| 105 | + |
| 106 | + val firstEntityStatement = generator.generateEntityStatement(); |
| 107 | + assertEquals(1, generator.getNbAttempts()); |
| 108 | + |
| 109 | + generator.setExpirationDate(new Date(System.currentTimeMillis() - 1_000L)); |
| 110 | + assertTrue(generator.shouldInitialize(false)); |
| 111 | + |
| 112 | + val secondEntityStatement = generator.generateEntityStatement(); |
| 113 | + assertNotEquals(firstEntityStatement, secondEntityStatement); |
| 114 | + assertEquals(2, generator.getNbAttempts()); |
| 115 | + } |
| 116 | + |
82 | 117 | @Test |
83 | 118 | public void testGenerateEntityStatementWithoutJwksAndWithoutKeystore() { |
84 | 119 | federation.setJwks(null); |
|
0 commit comments