From 6f38ac6657cabcee067a6299551d280680be16ff Mon Sep 17 00:00:00 2001 From: Griffin Smith Date: Fri, 27 Nov 2020 19:24:26 -0500 Subject: fix(tvix): Add missing break;s to BuildResult::FromProto Add missing break statements to the big switch block in BuildResult::FromProto, and cover the whole thing with a rapidcheck round-trip test. Change-Id: I7a07ca398cc5f02ca4fd8e6256fd563c6f3aea9d Reviewed-on: https://cl.tvl.fyi/c/depot/+/2178 Tested-by: BuildkiteCI Reviewed-by: kanepyork --- third_party/nix/src/tests/store-api-test.cc | 49 +++++++++++++++++++++++++++++ 1 file changed, 49 insertions(+) create mode 100644 third_party/nix/src/tests/store-api-test.cc (limited to 'third_party/nix/src/tests/store-api-test.cc') diff --git a/third_party/nix/src/tests/store-api-test.cc b/third_party/nix/src/tests/store-api-test.cc new file mode 100644 index 0000000000..515613b799 --- /dev/null +++ b/third_party/nix/src/tests/store-api-test.cc @@ -0,0 +1,49 @@ +#include "libstore/store-api.hh" + +#include +#include +#include +#include + +#include "libproto/worker.pb.h" + +namespace rc { +template <> +struct Arbitrary { + static Gen arbitrary() { + return gen::element(nix::BuildResult::Status::Built, + nix::BuildResult::Status::Substituted, + nix::BuildResult::Status::AlreadyValid, + nix::BuildResult::Status::PermanentFailure, + nix::BuildResult::Status::InputRejected, + nix::BuildResult::Status::OutputRejected, + nix::BuildResult::Status::TransientFailure, + nix::BuildResult::Status::CachedFailure, + nix::BuildResult::Status::TimedOut, + nix::BuildResult::Status::MiscFailure, + nix::BuildResult::Status::DependencyFailed, + nix::BuildResult::Status::LogLimitExceeded, + nix::BuildResult::Status::NotDeterministic); + } +}; +} // namespace rc + +namespace nix { + +class BuildResultTest : public ::testing::Test {}; + +RC_GTEST_PROP(BuildResultTest, StatusToFromProtoRoundTrip, + (BuildResult::Status && status)) { + BuildResult br; + br.status = status; + + auto proto_status = br.status_to_proto(); + nix::proto::BuildResult br_proto; + br_proto.set_status(proto_status); + + auto result = BuildResult::FromProto(br_proto); + + RC_ASSERT(result.value().status == status); +} + +} // namespace nix -- cgit 1.4.1