1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53
|
#include <gtest/gtest.h>
#include <cassert>
#include <iostream>
#include <rfl.hpp>
#include <rfl/parquet.hpp>
#include <string>
#include <vector>
namespace test_save_load {
using Age = rfl::Validator<unsigned int,
rfl::AllOf<rfl::Minimum<0>, rfl::Maximum<130>>>;
struct Person {
std::string first_name;
std::string last_name = "Simpson";
std::string town = "Springfield";
rfl::Timestamp<"%Y-%m-%d"> birthday;
Age age;
rfl::Email email;
};
TEST(parquet, test_save_load) {
const auto people1 =
std::vector<Person>({Person{.first_name = "Bart",
.birthday = "1987-04-19",
.age = 10,
.email = "bart@simpson.com"},
Person{.first_name = "Lisa",
.birthday = "1987-04-19",
.age = 8,
.email = "lisa@simpson.com"},
Person{.first_name = "Maggie",
.birthday = "1987-04-19",
.age = 0,
.email = "maggie@simpson.com"},
Person{.first_name = "Homer",
.birthday = "1987-04-19",
.age = 45,
.email = "homer@simpson.com"}});
rfl::parquet::save("people.parquet", people1);
const auto people2 =
rfl::parquet::load<std::vector<Person>>("people.parquet").value();
const auto bytes1 = rfl::parquet::write(people1);
const auto bytes2 = rfl::parquet::write(people2);
EXPECT_EQ(bytes1, bytes2);
}
} // namespace test_save_load
|