#include #include #include #include "tests/path.hh" #include "tests/libexpr.hh" #include "tests/value/context.hh" namespace nix { // Testing of trivial expressions struct NixStringContextElemTest : public LibExprTest { const Store & store() const { return *LibExprTest::store; } }; TEST_F(NixStringContextElemTest, empty_invalid) { EXPECT_THROW( NixStringContextElem::parse(store(), ""), BadNixStringContextElem); } TEST_F(NixStringContextElemTest, single_bang_invalid) { EXPECT_THROW( NixStringContextElem::parse(store(), "!"), BadNixStringContextElem); } TEST_F(NixStringContextElemTest, double_bang_invalid) { EXPECT_THROW( NixStringContextElem::parse(store(), "!!/"), BadStorePath); } TEST_F(NixStringContextElemTest, eq_slash_invalid) { EXPECT_THROW( NixStringContextElem::parse(store(), "=/"), BadStorePath); } TEST_F(NixStringContextElemTest, slash_invalid) { EXPECT_THROW( NixStringContextElem::parse(store(), "/"), BadStorePath); } TEST_F(NixStringContextElemTest, opaque) { std::string_view opaque = "/nix/store/g1w7hy3qg1w7hy3qg1w7hy3qg1w7hy3q-x"; auto elem = NixStringContextElem::parse(store(), opaque); auto * p = std::get_if(&elem); ASSERT_TRUE(p); ASSERT_EQ(p->path, store().parseStorePath(opaque)); ASSERT_EQ(elem.to_string(store()), opaque); } TEST_F(NixStringContextElemTest, drvDeep) { std::string_view drvDeep = "=/nix/store/g1w7hy3qg1w7hy3qg1w7hy3qg1w7hy3q-x.drv"; auto elem = NixStringContextElem::parse(store(), drvDeep); auto * p = std::get_if(&elem); ASSERT_TRUE(p); ASSERT_EQ(p->drvPath, store().parseStorePath(drvDeep.substr(1))); ASSERT_EQ(elem.to_string(store()), drvDeep); } TEST_F(NixStringContextElemTest, built) { std::string_view built = "!foo!/nix/store/g1w7hy3qg1w7hy3qg1w7hy3qg1w7hy3q-x.drv"; auto elem = NixStringContextElem::parse(store(), built); auto * p = std::get_if(&elem); ASSERT_TRUE(p); ASSERT_EQ(p->output, "foo"); ASSERT_EQ(p->drvPath, store().parseStorePath(built.substr(5))); ASSERT_EQ(elem.to_string(store()), 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, 2)) { case 0: return gen::just(*gen::arbitrary()); case 1: return gen::just(*gen::arbitrary()); default: return gen::just(*gen::arbitrary()); } } } namespace nix { RC_GTEST_FIXTURE_PROP( NixStringContextElemTest, prop_round_rip, (const NixStringContextElem & o)) { RC_ASSERT(o == NixStringContextElem::parse(store(), o.to_string(store()))); } }