forked from lix-project/lix
NarInfoDiskCache: Also test id consistency with updated fields
And clarify test
This commit is contained in:
parent
fb94d5cabd
commit
19b495a48a
1 changed files with 89 additions and 70 deletions
|
@ -9,96 +9,115 @@
|
||||||
namespace nix {
|
namespace nix {
|
||||||
|
|
||||||
TEST(NarInfoDiskCacheImpl, create_and_read) {
|
TEST(NarInfoDiskCacheImpl, create_and_read) {
|
||||||
|
// This is a large single test to avoid some setup overhead.
|
||||||
|
|
||||||
int prio = 12345;
|
int prio = 12345;
|
||||||
bool wantMassQuery = true;
|
bool wantMassQuery = true;
|
||||||
|
|
||||||
Path tmpDir = createTempDir();
|
Path tmpDir = createTempDir();
|
||||||
AutoDelete delTmpDir(tmpDir);
|
AutoDelete delTmpDir(tmpDir);
|
||||||
Path dbPath(tmpDir + "/test-narinfo-disk-cache.sqlite");
|
Path dbPath(tmpDir + "/test-narinfo-disk-cache.sqlite");
|
||||||
auto cache = getTestNarInfoDiskCache(dbPath);
|
|
||||||
|
|
||||||
{
|
int savedId;
|
||||||
auto bc1 = cache->createCache("https://bar", "/nix/storedir", wantMassQuery, prio);
|
int barId;
|
||||||
auto bc2 = cache->createCache("https://xyz", "/nix/storedir", false, 12);
|
SQLite db;
|
||||||
ASSERT_NE(bc1, bc2);
|
|
||||||
}
|
|
||||||
|
|
||||||
int savedId = cache->createCache("http://foo", "/nix/storedir", wantMassQuery, prio);;
|
|
||||||
{
|
|
||||||
auto r = cache->upToDateCacheExists("http://foo");
|
|
||||||
ASSERT_TRUE(r);
|
|
||||||
ASSERT_EQ(r->priority, prio);
|
|
||||||
ASSERT_EQ(r->wantMassQuery, wantMassQuery);
|
|
||||||
ASSERT_EQ(savedId, r->id);
|
|
||||||
}
|
|
||||||
|
|
||||||
SQLite db(dbPath);
|
|
||||||
SQLiteStmt getIds;
|
SQLiteStmt getIds;
|
||||||
getIds.create(db, "SELECT id FROM BinaryCaches WHERE url = 'http://foo'");
|
|
||||||
|
|
||||||
{
|
{
|
||||||
auto q(getIds.use());
|
auto cache = getTestNarInfoDiskCache(dbPath);
|
||||||
ASSERT_TRUE(q.next());
|
|
||||||
ASSERT_EQ(savedId, q.getInt(0));
|
|
||||||
ASSERT_FALSE(q.next());
|
|
||||||
}
|
|
||||||
|
|
||||||
db.exec("UPDATE BinaryCaches SET timestamp = timestamp - 1 - 7 * 24 * 3600;");
|
// Set up "background noise" and check that different caches receive different ids
|
||||||
|
{
|
||||||
|
auto bc1 = cache->createCache("https://bar", "/nix/storedir", wantMassQuery, prio);
|
||||||
|
auto bc2 = cache->createCache("https://xyz", "/nix/storedir", false, 12);
|
||||||
|
ASSERT_NE(bc1, bc2);
|
||||||
|
barId = bc1;
|
||||||
|
}
|
||||||
|
|
||||||
// Relies on memory cache
|
// Check that the fields are saved and returned correctly. This does not test
|
||||||
{
|
// the select statement yet, because of in-memory caching.
|
||||||
auto r = cache->upToDateCacheExists("http://foo");
|
savedId = cache->createCache("http://foo", "/nix/storedir", wantMassQuery, prio);;
|
||||||
ASSERT_TRUE(r);
|
{
|
||||||
ASSERT_EQ(r->priority, prio);
|
auto r = cache->upToDateCacheExists("http://foo");
|
||||||
ASSERT_EQ(r->wantMassQuery, wantMassQuery);
|
ASSERT_TRUE(r);
|
||||||
}
|
ASSERT_EQ(r->priority, prio);
|
||||||
|
ASSERT_EQ(r->wantMassQuery, wantMassQuery);
|
||||||
|
ASSERT_EQ(savedId, r->id);
|
||||||
|
}
|
||||||
|
|
||||||
// We can't clear the in-memory cache, so we use a new cache object.
|
// We're going to pay special attention to the id field because we had a bug
|
||||||
auto cache2 = getTestNarInfoDiskCache(dbPath);
|
// that changed it.
|
||||||
|
db = SQLite(dbPath);
|
||||||
|
getIds.create(db, "select id from BinaryCaches where url = 'http://foo'");
|
||||||
|
|
||||||
{
|
{
|
||||||
auto r = cache2->upToDateCacheExists("http://foo");
|
auto q(getIds.use());
|
||||||
ASSERT_FALSE(r);
|
ASSERT_TRUE(q.next());
|
||||||
}
|
ASSERT_EQ(savedId, q.getInt(0));
|
||||||
|
ASSERT_FALSE(q.next());
|
||||||
|
}
|
||||||
|
|
||||||
// Update, same data, check that the id number is reused
|
// Pretend that the caches are older, but keep one up to date, as "background noise"
|
||||||
cache2->createCache("http://foo", "/nix/storedir", wantMassQuery, prio);
|
db.exec("update BinaryCaches set timestamp = timestamp - 1 - 7 * 24 * 3600 where url <> 'https://xyz';");
|
||||||
|
|
||||||
{
|
// This shows that the in-memory cache works
|
||||||
auto r = cache2->upToDateCacheExists("http://foo");
|
{
|
||||||
ASSERT_TRUE(r);
|
auto r = cache->upToDateCacheExists("http://foo");
|
||||||
ASSERT_EQ(r->priority, prio);
|
ASSERT_TRUE(r);
|
||||||
ASSERT_EQ(r->wantMassQuery, wantMassQuery);
|
ASSERT_EQ(r->priority, prio);
|
||||||
ASSERT_EQ(r->id, savedId);
|
ASSERT_EQ(r->wantMassQuery, wantMassQuery);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
auto q(getIds.use());
|
// We can't clear the in-memory cache, so we use a new cache object. This is
|
||||||
ASSERT_TRUE(q.next());
|
// more realistic anyway.
|
||||||
auto currentId = q.getInt(0);
|
auto cache2 = getTestNarInfoDiskCache(dbPath);
|
||||||
ASSERT_FALSE(q.next());
|
|
||||||
ASSERT_EQ(currentId, savedId);
|
{
|
||||||
|
auto r = cache2->upToDateCacheExists("http://foo");
|
||||||
|
ASSERT_FALSE(r);
|
||||||
|
}
|
||||||
|
|
||||||
|
// "Update", same data, check that the id number is reused
|
||||||
|
cache2->createCache("http://foo", "/nix/storedir", wantMassQuery, prio);
|
||||||
|
|
||||||
|
{
|
||||||
|
auto r = cache2->upToDateCacheExists("http://foo");
|
||||||
|
ASSERT_TRUE(r);
|
||||||
|
ASSERT_EQ(r->priority, prio);
|
||||||
|
ASSERT_EQ(r->wantMassQuery, wantMassQuery);
|
||||||
|
ASSERT_EQ(r->id, savedId);
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
auto q(getIds.use());
|
||||||
|
ASSERT_TRUE(q.next());
|
||||||
|
auto currentId = q.getInt(0);
|
||||||
|
ASSERT_FALSE(q.next());
|
||||||
|
ASSERT_EQ(currentId, savedId);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check that the fields can be modified, and the id remains the same
|
||||||
|
{
|
||||||
|
auto r0 = cache2->upToDateCacheExists("https://bar");
|
||||||
|
ASSERT_FALSE(r0);
|
||||||
|
|
||||||
|
cache2->createCache("https://bar", "/nix/storedir", !wantMassQuery, prio + 10);
|
||||||
|
auto r = cache2->upToDateCacheExists("https://bar");
|
||||||
|
ASSERT_EQ(r->wantMassQuery, !wantMassQuery);
|
||||||
|
ASSERT_EQ(r->priority, prio + 10);
|
||||||
|
ASSERT_EQ(r->id, barId);
|
||||||
|
}
|
||||||
|
|
||||||
|
// // Force update (no use case yet; we only retrieve cache metadata when stale based on timestamp)
|
||||||
|
// {
|
||||||
|
// cache2->createCache("https://bar", "/nix/storedir", wantMassQuery, prio + 20);
|
||||||
|
// auto r = cache2->upToDateCacheExists("https://bar");
|
||||||
|
// ASSERT_EQ(r->wantMassQuery, wantMassQuery);
|
||||||
|
// ASSERT_EQ(r->priority, prio + 20);
|
||||||
|
// }
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check that the fields can be modified
|
|
||||||
{
|
|
||||||
auto r0 = cache2->upToDateCacheExists("https://bar");
|
|
||||||
ASSERT_FALSE(r0);
|
|
||||||
|
|
||||||
cache2->createCache("https://bar", "/nix/storedir", !wantMassQuery, prio + 10);
|
|
||||||
auto r = cache2->upToDateCacheExists("https://bar");
|
|
||||||
ASSERT_EQ(r->wantMassQuery, !wantMassQuery);
|
|
||||||
ASSERT_EQ(r->priority, prio + 10);
|
|
||||||
}
|
|
||||||
|
|
||||||
// // Force update (no use case yet; we only retrieve cache metadata when stale based on timestamp)
|
|
||||||
// {
|
|
||||||
// cache2->createCache("https://bar", "/nix/storedir", wantMassQuery, prio + 20);
|
|
||||||
// auto r = cache2->upToDateCacheExists("https://bar");
|
|
||||||
// ASSERT_EQ(r->wantMassQuery, wantMassQuery);
|
|
||||||
// ASSERT_EQ(r->priority, prio + 20);
|
|
||||||
// }
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue