diff C++/Tests/Pack/main.cpp @ 290:7433ebe6a8b0

Pack: * Stateful classes * Use << and >> operators for more convenience, * Use PackFileWriter and PackFileReader to write/read a file, * Use PackStringWriter and PackStringReader to write/read a string, * Pack now supports object serialization through Pack::TypeInfo<T>::(un)serialize.
author David Demelier <markand@malikania.fr>
date Thu, 13 Nov 2014 13:08:49 +0100
parents b5d795389387
children 345aaeb5e0ba
line wrap: on
line diff
--- a/C++/Tests/Pack/main.cpp	Tue Nov 11 15:05:18 2014 +0100
+++ b/C++/Tests/Pack/main.cpp	Thu Nov 13 13:08:49 2014 +0100
@@ -23,6 +23,31 @@
 
 #include <Pack.h>
 
+struct Point
+{
+	uint32_t width{};
+	uint32_t height{};
+
+	inline bool operator==(const Point &other) const
+	{
+		return width == other.width && height == other.height;
+	}
+};
+
+template <>
+struct Pack::TypeInfo<Point> : public Pack::Serializable
+{
+	static void serialize(PackWriter &writer, const Point &point)
+	{
+		writer << point.width << point.height;
+	}
+
+	static void unserialize(PackReader &reader, Point &point)
+	{
+		reader >> point.width >> point.height;
+	}
+};
+
 TEST(File, simpleLittleEndian)
 {
 	uint8_t u8(1), r8;
@@ -30,16 +55,16 @@
 	uint32_t u32(3), r32;
 	uint64_t u64(4), r64;
 
+	remove("output.bin");
+
 	try {
-		std::ofstream out;
-		out.open("simple-little.bin", std::ostream::out);
-		Pack::write(out, Pack::Little, u8, u16, u32, u64);
-		out.close();
+		{
+			PackFileWriter writer{"output.bin", Pack::Little};
+			writer << u8 << u16 << u32 << u64;
+		}
 
-		std::ifstream in;
-		in.open("simple-little.bin", std::ostream::in);
-		Pack::read(in, Pack::Little, r8, r16, r32, r64);
-		in.close();
+		PackFileReader reader{"output.bin", Pack::Little};
+		reader >> r8 >> r16 >> r32 >> r64;
 
 		ASSERT_EQ(u8, r8);
 		ASSERT_EQ(u16, r16);
@@ -57,16 +82,84 @@
 	uint32_t u32(3), r32;
 	uint64_t u64(4), r64;
 
+	remove("output.bin");
+
 	try {
-		std::ofstream out;
-		out.open("simple-big.bin", std::ostream::out);
-		Pack::write(out, Pack::Big, u8, u16, u32, u64);
-		out.close();
+		{
+			PackFileWriter writer{"output.bin", Pack::Big};
+			writer << u8 << u16 << u32 << u64;
+		}
+
+		PackFileReader reader{"output.bin", Pack::Big};
+		reader >> r8 >> r16 >> r32 >> r64;
+
+		ASSERT_EQ(u8, r8);
+		ASSERT_EQ(u16, r16);
+		ASSERT_EQ(u32, r32);
+		ASSERT_EQ(u64, r64);
+	} catch (const std::exception &error) {
+		FAIL() << error.what();
+	}
+}
+
+TEST(File, arrayLittleEndian)
+{
+	std::vector<uint8_t> u8 { 1, 2, 3, 4, 5, 6, 7, 8 };
+	std::vector<uint16_t> u16 { 10, 20, 30, 40, 50, 60, 70, 80 };
+	std::vector<uint32_t> u32 { 100, 200, 300, 400, 500, 600, 700, 800 };
+	std::vector<uint64_t> u64 { 1000, 2000, 3000, 4000, 5000, 6000, 7000, 8000 };
+
+	std::vector<uint8_t> r8(8);
+	std::vector<uint16_t> r16(8);
+	std::vector<uint32_t> r32(8);
+	std::vector<uint64_t> r64(8);
+
+	remove("output.bin");
+
+	try {
+		{
+			PackFileWriter writer{"output.bin", Pack::Little};
+
+			writer << u8 << u16 << u32 << u64;
+		}
 
-		std::ifstream in;
-		in.open("simple-big.bin", std::ostream::in);
-		Pack::read(in, Pack::Big, r8, r16, r32, r64);
-		in.close();
+		PackFileReader reader{"output.bin", Pack::Little};
+
+		reader >> r8 >> r16 >> r32 >> r64;
+
+		ASSERT_EQ(u8, r8);
+		ASSERT_EQ(u16, r16);
+		ASSERT_EQ(u32, r32);
+		ASSERT_EQ(u64, r64);
+	} catch (const std::exception &error) {
+		FAIL() << error.what();
+	}
+}
+
+TEST(File, arrayBigEndian)
+{
+	std::vector<uint8_t> u8 { 1, 2, 3, 4, 5, 6, 7, 8 };
+	std::vector<uint16_t> u16 { 10, 20, 30, 40, 50, 60, 70, 80 };
+	std::vector<uint32_t> u32 { 100, 200, 300, 400, 500, 600, 700, 800 };
+	std::vector<uint64_t> u64 { 1000, 2000, 3000, 4000, 5000, 6000, 7000, 8000 };
+
+	std::vector<uint8_t> r8(8);
+	std::vector<uint16_t> r16(8);
+	std::vector<uint32_t> r32(8);
+	std::vector<uint64_t> r64(8);
+
+	remove("output.bin");
+
+	try {
+		{
+			PackFileWriter writer{"output.bin", Pack::Big};
+
+			writer << u8 << u16 << u32 << u64;
+		}
+
+		PackFileReader reader{"output.bin", Pack::Big};
+
+		reader >> r8 >> r16 >> r32 >> r64;
 
 		ASSERT_EQ(u8, r8);
 		ASSERT_EQ(u16, r16);
@@ -77,6 +170,102 @@
 	}
 }
 
+TEST(File, serializeSimpleLittleEndian)
+{
+	Point point{200, 400};
+	Point result;
+
+	remove("output.bin");
+
+	try {
+		{
+			PackFileWriter writer{"output.bin", Pack::Little};
+
+			writer << point;
+		}
+
+		PackFileReader reader{"output.bin", Pack::Little};
+
+		reader >> result;
+
+		ASSERT_EQ(point, result);
+	} catch (const std::exception &ex) {
+		std::cerr << "warning: " << ex.what() << std::endl;
+	}
+}
+
+TEST(File, serializeSimpleBigEndian)
+{
+	Point point{200, 400};
+	Point result;
+
+	remove("output.bin");
+
+	try {
+		{
+			PackFileWriter writer{"output.bin", Pack::Big};
+
+			writer << point;
+		}
+
+		PackFileReader reader{"output.bin", Pack::Big};
+
+		reader >> result;
+
+		ASSERT_EQ(point, result);
+	} catch (const std::exception &ex) {
+		std::cerr << "warning: " << ex.what() << std::endl;
+	}
+}
+
+TEST(File, serializeArrayLittleEndian)
+{
+	std::vector<Point> points{{10, 20}, {30, 40}};
+	std::vector<Point> rpoints(2);
+
+	remove("output.bin");
+
+	try {
+		{
+			PackFileWriter writer{"output.bin", Pack::Little};
+
+			writer << points;
+		}
+
+		PackFileReader reader{"output.bin", Pack::Little};
+
+		reader >> rpoints;
+
+		ASSERT_EQ(points, rpoints);
+	} catch (const std::exception &ex) {
+		std::cerr << "warning: " << ex.what() << std::endl;
+	}
+}
+
+TEST(File, serializeArrayBigEndian)
+{
+	std::vector<Point> points{{10, 20}, {30, 40}};
+	std::vector<Point> rpoints(2);
+
+	remove("output.bin");
+
+	try {
+		{
+			PackFileWriter writer{"output.bin", Pack::Big};
+
+			writer << points;
+		}
+
+		PackFileReader reader{"output.bin", Pack::Big};
+
+		reader >> rpoints;
+
+		ASSERT_EQ(points, rpoints);
+	} catch (const std::exception &ex) {
+		std::cerr << "warning: " << ex.what() << std::endl;
+	}
+}
+
 TEST(String, simpleLittleEndian)
 {
 	uint8_t u8(1), r8;
@@ -85,11 +274,16 @@
 	uint64_t u64(4), r64;
 
 	try {
-		std::ostringstream out;
-		Pack::write(out, Pack::Little, u8, u16, u32, u64);
+		std::string input;
 
-		std::istringstream in(out.str());
-		Pack::read(in, Pack::Little, r8, r16, r32, r64);
+		{
+			PackStringWriter writer{Pack::Little};
+			writer << u8 << u16 << u32 << u64;
+			input = writer.buffer();
+		}
+
+		PackStringReader reader{std::move(input), Pack::Little};
+		reader >> r8 >> r16 >> r32 >> r64;
 
 		ASSERT_EQ(u8, r8);
 		ASSERT_EQ(u16, r16);
@@ -108,11 +302,86 @@
 	uint64_t u64(4), r64;
 
 	try {
-		std::ostringstream out;
-		Pack::write(out, Pack::Big, u8, u16, u32, u64);
+		std::string input;
+
+		{
+			PackStringWriter writer{Pack::Big};
+			writer << u8 << u16 << u32 << u64;
+			input = writer.buffer();
+		}
+
+		PackStringReader reader{std::move(input), Pack::Big};
+		reader >> r8 >> r16 >> r32 >> r64;
+
+		ASSERT_EQ(u8, r8);
+		ASSERT_EQ(u16, r16);
+		ASSERT_EQ(u32, r32);
+		ASSERT_EQ(u64, r64);
+	} catch (const std::exception &error) {
+		FAIL() << error.what();
+	}
+}
+
+TEST(String, arrayLittleEndian)
+{
+	std::vector<uint8_t> u8 { 1, 2, 3, 4, 5, 6, 7, 8 };
+	std::vector<uint16_t> u16 { 10, 20, 30, 40, 50, 60, 70, 80 };
+	std::vector<uint32_t> u32 { 100, 200, 300, 400, 500, 600, 700, 800 };
+	std::vector<uint64_t> u64 { 1000, 2000, 3000, 4000, 5000, 6000, 7000, 8000 };
+
+	std::vector<uint8_t> r8(8);
+	std::vector<uint16_t> r16(8);
+	std::vector<uint32_t> r32(8);
+	std::vector<uint64_t> r64(8);
+
+	try {
+		std::string input;
+
+		{
+			PackStringWriter writer{Pack::Little};
 
-		std::istringstream in(out.str());
-		Pack::read(in, Pack::Big, r8, r16, r32, r64);
+			writer << u8 << u16 << u32 << u64;
+			input = writer.buffer();
+		}
+
+		PackStringReader reader{std::move(input), Pack::Little};
+
+		reader >> r8 >> r16 >> r32 >> r64;
+
+		ASSERT_EQ(u8, r8);
+		ASSERT_EQ(u16, r16);
+		ASSERT_EQ(u32, r32);
+		ASSERT_EQ(u64, r64);
+	} catch (const std::exception &error) {
+		FAIL() << error.what();
+	}
+}
+
+TEST(String, arrayBigEndian)
+{
+	std::vector<uint8_t> u8 { 1, 2, 3, 4, 5, 6, 7, 8 };
+	std::vector<uint16_t> u16 { 10, 20, 30, 40, 50, 60, 70, 80 };
+	std::vector<uint32_t> u32 { 100, 200, 300, 400, 500, 600, 700, 800 };
+	std::vector<uint64_t> u64 { 1000, 2000, 3000, 4000, 5000, 6000, 7000, 8000 };
+
+	std::vector<uint8_t> r8(8);
+	std::vector<uint16_t> r16(8);
+	std::vector<uint32_t> r32(8);
+	std::vector<uint64_t> r64(8);
+
+	try {
+		std::string input;
+
+		{
+			PackStringWriter writer{Pack::Big};
+
+			writer << u8 << u16 << u32 << u64;
+			input = writer.buffer();
+		}
+
+		PackStringReader reader{std::move(input), Pack::Big};
+
+		reader >> r8 >> r16 >> r32 >> r64;
 
 		ASSERT_EQ(u8, r8);
 		ASSERT_EQ(u16, r16);
@@ -123,73 +392,103 @@
 	}
 }
 
-TEST(Array, simpleLittleEndian)
+TEST(String, serializeSimpleLittleEndian)
 {
-	std::vector<uint8_t> u8 { 1, 2, 3, 4, 5, 6, 7, 8 };
-	std::vector<uint16_t> u16 { 10, 20, 30, 40, 50, 60, 70, 80 };
-	std::vector<uint32_t> u32 { 100, 200, 300, 400, 500, 600, 700, 800 };
-	std::vector<uint64_t> u64 { 1000, 2000, 3000, 4000, 5000, 6000, 7000, 8000 };
-
-	std::vector<uint8_t> r8;
-	std::vector<uint16_t> r16;
-	std::vector<uint32_t> r32;
-	std::vector<uint64_t> r64;
+	Point point{200, 400};
+	Point result;
 
 	try {
-		std::ostringstream out;
-		Pack::writeArray(out, Pack::Little, u8.cbegin(), u8.size());
-		Pack::writeArray(out, Pack::Little, u16.cbegin(), u16.size());
-		Pack::writeArray(out, Pack::Little, u32.cbegin(), u32.size());
-		Pack::writeArray(out, Pack::Little, u64.cbegin(), u64.size());
+		std::string input;
+
+		{
+			PackStringWriter writer{Pack::Little};
 
-		std::istringstream in(out.str());
-		Pack::readArray(in, Pack::Little, std::back_inserter(r8), 8);
-		Pack::readArray(in, Pack::Little, std::back_inserter(r16), 8);
-		Pack::readArray(in, Pack::Little, std::back_inserter(r32), 8);
-		Pack::readArray(in, Pack::Little, std::back_inserter(r64), 8);
+			writer << point;
+			input = writer.buffer();
+		}
 
+		PackStringReader reader{std::move(input), Pack::Little};
 
-		ASSERT_EQ(u8, r8);
-		ASSERT_EQ(u16, r16);
-		ASSERT_EQ(u32, r32);
-		ASSERT_EQ(u64, r64);
-	} catch (const std::exception &error) {
-		FAIL() << error.what();
+		reader >> result;
+
+		ASSERT_EQ(point, result);
+	} catch (const std::exception &ex) {
+		std::cerr << "warning: " << ex.what() << std::endl;
 	}
 }
 
-TEST(Array, simpleBigEndian)
+TEST(String, serializeSimpleBigEndian)
 {
-	std::vector<uint8_t> u8 { 1, 2, 3, 4, 5, 6, 7, 8 };
-	std::vector<uint16_t> u16 { 10, 20, 30, 40, 50, 60, 70, 80 };
-	std::vector<uint32_t> u32 { 100, 200, 300, 400, 500, 600, 700, 800 };
-	std::vector<uint64_t> u64 { 1000, 2000, 3000, 4000, 5000, 6000, 7000, 8000 };
+	Point point{200, 400};
+	Point result;
+
+	try {
+		std::string input;
+
+		{
+			PackStringWriter writer{Pack::Big};
+
+			writer << point;
+			input = writer.buffer();
+		}
 
-	std::vector<uint8_t> r8;
-	std::vector<uint16_t> r16;
-	std::vector<uint32_t> r32;
-	std::vector<uint64_t> r64;
+		PackStringReader reader{std::move(input), Pack::Big};
+
+		reader >> result;
+
+		ASSERT_EQ(point, result);
+	} catch (const std::exception &ex) {
+		std::cerr << "warning: " << ex.what() << std::endl;
+	}
+}
+
+TEST(String, serializeArrayLittleEndian)
+{
+	std::vector<Point> points{{10, 20}, {30, 40}};
+	std::vector<Point> rpoints(2);
 
 	try {
-		std::ostringstream out;
-		Pack::writeArray(out, Pack::Big, u8.cbegin(), u8.size());
-		Pack::writeArray(out, Pack::Big, u16.cbegin(), u16.size());
-		Pack::writeArray(out, Pack::Big, u32.cbegin(), u32.size());
-		Pack::writeArray(out, Pack::Big, u64.cbegin(), u64.size());
+		std::string input;
+
+		{
+			PackStringWriter writer{Pack::Little};
+
+			writer << points;
+			input = writer.buffer();
+		}
+
+		PackStringReader reader{std::move(input), Pack::Little};
+
+		reader >> rpoints;
+
+		ASSERT_EQ(points, rpoints);
+	} catch (const std::exception &ex) {
+		std::cerr << "warning: " << ex.what() << std::endl;
+	}
+}
 
-		std::istringstream in(out.str());
-		Pack::readArray(in, Pack::Big, std::back_inserter(r8), 8);
-		Pack::readArray(in, Pack::Big, std::back_inserter(r16), 8);
-		Pack::readArray(in, Pack::Big, std::back_inserter(r32), 8);
-		Pack::readArray(in, Pack::Big, std::back_inserter(r64), 8);
+TEST(String, serializeArrayBigEndian)
+{
+	std::vector<Point> points{{10, 20}, {30, 40}};
+	std::vector<Point> rpoints(2);
 
+	try {
+		std::string input;
+
+		{
+			PackStringWriter writer{Pack::Big};
 
-		ASSERT_EQ(u8, r8);
-		ASSERT_EQ(u16, r16);
-		ASSERT_EQ(u32, r32);
-		ASSERT_EQ(u64, r64);
-	} catch (const std::exception &error) {
-		FAIL() << error.what();
+			writer << points;
+			input = writer.buffer();
+		}
+
+		PackStringReader reader{std::move(input), Pack::Big};
+
+		reader >> rpoints;
+
+		ASSERT_EQ(points, rpoints);
+	} catch (const std::exception &ex) {
+		std::cerr << "warning: " << ex.what() << std::endl;
 	}
 }