123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124 |
- #include <gtest/gtest.h>
- #include <ls_std/ls_std_core.hpp>
- #include <ls_std/ls_std_logic.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::logic::SerializableJsonState serializable{nullptr};
- }
- catch (const ls::std::core::IllegalArgumentException &_exception)
- {
- throw;
- }
- }, ls::std::core::IllegalArgumentException);
- }
- TEST_F(SerializableJsonStateTest, marshal)
- {
- ::std::shared_ptr<ls::std::logic::State> x = ::std::make_shared<ls::std::logic::State>("A");
- x->addStateConnection(::std::make_shared<ls::std::logic::StateConnection>("AB", "B"));
- x->addStateConnection(::std::make_shared<ls::std::logic::StateConnection>("AC", "C"));
- ls::std::logic::SerializableJsonState serializable{x};
- ls::std::core::type::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::logic::State> x = ::std::make_shared<ls::std::logic::State>("A");
- ls::std::logic::SerializableJsonState serializable{x};
-
- ASSERT_STREQ("A", x->getId().c_str());
- ASSERT_TRUE(x->getConnectedStates().empty());
-
- ::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::logic::State> x = ::std::make_shared<ls::std::logic::State>("A");
- ls::std::logic::SerializableJsonState serializable{x};
- ASSERT_TRUE(serializable.getValue() == x);
- }
- TEST_F(SerializableJsonStateTest, setValue)
- {
- ::std::shared_ptr<ls::std::logic::State> x = ::std::make_shared<ls::std::logic::State>("A");
- x->addStateConnection(::std::make_shared<ls::std::logic::StateConnection>("AB", "B"));
- x->addStateConnection(::std::make_shared<ls::std::logic::StateConnection>("AC", "C"));
- ls::std::logic::SerializableJsonState serializable{x};
- ls::std::core::type::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());
-
- ::std::shared_ptr<ls::std::logic::State> y = ::std::make_shared<ls::std::logic::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::logic::State> state = ::std::make_shared<ls::std::logic::State>("A");
- ls::std::logic::SerializableJsonState serializable{state};
- EXPECT_THROW({
- try
- {
- serializable.setValue(nullptr);
- }
- catch (const ls::std::core::IllegalArgumentException &_exception)
- {
- throw;
- }
- }, ls::std::core::IllegalArgumentException);
- }
- }
|