add libcmd test for lookupFileArg
Change-Id: I9e2ef170ffe916f902daec8b5630d29434c5d5f2
This commit is contained in:
parent
677cf75473
commit
0565f97e78
57
tests/unit/libcmd/args.cc
Normal file
57
tests/unit/libcmd/args.cc
Normal file
|
@ -0,0 +1,57 @@
|
|||
#include <iostream>
|
||||
#include <memory>
|
||||
#include <string_view>
|
||||
|
||||
#include <boost/core/demangle.hpp>
|
||||
#include <gtest/gtest.h>
|
||||
|
||||
#include "common-eval-args.hh"
|
||||
#include "eval.hh"
|
||||
#include "filetransfer.hh"
|
||||
#include "shared.hh"
|
||||
#include "store-api.hh"
|
||||
#include "util.hh"
|
||||
|
||||
constexpr std::string_view INVALID_CHANNEL = "channel:example";
|
||||
constexpr std::string_view CHANNEL_URL = "https://nixos.org/channels/example/nixexprs.tar.xz";
|
||||
|
||||
namespace nix
|
||||
{
|
||||
|
||||
TEST(Arguments, lookupFileArg) {
|
||||
initNix();
|
||||
initGC();
|
||||
|
||||
std::string const unitDataPath = getEnv("_NIX_TEST_UNIT_DATA").value();
|
||||
// Meson should be allowed to pass us a relative path here tbh.
|
||||
auto const canonDataPath = CanonPath::fromCwd(unitDataPath);
|
||||
|
||||
std::string const searchPathElem = fmt("example=%s", unitDataPath);
|
||||
|
||||
SearchPath searchPath;
|
||||
searchPath.elements.push_back(SearchPath::Elem::parse(searchPathElem));
|
||||
|
||||
auto store = openStore("dummy://");
|
||||
auto statePtr = std::make_shared<EvalState>(searchPath, store, store);
|
||||
auto & state = *statePtr;
|
||||
|
||||
SourcePath const foundUnitData = lookupFileArg(state, "<example>");
|
||||
EXPECT_EQ(foundUnitData.path, canonDataPath);
|
||||
|
||||
// lookupFileArg should not resolve <search paths> if anything else is before or after it.
|
||||
SourcePath const yepEvenSpaces = lookupFileArg(state, " <example>");
|
||||
EXPECT_EQ(yepEvenSpaces.path, CanonPath::fromCwd(" <example>"));
|
||||
EXPECT_EQ(lookupFileArg(state, "<example>/nixos").path, CanonPath::fromCwd("<example>/nixos"));
|
||||
|
||||
try {
|
||||
lookupFileArg(state, INVALID_CHANNEL);
|
||||
} catch (FileTransferError const & ex) {
|
||||
std::string_view const msg(ex.what());
|
||||
EXPECT_NE(msg.find(CHANNEL_URL), msg.npos);
|
||||
}
|
||||
|
||||
SourcePath const normalFile = lookupFileArg(state, unitDataPath);
|
||||
EXPECT_EQ(normalFile.path, canonDataPath);
|
||||
}
|
||||
|
||||
}
|
|
@ -212,3 +212,30 @@ test(
|
|||
protocol : 'gtest',
|
||||
verbose : true,
|
||||
)
|
||||
|
||||
libcmd_tester = executable(
|
||||
'liblixcmd-tests',
|
||||
files('libcmd/args.cc'),
|
||||
dependencies : [
|
||||
liblixcmd,
|
||||
liblixutil,
|
||||
liblixmain,
|
||||
liblixexpr,
|
||||
liblixstore,
|
||||
gtest,
|
||||
boost,
|
||||
],
|
||||
)
|
||||
|
||||
test(
|
||||
'libcmd-unit-tests',
|
||||
libcmd_tester,
|
||||
args : tests_args,
|
||||
env : {
|
||||
# No special meaning here, it's just a file laying around that is unlikely to go anywhere
|
||||
# any time soon.
|
||||
'_NIX_TEST_UNIT_DATA': meson.project_source_root() / 'src/nix-env/buildenv.nix',
|
||||
},
|
||||
suite : 'check',
|
||||
protocol : 'gtest',
|
||||
)
|
||||
|
|
Loading…
Reference in a new issue