123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123 |
- /*
- * Author: Patrick-Christopher Mattulat
- * Company: Lynar Studios
- * E-Mail: webmaster@lynarstudios.com
- * Created: 2020-09-15
- * Changed: 2021-09-19
- *
- * */
- #include <gtest/gtest.h>
- #include <ls_std/ls_std.hpp>
- namespace
- {
- class SerializableJsonStateTest : public ::testing::Test
- {
- protected:
- SerializableJsonStateTest() = default;
- ~SerializableJsonStateTest() override = default;
- void SetUp() override
- {}
- void TearDown() override
- {}
- };
- TEST_F(SerializableJsonStateTest, constructor_no_parameter_set)
- {
- EXPECT_THROW({
- try
- {
- ls_std::SerializableJsonState serializable{nullptr};
- }
- catch (const ls_std::IllegalArgumentException &_exception)
- {
- throw;
- }
- }, ls_std::IllegalArgumentException);
- }
- TEST_F(SerializableJsonStateTest, marshal)
- {
- std::shared_ptr<ls_std::State> x = std::make_shared<ls_std::State>("A");
- x->addStateConnection(std::make_shared<ls_std::StateConnection>("AB", "B"));
- x->addStateConnection(std::make_shared<ls_std::StateConnection>("AC", "C"));
- ls_std::SerializableJsonState serializable{x};
- ls_std::byte_field jsonString = serializable.marshal();
- ASSERT_TRUE(!jsonString.empty());
- std::string expectedJson = R"({"connectedStates":{"AB":{"condition":false,"connectionId":"AB","stateId":"B"},"AC":{"condition":false,"connectionId":"AC","stateId":"C"}},"id":"A"})";
- ASSERT_STREQ(expectedJson.c_str(), jsonString.c_str());
- }
- TEST_F(SerializableJsonStateTest, unmarshal)
- {
- std::shared_ptr<ls_std::State> x = std::make_shared<ls_std::State>("A");
- ls_std::SerializableJsonState serializable{x};
- // before
- ASSERT_STREQ("A", x->getId().c_str());
- ASSERT_TRUE(x->getConnectedStates().empty());
- // after
- std::string jsonString = R"({"id":"A","connectedStates":{"AB":{"condition":false,"connectionId":"AB","stateId":"B"}}})";
- serializable.unmarshal(jsonString);
- ASSERT_STREQ("A", x->getId().c_str());
- ASSERT_EQ(1, x->getConnectedStates().size());
- ASSERT_STREQ("AB", x->getConnectedStates().at("AB")->getConnectionId().c_str());
- ASSERT_FALSE(x->getConnectedStates().at("AB")->isPassable());
- ASSERT_STREQ("B", x->getConnectedStates().at("AB")->getStateId().c_str());
- }
- TEST_F(SerializableJsonStateTest, getValue)
- {
- std::shared_ptr<ls_std::State> x = std::make_shared<ls_std::State>("A");
- ls_std::SerializableJsonState serializable{x};
- ASSERT_TRUE(serializable.getValue() == x);
- }
- TEST_F(SerializableJsonStateTest, setValue)
- {
- std::shared_ptr<ls_std::State> x = std::make_shared<ls_std::State>("A");
- x->addStateConnection(std::make_shared<ls_std::StateConnection>("AB", "B"));
- x->addStateConnection(std::make_shared<ls_std::StateConnection>("AC", "C"));
- ls_std::SerializableJsonState serializable{x};
- ls_std::byte_field jsonString = serializable.marshal();
- std::string expectedJson = R"({"connectedStates":{"AB":{"condition":false,"connectionId":"AB","stateId":"B"},"AC":{"condition":false,"connectionId":"AC","stateId":"C"}},"id":"A"})";
- ASSERT_STREQ(expectedJson.c_str(), jsonString.c_str());
- // setValue should now clear json
- std::shared_ptr<ls_std::State> y = std::make_shared<ls_std::State>("B");
- serializable.setValue(y);
- jsonString = serializable.marshal();
- ASSERT_STREQ(R"({"id":"B"})", jsonString.c_str());
- }
- TEST_F(SerializableJsonStateTest, setValue_parameter_not_set)
- {
- std::shared_ptr<ls_std::State> state = std::make_shared<ls_std::State>("A");
- ls_std::SerializableJsonState serializable{state};
- EXPECT_THROW({
- try
- {
- serializable.setValue(nullptr);
- }
- catch (const ls_std::IllegalArgumentException &_exception)
- {
- throw;
- }
- }, ls_std::IllegalArgumentException);
- }
- }
|