#include #include #include #include #include #include #include #include #include #include #include #include #ifdef VALIJSON_BUILD_CXX11_ADAPTERS #include #include #endif // VALIJSON_BUILD_CXX11_ADAPTERS #define TEST_DATA_DIR "../tests/data/documents/" using valijson::adapters::AdapterTraits; class TestAdapterComparison : public testing::Test { protected: struct JsonFile { JsonFile(const std::string &path, int strictGroup, int looseGroup) : path(path), strictGroup(strictGroup), looseGroup(looseGroup) { } std::string path; int strictGroup; int looseGroup; }; static void SetUpTestCase() { const std::string testDataDir(TEST_DATA_DIR); // // Each test is allocated to two groups. The first group is the strict // comparison group. All test files that have been assigned to the same // group should be equal, when compared using strict types. The second // group is the loose comparison group. All tests files in a loose // group should be equal, when compared without using strict types. // // As an example, the first three test files are in the same loose // group. This means they are expected to be equal when compared without // strict types. However, only the first two files in the same strict // group, which means that only they should be equal. // jsonFiles.push_back(JsonFile(testDataDir + "array_doubles_1_2_3.json", 1, 1)); jsonFiles.push_back(JsonFile(testDataDir + "array_integers_1_2_3.json", 1, 1)); jsonFiles.push_back(JsonFile(testDataDir + "array_strings_1_2_3.json", 2, 1)); jsonFiles.push_back(JsonFile(testDataDir + "array_doubles_1_2_3_4.json", 3, 2)); jsonFiles.push_back(JsonFile(testDataDir + "array_integers_1_2_3_4.json", 3, 2)); jsonFiles.push_back(JsonFile(testDataDir + "array_strings_1_2_3_4.json", 4, 2)); jsonFiles.push_back(JsonFile(testDataDir + "array_doubles_10_20_30_40.json", 5, 3)); jsonFiles.push_back(JsonFile(testDataDir + "array_integers_10_20_30_40.json", 5, 3)); jsonFiles.push_back(JsonFile(testDataDir + "array_strings_10_20_30_40.json", 6, 3)); } template static void testComparison() { std::vector::const_iterator outerItr, innerItr; for(outerItr = jsonFiles.begin(); outerItr != jsonFiles.end() - 1; ++outerItr) { for(innerItr = outerItr; innerItr != jsonFiles.end(); ++innerItr) { const bool expectedStrict = (outerItr->strictGroup == innerItr->strictGroup); const bool expectedLoose = (outerItr->looseGroup == innerItr->looseGroup); typename AdapterTraits::DocumentType document1; ASSERT_TRUE( valijson::utils::loadDocument(outerItr->path, document1) ); const Adapter1 adapter1(document1); const std::string adapter1Name = AdapterTraits::adapterName(); typename AdapterTraits::DocumentType document2; ASSERT_TRUE( valijson::utils::loadDocument(innerItr->path, document2) ); const Adapter2 adapter2(document2); const std::string adapter2Name = AdapterTraits::adapterName(); // If either adapter does not support strict types, then strict // comparison should not be used, UNLESS the adapters are of the // same type. If they are of the same type, then the internal // type degradation should be the same, therefore strict testing // of equality makes sense. if (adapter1.hasStrictTypes() && adapter2.hasStrictTypes() && adapter1Name == adapter2Name) { EXPECT_EQ(expectedStrict, adapter1.equalTo(adapter2, true)) << "Comparing '" << outerItr->path << "' to '" << innerItr->path << "' " << "with strict comparison enabled"; EXPECT_EQ(expectedStrict, adapter2.equalTo(adapter1, true)) << "Comparing '" << innerItr->path << "' to '" << outerItr->path << "' " << "with strict comparison enabled"; } EXPECT_EQ(expectedLoose, adapter1.equalTo(adapter2, false)) << "Comparing '" << outerItr->path << "' to '" << innerItr->path << "' " << "with strict comparison disabled"; EXPECT_EQ(expectedLoose, adapter2.equalTo(adapter1, false)) << "Comparing '" << innerItr->path << "' to '" << outerItr->path << "' " << "with strict comparison disabled"; } } } static std::vector jsonFiles; }; std::vector TestAdapterComparison::jsonFiles; TEST_F(TestAdapterComparison, JsonCppVsJsonCpp) { testComparison< valijson::adapters::JsonCppAdapter, valijson::adapters::JsonCppAdapter>(); } TEST_F(TestAdapterComparison, JsonCppVsPicoJson) { testComparison< valijson::adapters::JsonCppAdapter, valijson::adapters::PicoJsonAdapter>(); } TEST_F(TestAdapterComparison, JsonCppVsPropertyTree) { testComparison< valijson::adapters::JsonCppAdapter, valijson::adapters::PropertyTreeAdapter>(); } TEST_F(TestAdapterComparison, JsonCppVsRapidJson) { testComparison< valijson::adapters::JsonCppAdapter, valijson::adapters::RapidJsonAdapter>(); } TEST_F(TestAdapterComparison, JsonCppVsRapidJsonCrtAlloc) { testComparison< valijson::adapters::JsonCppAdapter, valijson::adapters::GenericRapidJsonAdapter< rapidjson::GenericValue, rapidjson::CrtAllocator> > >(); } TEST_F(TestAdapterComparison, PropertyTreeVsPicoJson) { testComparison< valijson::adapters::PropertyTreeAdapter, valijson::adapters::PicoJsonAdapter>(); } TEST_F(TestAdapterComparison, PropertyTreeVsPropertyTree) { testComparison< valijson::adapters::PropertyTreeAdapter, valijson::adapters::PropertyTreeAdapter>(); } TEST_F(TestAdapterComparison, PropertyTreeVsRapidJson) { testComparison< valijson::adapters::PropertyTreeAdapter, valijson::adapters::RapidJsonAdapter>(); } TEST_F(TestAdapterComparison, PropertyTreeVsRapidJsonCrtAlloc) { testComparison< valijson::adapters::PropertyTreeAdapter, valijson::adapters::GenericRapidJsonAdapter< rapidjson::GenericValue, rapidjson::CrtAllocator> > >(); } TEST_F(TestAdapterComparison, RapidJsonVsRapidJson) { testComparison< valijson::adapters::RapidJsonAdapter, valijson::adapters::RapidJsonAdapter>(); } TEST_F(TestAdapterComparison, RapidJsonVsRapidJsonCrtAlloc) { testComparison< valijson::adapters::RapidJsonAdapter, valijson::adapters::GenericRapidJsonAdapter< rapidjson::GenericValue, rapidjson::CrtAllocator> > >(); } TEST_F(TestAdapterComparison, RapidJsonVsPicoJson) { testComparison< valijson::adapters::RapidJsonAdapter, valijson::adapters::PicoJsonAdapter>(); } TEST_F(TestAdapterComparison, PicoJsonVsPicoJson) { testComparison< valijson::adapters::PicoJsonAdapter, valijson::adapters::PicoJsonAdapter>(); } TEST_F(TestAdapterComparison, PicoJsonVsRapidJsonCrtAlloc) { testComparison< valijson::adapters::PicoJsonAdapter, valijson::adapters::GenericRapidJsonAdapter< rapidjson::GenericValue, rapidjson::CrtAllocator> > >(); } TEST_F(TestAdapterComparison, RapidJsonCrtAllocVsRapidJsonCrtAlloc) { testComparison< valijson::adapters::GenericRapidJsonAdapter< rapidjson::GenericValue, rapidjson::CrtAllocator> >, valijson::adapters::GenericRapidJsonAdapter< rapidjson::GenericValue, rapidjson::CrtAllocator> > >(); } #ifdef VALIJSON_BUILD_CXX11_ADAPTERS TEST_F(TestAdapterComparison, Json11VsJson11) { testComparison< valijson::adapters::Json11Adapter, valijson::adapters::Json11Adapter>(); } TEST_F(TestAdapterComparison, Json11VsJsonCpp) { testComparison< valijson::adapters::Json11Adapter, valijson::adapters::JsonCppAdapter>(); } TEST_F(TestAdapterComparison, Json11VsRapidJson) { testComparison< valijson::adapters::Json11Adapter, valijson::adapters::RapidJsonAdapter>(); } TEST_F(TestAdapterComparison, Json11VsRapidJsonCrtAlloc) { testComparison< valijson::adapters::Json11Adapter, valijson::adapters::GenericRapidJsonAdapter< rapidjson::GenericValue, rapidjson::CrtAllocator> > >(); } TEST_F(TestAdapterComparison, Json11VsPicoJson) { testComparison< valijson::adapters::Json11Adapter, valijson::adapters::PicoJsonAdapter>(); } TEST_F(TestAdapterComparison, Json11VsPropertyTree) { testComparison< valijson::adapters::Json11Adapter, valijson::adapters::PropertyTreeAdapter>(); } #endif // VALIJSON_BUILD_CXX11_ADAPTERS