Jade Lovelace
21ad02c1d0
The following behaviour was previously present and has been fixed:
lix/lix2 » nix eval --expr '{x."" = 2;}' 'x.""'
{ "" = 2; }
lix/lix2 » nix eval --expr '{x."".y = 2;}' 'x."".y'
error: empty attribute name in selection path 'x."".y'
Change-Id: Iad21988f1191c33a3661c72a6b7f01a8b8b3e6eb
46 lines
1.4 KiB
C++
46 lines
1.4 KiB
C++
#include "lix/libexpr/attr-path.hh"
|
|
#include "lix/libexpr/attr-set.hh"
|
|
#include "tests/libexpr.hh"
|
|
#include <gtest/gtest.h>
|
|
#include <rapidcheck/gen/Arbitrary.h>
|
|
#include <rapidcheck/gen/Container.h>
|
|
#include <rapidcheck/gen/Predicate.h>
|
|
#include <rapidcheck/gtest.h>
|
|
|
|
namespace nix {
|
|
|
|
class AttrPathEval : public LibExprTest
|
|
{
|
|
public:
|
|
std::pair<Value *, PosIdx> testFindAlongAttrPath(std::string expr, std::string path);
|
|
};
|
|
|
|
RC_GTEST_PROP(AttrPath, prop_round_trip, ())
|
|
{
|
|
auto strings = *rc::gen::container<std::vector<std::string>>(
|
|
rc::gen::container<std::string>(rc::gen::distinctFrom('"'))
|
|
);
|
|
auto const unparsed = unparseAttrPath(strings);
|
|
auto const unparsedReparsed = parseAttrPath(unparsed);
|
|
|
|
RC_ASSERT(strings == unparsedReparsed);
|
|
}
|
|
|
|
std::pair<Value *, PosIdx> AttrPathEval::testFindAlongAttrPath(std::string expr, std::string path)
|
|
{
|
|
auto v = eval(expr);
|
|
auto bindings = evalState().ctx.buildBindings(0).finish();
|
|
return findAlongAttrPath(state, path, *bindings, v);
|
|
}
|
|
|
|
// n.b. I do not know why we throw for empty attrs but they are apparently
|
|
// disallowed.
|
|
TEST_F(AttrPathEval, emptyAttrsThrows)
|
|
{
|
|
std::string expr = "{a.\"\".b = 2;}";
|
|
ASSERT_NO_THROW(testFindAlongAttrPath(expr, "a"));
|
|
ASSERT_THROW(testFindAlongAttrPath(expr, "a.\"\".b"), Error);
|
|
ASSERT_THROW(testFindAlongAttrPath(expr, "a.\"\""), Error);
|
|
}
|
|
|
|
}
|