|
|
@@ -17,7 +17,7 @@ int main(int argc, char *argv[])
|
|
|
TDB_INTERNAL|TDB_CONVERT, TDB_CONVERT,
|
|
|
TDB_NOMMAP|TDB_CONVERT };
|
|
|
|
|
|
- plan_tests(sizeof(flags) / sizeof(flags[0]) * 7 + 1);
|
|
|
+ plan_tests(sizeof(flags) / sizeof(flags[0]) * 11 + 1);
|
|
|
|
|
|
for (i = 0; i < sizeof(flags) / sizeof(flags[0]); i++) {
|
|
|
tdb = tdb_open("run-expand.tdb", flags[i],
|
|
|
@@ -27,12 +27,17 @@ int main(int argc, char *argv[])
|
|
|
continue;
|
|
|
|
|
|
val = tdb->map_size;
|
|
|
+ /* Need some hash lock for expand. */
|
|
|
+ ok1(tdb_lock_hashes(tdb, 0, 1, F_WRLCK, TDB_LOCK_WAIT) == 0);
|
|
|
ok1(tdb_expand(tdb, 1) == 0);
|
|
|
ok1(tdb->map_size >= val + 1 * TDB_EXTENSION_FACTOR);
|
|
|
+ ok1(tdb_unlock_hashes(tdb, 0, 1, F_WRLCK) == 0);
|
|
|
ok1(tdb_check(tdb, NULL, NULL) == 0);
|
|
|
|
|
|
val = tdb->map_size;
|
|
|
+ ok1(tdb_lock_hashes(tdb, 0, 1, F_WRLCK, TDB_LOCK_WAIT) == 0);
|
|
|
ok1(tdb_expand(tdb, 1024) == 0);
|
|
|
+ ok1(tdb_unlock_hashes(tdb, 0, 1, F_WRLCK) == 0);
|
|
|
ok1(tdb->map_size >= val + 1024 * TDB_EXTENSION_FACTOR);
|
|
|
ok1(tdb_check(tdb, NULL, NULL) == 0);
|
|
|
tdb_close(tdb);
|