/* * MIT License * * Copyright (c) 2019 Alexey Edelev * * This file is part of qtprotobuf project https://git.semlanik.org/semlanik/qtprotobuf * * Permission is hereby granted, free of charge, to any person obtaining a copy of this * software and associated documentation files (the "Software"), to deal in the Software * without restriction, including without limitation the rights to use, copy, modify, * merge, publish, distribute, sublicense, and/or sell copies of the Software, and * to permit persons to whom the Software is furnished to do so, subject to the following * conditions: * * The above copyright notice and this permission notice shall be included in all copies * or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR * PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE * FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER * DEALINGS IN THE SOFTWARE. */ #include #include #include namespace qtprotobuf { namespace tests { class CoverterTest : public ::testing::Test { public: CoverterTest() = default; }; TEST_F(CoverterTest, TestFromTypeConverters) { QVariant testVariant; testVariant.setValue(42); ASSERT_EQ(42, testVariant.value()._t); testVariant.setValue(43); ASSERT_EQ(43, testVariant.value()._t); testVariant.setValue(44); ASSERT_EQ(44, testVariant.value()._t); testVariant.setValue(45); ASSERT_EQ(45, testVariant.value()._t); testVariant.setValue(46); ASSERT_EQ(46, testVariant.value()._t); testVariant.setValue(47); ASSERT_EQ(47, testVariant.value()._t); } TEST_F(CoverterTest, TestToTypeConverters) { bool ok = false; QVariant testVariant; testVariant.setValue({42}); ASSERT_EQ(42, testVariant.toUInt(&ok)); ASSERT_TRUE(ok); ok = false; testVariant.setValue({43}); ASSERT_EQ(43, testVariant.toULongLong(&ok)); ASSERT_TRUE(ok); ok = false; testVariant.setValue({44}); ASSERT_EQ(44, testVariant.toInt(&ok)); ASSERT_TRUE(ok); ok = false; testVariant.setValue({45}); ASSERT_EQ(45, testVariant.toLongLong(&ok)); ASSERT_TRUE(ok); ok = false; testVariant.setValue({46}); ASSERT_EQ(46, testVariant.toInt(&ok)); ASSERT_TRUE(ok); ok = false; testVariant.setValue({47}); ASSERT_EQ(47, testVariant.toLongLong(&ok)); ASSERT_TRUE(ok); } } }