#include #include #include #include "tests/path.hh" #include "tests/libexpr.hh" #include "tests/value/context.hh" namespace nix { TEST(NixStringContextElemTest, empty_invalid) { EXPECT_THROW( NixStringContextElem::parse(""), BadNixStringContextElem); } TEST(NixStringContextElemTest, single_bang_invalid) { EXPECT_THROW( NixStringContextElem::parse("!"), BadNixStringContextElem); } TEST(NixStringContextElemTest, double_bang_invalid) { EXPECT_THROW( NixStringContextElem::parse("!!/"), BadStorePath); } TEST(NixStringContextElemTest, eq_slash_invalid) { EXPECT_THROW( NixStringContextElem::parse("=/"), BadStorePath); } TEST(NixStringContextElemTest, slash_invalid) { EXPECT_THROW( NixStringContextElem::parse("/"), BadStorePath); } TEST(NixStringContextElemTest, opaque) { std::string_view opaque = "g1w7hy3qg1w7hy3qg1w7hy3qg1w7hy3q-x"; auto elem = NixStringContextElem::parse(opaque); auto * p = std::get_if(&elem); ASSERT_TRUE(p); ASSERT_EQ(p->path, StorePath { opaque }); ASSERT_EQ(elem.to_string(), opaque); } TEST(NixStringContextElemTest, drvDeep) { std::string_view drvDeep = "=g1w7hy3qg1w7hy3qg1w7hy3qg1w7hy3q-x.drv"; auto elem = NixStringContextElem::parse(drvDeep); auto * p = std::get_if(&elem); ASSERT_TRUE(p); ASSERT_EQ(p->drvPath, StorePath { drvDeep.substr(1) }); ASSERT_EQ(elem.to_string(), drvDeep); } TEST(NixStringContextElemTest, built) { std::string_view built = "!foo!g1w7hy3qg1w7hy3qg1w7hy3qg1w7hy3q-x.drv"; auto elem = NixStringContextElem::parse(built); auto * p = std::get_if(&elem); ASSERT_TRUE(p); ASSERT_EQ(p->output, "foo"); ASSERT_EQ(p->drvPath, StorePath { built.substr(5) }); ASSERT_EQ(elem.to_string(), built); } } namespace rc { using namespace nix; Gen Arbitrary::arbitrary() { return gen::just(NixStringContextElem::Opaque { .path = *gen::arbitrary(), }); } Gen Arbitrary::arbitrary() { return gen::just(NixStringContextElem::DrvDeep { .drvPath = *gen::arbitrary(), }); } Gen Arbitrary::arbitrary() { return gen::just(NixStringContextElem::Built { .drvPath = *gen::arbitrary(), .output = (*gen::arbitrary()).name, }); } Gen Arbitrary::arbitrary() { switch (*gen::inRange(0, std::variant_size_v)) { case 0: return gen::just(*gen::arbitrary()); case 1: return gen::just(*gen::arbitrary()); case 2: return gen::just(*gen::arbitrary()); default: assert(false); } } } namespace nix { RC_GTEST_PROP( NixStringContextElemTest, prop_round_rip, (const NixStringContextElem & o)) { RC_ASSERT(o == NixStringContextElem::parse(o.to_string())); } }