From f6498bfc73d92f61092c71782cd2383afca1ca5b Mon Sep 17 00:00:00 2001 From: David Neto Date: Fri, 11 Sep 2015 13:36:02 -0400 Subject: [PATCH] Assembler test for OpEntryPoint --- test/TextToBinary.ModeSetting.cpp | 45 +++++++++++++++++++++++++++++-- 1 file changed, 43 insertions(+), 2 deletions(-) diff --git a/test/TextToBinary.ModeSetting.cpp b/test/TextToBinary.ModeSetting.cpp index 084dfa04e..ab5ebb6bd 100644 --- a/test/TextToBinary.ModeSetting.cpp +++ b/test/TextToBinary.ModeSetting.cpp @@ -35,6 +35,7 @@ namespace { using spvtest::MakeInstruction; +using spvtest::MakeVector; using ::testing::Eq; // Test OpMemoryModel @@ -77,6 +78,48 @@ INSTANTIATE_TEST_CASE_P(TextToBinaryMemoryModel, OpMemoryModelTest, })); #undef CASE // clang-format on + +// Test OpEntryPoint + +// An example case for OpEntryPoint +struct EntryPointCase { + spv::ExecutionModel execution_value; + std::string execution_name; + std::string entry_point_name; +}; + +using OpEntryPointTest = test_fixture::TextToBinaryTestBase< + ::testing::TestWithParam>; + +TEST_P(OpEntryPointTest, AnyEntryPointCase) { + // TODO(dneto): utf-8, escaping, quoting cases for entry point name. + std::string input = "OpEntryPoint " + GetParam().execution_name + + " %1 \"" + GetParam().entry_point_name + "\""; + std::vector expected_operands{GetParam().execution_value, 1}; + std::vector encoded_entry_point_name = + MakeVector(GetParam().entry_point_name); + expected_operands.insert(expected_operands.end(), + encoded_entry_point_name.begin(), + encoded_entry_point_name.end()); + EXPECT_THAT(CompiledInstructions(input), + Eq(MakeInstruction(spv::OpEntryPoint, expected_operands))); +} + +// clang-format off +#define CASE(NAME) spv::ExecutionModel##NAME, #NAME +INSTANTIATE_TEST_CASE_P(TextToBinaryEntryPoint, OpEntryPointTest, + ::testing::ValuesIn(std::vector{ + { CASE(Vertex), "" }, + { CASE(TessellationControl), "my tess" }, + { CASE(TessellationEvaluation), "really fancy" }, + { CASE(Geometry), "Euclid" }, + { CASE(Fragment), "FAT32" }, + { CASE(GLCompute), "cubic" }, + { CASE(Kernel), "Sanders" }, + })); +#undef CASE +// clang-format on + // Test OpCapability struct CapabilityCase { @@ -137,8 +180,6 @@ INSTANTIATE_TEST_CASE_P(TextToBinaryCapability, OpCapabilityTest, #undef CASE // clang-format on -// TODO(dneto): OpMemoryModel -// TODO(dneto): OpMemoryEntryPoint // TODO(dneto): OpExecutionMode } // anonymous namespace