1
0
mirror of https://github.com/opencv/opencv_contrib.git synced 2025-10-21 06:11:09 +08:00
Files
opencv_contrib/modules/gapi/test/util/optional_tests.cpp
Alexander Smorkalov 2d69dd1215 Merge pull request #3827 from asmorkalov:as/gapi_migration
Migrate G-API module from main repo to opencv_contrib #3827

Related to https://github.com/opencv/opencv/pull/26469
Required https://github.com/opencv/opencv/pull/26527
CI: https://github.com/opencv/ci-gha-workflow/pull/201

TODO:
- [x]  Python types generator fix
- [x] CI update

### Pull Request Readiness Checklist

See details at https://github.com/opencv/opencv/wiki/How_to_contribute#making-a-good-pull-request

- [x] I agree to contribute to the project under Apache 2 License.
- [x] To the best of my knowledge, the proposed patch is not based on a code under GPL or another license that is incompatible with OpenCV
- [ ] The PR is proposed to the proper branch
- [ ] There is a reference to the original bug report and related work
- [ ] There is accuracy test, performance test and test data in opencv_extra repository, if applicable
      Patch to opencv_extra has the same branch name.
- [ ] The feature is well documented and sample code can be built with the project CMake
2024-11-27 16:02:16 +03:00

176 lines
3.7 KiB
C++

// This file is part of OpenCV project.
// It is subject to the license terms in the LICENSE file found in the top-level directory
// of this distribution and at http://opencv.org/license.html.
//
// Copyright (C) 2018 Intel Corporation
#include "../test_precomp.hpp"
#include <opencv2/gapi/util/optional.hpp>
#include <opencv2/gapi/util/compiler_hints.hpp> //suppress_unused_warning
namespace opencv_test
{
TEST(Optional, EmptyCtor)
{
util::optional<int> o;
EXPECT_FALSE(o.has_value());
EXPECT_FALSE(static_cast<bool>(o));
}
TEST(Optional, ValueCTor)
{
util::optional<int> o(42);
EXPECT_TRUE(o.has_value());
EXPECT_TRUE(static_cast<bool>(o));
}
TEST(Optional, MoveCtr)
{
util::optional<std::string> os1(std::string("text"));
EXPECT_TRUE(os1.has_value());
util::optional<std::string> os2(std::move(os1));
EXPECT_FALSE(os1.has_value());
EXPECT_TRUE(os2.has_value());
EXPECT_EQ("text", os2.value());
}
TEST(Optional, EmptyThrows)
{
struct foo { int bar; };
util::optional<foo> om;
const util::optional<foo> oc;
int dummy;
EXPECT_THROW(dummy = om->bar, util::bad_optional_access);
EXPECT_THROW(dummy = oc->bar, util::bad_optional_access);
cv::util::suppress_unused_warning(dummy);
EXPECT_THROW(*om, util::bad_optional_access);
EXPECT_THROW(*oc, util::bad_optional_access);
EXPECT_THROW(om.value(), util::bad_optional_access);
EXPECT_THROW(oc.value(), util::bad_optional_access);
}
TEST(Optional, ValueNoThrow)
{
struct foo { int bar; };
util::optional<foo> om(foo{42});
const util::optional<foo> oc(foo{42});
int dummy;
EXPECT_NO_THROW(dummy = om->bar);
EXPECT_NO_THROW(dummy = oc->bar);
cv::util::suppress_unused_warning(dummy);
EXPECT_NO_THROW(*om);
EXPECT_NO_THROW(*oc);
EXPECT_NO_THROW(om.value());
EXPECT_NO_THROW(oc.value());
}
TEST(Optional, Value)
{
util::optional<int> oi(42);
struct foo { int bar; };
util::optional<foo> of(foo{42});
EXPECT_EQ(42, oi.value());
EXPECT_EQ(42, *oi);
EXPECT_EQ(42, of.value().bar);
EXPECT_EQ(42, of->bar);
}
TEST(Optional, Mutable)
{
util::optional<int> oi(42);
*oi = 43;
EXPECT_EQ(43, *oi);
struct foo { int bar; int baz; };
util::optional<foo> of(foo{11,22});
(*of).bar = 42;
EXPECT_EQ(42, of->bar);
EXPECT_EQ(22, of->baz);
of->baz = 33;
EXPECT_EQ(42, of->bar);
EXPECT_EQ(33, of->baz);
}
TEST(Optional, MoveAssign)
{
util::optional<int> e, i(42);
EXPECT_FALSE(e.has_value());
EXPECT_TRUE(i.has_value());
EXPECT_EQ(42, *i);
e = std::move(i);
EXPECT_TRUE(e.has_value());
EXPECT_FALSE(i.has_value());
EXPECT_EQ(42, *e);
}
TEST(Optional, CopyAssign)
{
util::optional<int> e;
const util::optional<int> i(42);
EXPECT_FALSE(e.has_value());
EXPECT_TRUE(i.has_value());
EXPECT_EQ(42, *i);
e = i;
EXPECT_TRUE(e.has_value());
EXPECT_TRUE(i.has_value());
EXPECT_EQ(42, *e);
EXPECT_EQ(42, *i);
}
TEST(Optional, ValueOr)
{
util::optional<int> e;
EXPECT_FALSE(e.has_value());
EXPECT_EQ(42, e.value_or(42));
EXPECT_EQ(42, e.value_or(42.1));
}
TEST(Optional, Swap)
{
util::optional<int> e, i(42);
EXPECT_FALSE(e.has_value());
EXPECT_TRUE(i.has_value());
EXPECT_EQ(42, *i);
e.swap(i);
EXPECT_TRUE(e.has_value());
EXPECT_FALSE(i.has_value());
EXPECT_EQ(42, *e);
}
TEST(Optional, Reset)
{
util::optional<int> i(42);
EXPECT_TRUE(i.has_value());
i.reset();
EXPECT_FALSE(i.has_value());
}
TEST(Optional, MakeOptional)
{
std::string s("text");
auto os = util::make_optional(s);
EXPECT_TRUE(os.has_value());
EXPECT_EQ(s, os.value());
}
} // namespace opencv_test