// 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 "api/gcomputation_priv.hpp" namespace opencv_test { TEST(GMetaArg, Traits_Is_Positive) { using namespace cv::detail; static_assert(is_meta_descr::value, "GScalarDesc is a meta description type"); static_assert(is_meta_descr::value, "GMatDesc is a meta description type"); } TEST(GMetaArg, Traits_Is_Negative) { using namespace cv::detail; static_assert(!is_meta_descr::value, "GCompileArgs is NOT a meta description type"); static_assert(!is_meta_descr::value, "int is NOT a meta description type"); static_assert(!is_meta_descr::value, "str::string is NOT a meta description type"); } TEST(GMetaArg, Traits_Are_EntireList_Positive) { using namespace cv::detail; static_assert(are_meta_descrs::value, "GScalarDesc is a meta description type"); static_assert(are_meta_descrs::value, "GMatDesc is a meta description type"); static_assert(are_meta_descrs::value, "Both GMatDesc and GScalarDesc are meta types"); } TEST(GMetaArg, Traits_Are_EntireList_Negative) { using namespace cv::detail; static_assert(!are_meta_descrs::value, "GCompileArgs is NOT among meta types"); static_assert(!are_meta_descrs::value, "Both int and std::string is NOT among meta types"); static_assert(!are_meta_descrs::value, "List of type is not valid for meta as there\'s int"); static_assert(!are_meta_descrs::value, "List of type is not valid for meta as there\'s GCompileArgs"); } TEST(GMetaArg, Traits_Are_ButLast_Positive) { using namespace cv::detail; static_assert(are_meta_descrs_but_last::value, "List is valid (int is omitted)"); static_assert(are_meta_descrs_but_last::value, "List is valid (GCompileArgs are omitted)"); } TEST(GMetaArg, Traits_Are_ButLast_Negative) { using namespace cv::detail; static_assert(!are_meta_descrs_but_last::value, "Both int is NOT among meta types (std::string is omitted)"); static_assert(!are_meta_descrs_but_last::value, "List of type is not valid for meta as there\'s two ints"); static_assert(!are_meta_descrs_but_last::value, "List of type is not valid for meta as there\'s GCompileArgs"); } TEST(GMetaArg, Can_Get_Metas_From_Input_Run_Args) { cv::Mat m(3, 3, CV_8UC3); cv::Scalar s; std::vector v; GMatDesc m_desc; GMetaArgs meta_args = descr_of(cv::gin(m, s, v)); EXPECT_EQ(meta_args.size(), 3u); EXPECT_NO_THROW(m_desc = util::get(meta_args[0])); EXPECT_NO_THROW(util::get(meta_args[1])); EXPECT_NO_THROW(util::get(meta_args[2])); EXPECT_EQ(CV_8U, m_desc.depth); EXPECT_EQ(3, m_desc.chan); EXPECT_EQ(cv::gapi::own::Size(3, 3), m_desc.size); } TEST(GMetaArg, Can_Get_Metas_From_Output_Run_Args) { cv::Mat m(3, 3, CV_8UC3); cv::Scalar s; std::vector v; GMatDesc m_desc; GRunArgsP out_run_args = cv::gout(m, s, v); GMetaArg m_meta = descr_of(out_run_args[0]); GMetaArg s_meta = descr_of(out_run_args[1]); GMetaArg v_meta = descr_of(out_run_args[2]); EXPECT_NO_THROW(m_desc = util::get(m_meta)); EXPECT_NO_THROW(util::get(s_meta)); EXPECT_NO_THROW(util::get(v_meta)); EXPECT_EQ(CV_8U, m_desc.depth); EXPECT_EQ(3, m_desc.chan); EXPECT_EQ(cv::Size(3, 3), m_desc.size); } TEST(GMetaArg, Can_Describe_RunArg) { cv::Mat m(3, 3, CV_8UC3); cv::UMat um(3, 3, CV_8UC3); cv::Scalar s; constexpr int w = 3, h = 3, c = 3; uchar data[w*h*c]; cv::gapi::own::Mat om(h, w, CV_8UC3, data); cv::Scalar os; std::vector v; GMetaArgs metas = {GMetaArg(descr_of(m)), GMetaArg(descr_of(um)), GMetaArg(descr_of(s)), GMetaArg(descr_of(om)), GMetaArg(descr_of(os)), GMetaArg(descr_of(v))}; auto in_run_args = cv::gin(m, um, s, om, os, v); for (int i = 0; i < 3; i++) { EXPECT_TRUE(can_describe(metas[i], in_run_args[i])); } } TEST(GMetaArg, Can_Describe_RunArgs) { cv::Mat m(3, 3, CV_8UC3); cv::Scalar s; std::vector v; GMetaArgs metas0 = {GMetaArg(descr_of(m)), GMetaArg(descr_of(s)), GMetaArg(descr_of(v))}; auto in_run_args0 = cv::gin(m, s, v); EXPECT_TRUE(can_describe(metas0, in_run_args0)); auto in_run_args01 = cv::gin(m, s); EXPECT_FALSE(can_describe(metas0, in_run_args01)); } TEST(GMetaArg, Can_Describe_RunArgP) { cv::Mat m(3, 3, CV_8UC3); cv::UMat um(3, 3, CV_8UC3); cv::Scalar s; constexpr int w = 3, h = 3, c = 3; uchar data[w*h*c]; cv::gapi::own::Mat om(h, w, CV_8UC3, data); cv::Scalar os; std::vector v; GMetaArgs metas = {GMetaArg(descr_of(m)), GMetaArg(descr_of(um)), GMetaArg(descr_of(s)), GMetaArg(descr_of(om)), GMetaArg(descr_of(os)), GMetaArg(descr_of(v))}; auto out_run_args = cv::gout(m, um, s, om, os, v); for (int i = 0; i < 3; i++) { EXPECT_TRUE(can_describe(metas[i], out_run_args[i])); } } } // namespace opencv_test