#include #include #include #include class TestRapidJsonAdapter : public testing::Test { }; template void testBasicArrayIteration() { const unsigned int numElements = 10; // Create a rapidjson document that consists of an array of numbers rapidjson::Document document; document.SetArray(); for (unsigned int i = 0; i < numElements; i++) { rapidjson::Value value; value.SetDouble(i); document.PushBack(value, document.GetAllocator()); } // Ensure that wrapping the document preserves the array and does not allow // it to be cast to other types valijson::adapters::RapidJsonAdapter adapter(document); ASSERT_NO_THROW( adapter.getArray() ); ASSERT_ANY_THROW( adapter.getBool() ); ASSERT_ANY_THROW( adapter.getDouble() ); ASSERT_ANY_THROW( adapter.getObject() ); ASSERT_ANY_THROW( adapter.getString() ); // Ensure that the array contains the expected number of elements EXPECT_EQ( numElements, adapter.getArray().size() ); // Ensure that the elements are returned in the order they were inserted unsigned int expectedValue = 0; BOOST_FOREACH( const valijson::adapters::RapidJsonAdapter value, adapter.getArray() ) { ASSERT_TRUE( value.isNumber() ); EXPECT_EQ( double(expectedValue), value.getDouble() ); expectedValue++; } // Ensure that the correct number of elements were iterated over EXPECT_EQ(numElements, expectedValue); } template void testBasicObjectIteration() { const unsigned int numElements = 10; // Create a rapidjson document that consists of an object that maps numeric // strings their corresponding numeric values rapidjson::Document document; document.SetObject(); for (unsigned int i = 0; i < numElements; i++) { rapidjson::Value name, value; name.SetString(boost::lexical_cast(i).c_str(), document.GetAllocator()); value.SetDouble(i); document.AddMember(name, value, document.GetAllocator()); } // Ensure that wrapping the document preserves the object and does not // allow it to be cast to other types valijson::adapters::RapidJsonAdapter adapter(document); ASSERT_NO_THROW( adapter.getObject() ); ASSERT_ANY_THROW( adapter.getArray() ); ASSERT_ANY_THROW( adapter.getBool() ); ASSERT_ANY_THROW( adapter.getDouble() ); ASSERT_ANY_THROW( adapter.getString() ); // Ensure that the object contains the expected number of members EXPECT_EQ( numElements, adapter.getObject().size() ); // Ensure that the members are returned in the order they were inserted unsigned int expectedValue = 0; BOOST_FOREACH( const valijson::adapters::RapidJsonAdapter::ObjectMember member, adapter.getObject() ) { ASSERT_TRUE( member.second.isNumber() ); EXPECT_EQ( boost::lexical_cast(expectedValue), member.first ); EXPECT_EQ( double(expectedValue), member.second.getDouble() ); expectedValue++; } // Ensure that the correct number of elements were iterated over EXPECT_EQ( numElements, expectedValue ); } TEST_F(TestRapidJsonAdapter, BasicArrayIteration) { // Test using default RapidJson value type, which uses MemoryPoolAllocator testBasicArrayIteration(); // Test using value type based on CrtAllocator testBasicArrayIteration, rapidjson::CrtAllocator> >(); } TEST_F(TestRapidJsonAdapter, BasicObjectIteration) { // Test using default RapidJson value type, which uses MemoryPoolAllocator testBasicObjectIteration(); // Test using value type based on CrtAllocator testBasicObjectIteration, rapidjson::CrtAllocator> >(); }