Ich habe den folgenden Code eingerichtet, um einen Test auf getExpire()
durchzuführen (jedis 2.5.2, spring-data-redis 1.4.2.RELEASE):
@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(classes = DemoApplication.class)
public class DemoApplicationTests {
@Autowired
private RedisTemplate<String, String> template;
@Test
public void contextLoads() {
template.getConnectionFactory().getConnection().flushAll();
assertFalse(template.hasKey("key"));
assertFalse(template.expire("key", 10, TimeUnit.MINUTES));
assertEquals(0, template.getExpire("key", TimeUnit.MINUTES).longValue());
template.opsForHash().put("key", "hashkey", "hashvalue");
assertTrue(template.hasKey("key"));
assertTrue(template.expire("key", 10, TimeUnit.MINUTES));
assertTrue(template.getExpire("key", TimeUnit.MINUTES) > 8);
}
}
Abhängig von Ihrer Redis-Konfiguration gehen alle Redis-Daten verloren, wenn Sie Ihre Redis-Instanz neu starten.
Sie sollten auch eine Assertion zu expireSession
hinzufügen (assertTrue(cache.expireSession(session, duration));
), um sicherzustellen, dass der Ablauf funktioniert hat.