#include "unittest.h"
#include <libpmemobj++/p.hpp>
#include <libpmemobj++/persistent_ptr.hpp>
#include <libpmemobj++/pool.hpp>
namespace nvobj = pmem::obj;
namespace
{
size_t MB = ((size_t)1 << 20);
struct root {
nvobj::p<int> val;
};
void
pool_create(const char *path, const char *layout, size_t poolsize,
unsigned mode)
{
nvobj::pool<root> pop;
try {
pop = nvobj::pool<root>::create(path, layout, poolsize, mode);
nvobj::persistent_ptr<root> root = pop.get_root();
UT_ASSERT(root != nullptr);
} catch (pmem::pool_error &) {
UT_OUT("!%s: pool::create", path);
return;
}
os_stat_t stbuf;
STAT(path, &stbuf);
UT_OUT("%s: file size %zu mode 0%o", path, stbuf.st_size,
stbuf.st_mode & 0777);
try {
pop.close();
} catch (std::logic_error &lr) {
UT_OUT("%s: pool.close: %s", path, lr.what());
return;
}
int result = nvobj::pool<root>::check(path, layout);
if (result < 0)
UT_OUT("!%s: pool::check", path);
else if (result == 0)
UT_OUT("%s: pool::check: not consistent", path);
}
void
pool_open(const char *path, const char *layout)
{
nvobj::pool<root> pop;
try {
pop = nvobj::pool<root>::open(path, layout);
} catch (pmem::pool_error &) {
UT_OUT("!%s: pool::open", path);
return;
}
UT_OUT("%s: pool::open: Success", path);
try {
pop.close();
} catch (std::logic_error &lr) {
UT_OUT("%s: pool.close: %s", path, lr.what());
}
}
void
double_close(const char *path, const char *layout, size_t poolsize,
unsigned mode)
{
nvobj::pool<root> pop;
try {
pop = nvobj::pool<root>::create(path, layout, poolsize, mode);
} catch (pmem::pool_error &) {
UT_OUT("!%s: pool::create", path);
return;
}
UT_OUT("%s: pool::create: Success", path);
try {
pop.close();
UT_OUT("%s: pool.close: Success", path);
pop.close();
} catch (std::logic_error &lr) {
UT_OUT("%s: pool.close: %s", path, lr.what());
}
}
void
get_root_closed()
{
nvobj::pool<root> pop;
try {
pop.get_root();
} catch (pmem::pool_error &pe) {
UT_OUT("pool.get_root: %s", pe.what());
}
}
}
int
main(int argc, char *argv[])
{
START(argc, argv, "obj_cpp_pool");
if (argc < 4)
UT_FATAL("usage: %s op path layout [poolsize mode]", argv[0]);
const char *layout = nullptr;
size_t poolsize;
unsigned mode;
if (strcmp(argv[3], "EMPTY") == 0)
layout = "";
else if (strcmp(argv[3], "NULL") != 0)
layout = argv[3];
switch (argv[1][0]) {
case 'c':
poolsize = strtoul(argv[4], nullptr, 0) *
MB;
mode = strtoul(argv[5], nullptr, 8);
pool_create(argv[2], layout, poolsize, mode);
break;
case 'o':
pool_open(argv[2], layout);
break;
case 'd':
poolsize = strtoul(argv[4], nullptr, 0) *
MB;
mode = strtoul(argv[5], nullptr, 8);
double_close(argv[2], layout, poolsize, mode);
break;
case 'i':
get_root_closed();
break;
default:
UT_FATAL("unknown operation");
}
DONE(nullptr);
}