123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109 |
- /*
- * Author: Patrick-Christopher Mattulat
- * Company: Lynar Studios
- * E-Mail: webmaster@lynarstudios.com
- * Created: 2020-09-14
- * Changed: 2021-09-19
- *
- * */
- #include <gtest/gtest.h>
- #include <ls_std/ls_std.hpp>
- namespace
- {
- class SerializableJsonStateConnectionTest : public ::testing::Test
- {
- protected:
- SerializableJsonStateConnectionTest() = default;
- ~SerializableJsonStateConnectionTest() override = default;
- void SetUp() override
- {}
- void TearDown() override
- {}
- };
- TEST_F(SerializableJsonStateConnectionTest, constructor_no_parameter_set)
- {
- EXPECT_THROW({
- try
- {
- ls_std::SerializableJsonStateConnection serializable{nullptr};
- }
- catch (const ls_std::IllegalArgumentException &_exception)
- {
- throw;
- }
- }, ls_std::IllegalArgumentException);
- }
- // implementation
- TEST_F(SerializableJsonStateConnectionTest, marshal)
- {
- ls_std::StateConnection x{"AB", "B"};
- ls_std::SerializableJsonStateConnection serializable{std::make_shared<ls_std::StateConnection>(x)};
- ls_std::String jsonString{serializable.marshal()};
- ASSERT_STREQ(R"({"condition":false,"connectionId":"AB","stateId":"B"})", jsonString.toString().c_str());
- }
- TEST_F(SerializableJsonStateConnectionTest, unmarshal)
- {
- std::shared_ptr<ls_std::StateConnection> x = std::make_shared<ls_std::StateConnection>("AB", "B");
- ASSERT_STREQ("AB", x->getConnectionId().c_str());
- ASSERT_STREQ("B", x->getStateId().c_str());
- ASSERT_FALSE(x->isPassable());
- ls_std::SerializableJsonStateConnection serializable{x};
- serializable.unmarshal(R"({"condition":true,"connectionId":"BC","stateId":"C"})");
- ASSERT_STREQ("BC", x->getConnectionId().c_str());
- ASSERT_STREQ("C", x->getStateId().c_str());
- ASSERT_TRUE(x->isPassable());
- }
- TEST_F(SerializableJsonStateConnectionTest, getValue)
- {
- std::shared_ptr<ls_std::StateConnection> x = std::make_shared<ls_std::StateConnection>("AB", "B");
- ls_std::SerializableJsonStateConnection serializable{x};
- ASSERT_TRUE(serializable.getValue() == x);
- }
- TEST_F(SerializableJsonStateConnectionTest, setValue)
- {
- ls_std::StateConnection x{"AB", "B"};
- ls_std::SerializableJsonStateConnection serializable{std::make_shared<ls_std::StateConnection>(x)};
- ls_std::String jsonString{serializable.marshal()};
- ASSERT_STREQ(R"({"condition":false,"connectionId":"AB","stateId":"B"})", jsonString.toString().c_str());
- // set value should now reset json
- ls_std::StateConnection y{"BC", "C"};
- serializable.setValue(std::make_shared<ls_std::StateConnection>(y));
- jsonString = serializable.marshal();
- ASSERT_STREQ(R"({"condition":false,"connectionId":"BC","stateId":"C"})", jsonString.toString().c_str());
- }
- TEST_F(SerializableJsonStateConnectionTest, setValue_no_parameter_set)
- {
- ls_std::StateConnection stateConnection{"AB", "B"};
- ls_std::SerializableJsonStateConnection serializable{std::make_shared<ls_std::StateConnection>(stateConnection)};
- EXPECT_THROW({
- try
- {
- serializable.setValue(nullptr);
- }
- catch (const ls_std::IllegalArgumentException &_exception)
- {
- throw;
- }
- }, ls_std::IllegalArgumentException);
- }
- }
|