第一次设置到期已经过去的时间返回True

时间:2014-08-04 07:04:39

标签: redis stackexchange.redis

在下面的测试中,我试图将密钥的到期时间设置为已经过去的时间(10秒前)。如果设置到期“失败”,我需要它能够抛出异常。我明白,我可以在设置缓存之前验证过期时间,但在某些情况下我可能更愿意避免单独检查。

从(一致)行为我可以观察到,第一次它总是“成功”(返回true),第二次它的行为与预期一致(返回false)。

    [Test]
    public void SetExpirationToPassed()
    {
        var key = "testKey";
        using (var conn = CreateConnection())
        {
            // Given
            var cache = conn.GetDatabase();

            cache.HashSet(key, "full", "test", When.NotExists, CommandFlags.PreferMaster);

            Thread.Sleep(10 * 1000);

            // When
            var expiresOn = DateTime.UtcNow.AddSeconds(-10);

            var firstResult = cache.KeyExpire(key, expiresOn, CommandFlags.PreferMaster);
            var secondResult = cache.KeyExpire(key, expiresOn, CommandFlags.PreferMaster);
            var exists = cache.KeyExists(key);
            var ttl = cache.KeyTimeToLive(key);

            // Then
            secondResult.ShouldBe(false);
            firstResult.ShouldBe(false);
            exists.ShouldBe(false);
            ttl.ShouldBe(null);
        }
    }


    private ConnectionMultiplexer CreateConnection()
    {
        return ConnectionMultiplexer connection =ConnectionMultiplexer.Connect(...);
    }

可能是我做错了什么?

1 个答案:

答案 0 :(得分:0)

KeyExpire返回一个布尔值,表示是否可以设置到期时间。当您将到期时间设置为过去时,密钥将不再存在,因此当您尝试第二次设置时:它会失败。

因此,预期的行为应该是:

firstResult.ShouldBe(true);
secondResult.ShouldBe(false);
exists.ShouldBe(false);
ttl.ShouldBe(null);

对于一致运行,您可能还希望在每次运行之前删除密钥:

var cache = conn.GetDatabase();
cache.KeyDelete(key);
cache.HashSet(key, "full", "test", When.NotExists);

在顶部。

有了这个:它似乎像我预期的那样工作。如果您看到不同的内容,请说明确切的结果