mirror of
https://github.com/privatevoid-net/nix-super.git
synced 2024-11-22 14:06:16 +02:00
C API: add tests for libutil and libstore
This commit is contained in:
parent
46f5d0ee7b
commit
41f1669dea
6 changed files with 133 additions and 25 deletions
|
@ -8,11 +8,6 @@
|
|||
|
||||
#include "globals.hh"
|
||||
|
||||
struct StorePath
|
||||
{
|
||||
nix::StorePath path;
|
||||
};
|
||||
|
||||
nix_err nix_libstore_init(nix_c_context * context)
|
||||
{
|
||||
if (context)
|
||||
|
|
|
@ -6,4 +6,10 @@ struct Store
|
|||
{
|
||||
nix::ref<nix::Store> ptr;
|
||||
};
|
||||
|
||||
struct StorePath
|
||||
{
|
||||
nix::StorePath path;
|
||||
};
|
||||
|
||||
#endif
|
||||
|
|
|
@ -26,6 +26,6 @@ libstore-tests_CXXFLAGS += $(libstore-tests_EXTRA_INCLUDES)
|
|||
|
||||
libstore-tests_LIBS = \
|
||||
libstore-test-support libutil-test-support \
|
||||
libstore libutil
|
||||
libstore libstorec libutil libutilc
|
||||
|
||||
libstore-tests_LDFLAGS := -lrapidcheck $(GTEST_LIBS)
|
||||
|
|
70
tests/unit/libstore/nix_api_store.cc
Normal file
70
tests/unit/libstore/nix_api_store.cc
Normal file
|
@ -0,0 +1,70 @@
|
|||
#include "nix_api_util.h"
|
||||
#include "nix_api_util_internal.h"
|
||||
#include "nix_api_store.h"
|
||||
#include "nix_api_store_internal.h"
|
||||
#include "tests/nix_api_util.hh"
|
||||
|
||||
#define STORE_DIR "/nix/store/"
|
||||
#define HASH_PART "g1w7hy3qg1w7hy3qg1w7hy3qg1w7hy3q"
|
||||
const char * validPath = STORE_DIR HASH_PART "-x";
|
||||
|
||||
namespace nixC {
|
||||
|
||||
class nix_api_store_test : public nix_api_util_context
|
||||
{
|
||||
public:
|
||||
void SetUp() override
|
||||
{
|
||||
nix_api_util_context::SetUp();
|
||||
nix_libstore_init(ctx);
|
||||
store = nix_store_open(ctx, "dummy://", NULL);
|
||||
};
|
||||
void TearDown() override
|
||||
{
|
||||
nix_store_unref(store);
|
||||
nix_api_util_context::TearDown();
|
||||
}
|
||||
|
||||
Store * store;
|
||||
};
|
||||
|
||||
TEST_F(nix_api_util_context, nix_libstore_init)
|
||||
{
|
||||
auto ret = nix_libstore_init(ctx);
|
||||
ASSERT_EQ(NIX_OK, ret);
|
||||
}
|
||||
|
||||
TEST_F(nix_api_store_test, nix_store_get_uri)
|
||||
{
|
||||
char value[256];
|
||||
auto ret = nix_store_get_uri(ctx, store, value, 256);
|
||||
ASSERT_EQ(NIX_OK, ret);
|
||||
ASSERT_STREQ("dummy", value);
|
||||
}
|
||||
|
||||
TEST_F(nix_api_store_test, InvalidPathFails)
|
||||
{
|
||||
nix_store_parse_path(ctx, store, "invalid-path");
|
||||
ASSERT_EQ(ctx->last_err_code, NIX_ERR_NIX_ERROR);
|
||||
}
|
||||
|
||||
TEST_F(nix_api_store_test, ReturnsValidStorePath)
|
||||
{
|
||||
StorePath * result = nix_store_parse_path(ctx, store, validPath);
|
||||
ASSERT_NE(result, nullptr);
|
||||
ASSERT_STREQ("x", result->path.name().data());
|
||||
ASSERT_STREQ(HASH_PART "-x", result->path.to_string().data());
|
||||
}
|
||||
|
||||
TEST_F(nix_api_store_test, SetsLastErrCodeToNixOk)
|
||||
{
|
||||
nix_store_parse_path(ctx, store, validPath);
|
||||
ASSERT_EQ(ctx->last_err_code, NIX_OK);
|
||||
}
|
||||
|
||||
TEST_F(nix_api_store_test, DoesNotCrashWhenContextIsNull)
|
||||
{
|
||||
ASSERT_NO_THROW(nix_store_parse_path(nullptr, store, validPath));
|
||||
}
|
||||
|
||||
}
|
25
tests/unit/libutil-support/tests/nix_api_util.hh
Normal file
25
tests/unit/libutil-support/tests/nix_api_util.hh
Normal file
|
@ -0,0 +1,25 @@
|
|||
#pragma once
|
||||
///@file
|
||||
#include "nix_api_util.h"
|
||||
|
||||
#include <gtest/gtest.h>
|
||||
|
||||
|
||||
class nix_api_util_context : public ::testing::Test
|
||||
{
|
||||
protected:
|
||||
static void SetUpTestSuite()
|
||||
{
|
||||
nix_libutil_init(NULL);
|
||||
}
|
||||
void SetUp() override
|
||||
{
|
||||
ctx = nix_c_context_create();
|
||||
};
|
||||
void TearDown() override
|
||||
{
|
||||
nix_c_context_free(ctx);
|
||||
ctx = nullptr;
|
||||
}
|
||||
nix_c_context * ctx;
|
||||
};
|
|
@ -3,26 +3,12 @@
|
|||
#include "args.hh"
|
||||
#include "nix_api_util.h"
|
||||
#include "nix_api_util_internal.h"
|
||||
#include "tests/nix_api_util.hh"
|
||||
|
||||
#include <gtest/gtest.h>
|
||||
|
||||
namespace nixC {
|
||||
|
||||
class nix_api_util_context : public ::testing::Test {
|
||||
protected:
|
||||
static void SetUpTestSuite() {
|
||||
nix_libutil_init(NULL);
|
||||
}
|
||||
void SetUp() override {
|
||||
ctx = nix_c_context_create();
|
||||
};
|
||||
void TearDown() override {
|
||||
nix_c_context_free(ctx);
|
||||
ctx = nullptr;
|
||||
}
|
||||
nix_c_context* ctx;
|
||||
};
|
||||
|
||||
TEST_F(nix_api_util_context, nix_context_error) {
|
||||
std::string err_msg_ref;
|
||||
try {
|
||||
|
@ -57,12 +43,38 @@ TEST(nix_api_util, nix_version_get) {
|
|||
ASSERT_EQ(std::string(nix_version_get()), PACKAGE_VERSION);
|
||||
}
|
||||
|
||||
TEST_F(nix_api_util_context, nix_setting_get) {
|
||||
// todo
|
||||
struct MySettings : nix::Config
|
||||
{
|
||||
nix::Setting<std::string> settingSet{this, "empty", "setting-name", "Description"};
|
||||
};
|
||||
|
||||
MySettings mySettings;
|
||||
static nix::GlobalConfig::Register rs(&mySettings);
|
||||
|
||||
TEST_F(nix_api_util_context, nix_setting_get)
|
||||
{
|
||||
ASSERT_EQ(ctx->last_err_code, NIX_OK);
|
||||
char value[256];
|
||||
nix_err result = nix_setting_get(ctx, "invalid-key", value, 256);
|
||||
ASSERT_EQ(result, NIX_ERR_KEY);
|
||||
|
||||
result = nix_setting_get(ctx, "setting-name", value, 256);
|
||||
ASSERT_EQ(result, NIX_OK);
|
||||
ASSERT_STREQ("empty", value);
|
||||
}
|
||||
|
||||
TEST_F(nix_api_util_context, nix_setting_set) {
|
||||
// todo
|
||||
TEST_F(nix_api_util_context, nix_setting_set)
|
||||
{
|
||||
nix_err result = nix_setting_set(ctx, "invalid-key", "new-value");
|
||||
ASSERT_EQ(result, NIX_ERR_KEY);
|
||||
|
||||
result = nix_setting_set(ctx, "setting-name", "new-value");
|
||||
ASSERT_EQ(result, NIX_OK);
|
||||
|
||||
char value[256];
|
||||
result = nix_setting_get(ctx, "setting-name", value, 256);
|
||||
ASSERT_EQ(result, NIX_OK);
|
||||
ASSERT_STREQ("new-value", value);
|
||||
}
|
||||
|
||||
TEST_F(nix_api_util_context, nix_err_msg) {
|
||||
|
|
Loading…
Reference in a new issue