720 lines
65 KiB
C++
720 lines
65 KiB
C++
/*
|
|
* Copyright (C) 2021-2022 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: MIT
|
|
*
|
|
*/
|
|
|
|
#pragma once
|
|
#include "shared/source/helpers/hw_info.h"
|
|
#include "shared/test/common/test_macros/hw_test_base.h"
|
|
#include "shared/test/common/test_macros/test.h"
|
|
|
|
#include "gtest/gtest.h"
|
|
#include "hw_cmds.h"
|
|
#include "igfxfmid.h"
|
|
#include "per_product_test_selector.h"
|
|
#include "test_mode.h"
|
|
|
|
// Macros to provide template based testing.
|
|
// Test can use FamilyType in the test -- equivalent to Gen9Family
|
|
#define HWTEST_TEST_(test_suite_name, test_name, parent_class, parent_id, SetUpT_name, TearDownT_name) \
|
|
CHECK_TEST_NAME_LENGTH(test_suite_name, test_name) \
|
|
\
|
|
class GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) : public parent_class { \
|
|
\
|
|
public: \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) \
|
|
() {} \
|
|
\
|
|
private: \
|
|
template <typename FamilyType> \
|
|
void testBodyHw(); \
|
|
template <typename T> \
|
|
void emptyFcn() {} \
|
|
void SetUp() override { \
|
|
if (IS_TEST_EXCLUDED(test_suite_name, test_name)) { \
|
|
GTEST_SKIP(); \
|
|
} \
|
|
parent_class::SetUp(); \
|
|
FAMILY_SELECTOR(::renderCoreFamily, SetUpT_name); \
|
|
} \
|
|
void TearDown() override { \
|
|
if (!IS_TEST_EXCLUDED(test_suite_name, test_name)) { \
|
|
FAMILY_SELECTOR(::renderCoreFamily, TearDownT_name) \
|
|
parent_class::TearDown(); \
|
|
} \
|
|
} \
|
|
\
|
|
void TestBody() override { \
|
|
if (!IS_TEST_EXCLUDED(test_suite_name, test_name)) { \
|
|
FAMILY_SELECTOR(::renderCoreFamily, testBodyHw) \
|
|
} \
|
|
} \
|
|
static ::testing::TestInfo *const test_info_ GTEST_ATTRIBUTE_UNUSED_; \
|
|
GTEST_DISALLOW_COPY_AND_ASSIGN_( \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)); \
|
|
}; \
|
|
\
|
|
::testing::TestInfo *const GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::test_info_ = \
|
|
::testing::internal::MakeAndRegisterTestInfo( \
|
|
#test_suite_name, #test_name, nullptr, nullptr, \
|
|
::testing::internal::CodeLocation(__FILE__, __LINE__), (parent_id), \
|
|
::testing::internal::SuiteApiResolver< \
|
|
parent_class>::GetSetUpCaseOrSuite(), \
|
|
::testing::internal::SuiteApiResolver< \
|
|
parent_class>::GetTearDownCaseOrSuite(), \
|
|
new ::testing::internal::TestFactoryImpl<GTEST_TEST_CLASS_NAME_( \
|
|
test_suite_name, test_name)>); \
|
|
template <typename FamilyType> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::testBodyHw()
|
|
|
|
#define HWTEST_F(test_fixture, test_name) \
|
|
HWTEST_TEST_(test_fixture, test_name, test_fixture, \
|
|
::testing::internal::GetTypeId<test_fixture>(), emptyFcn, emptyFcn)
|
|
|
|
// Macros to provide template based testing.
|
|
// Test can use productFamily, gfxCoreFamily and FamilyType in the test
|
|
#define HWTEST2_TEST_(test_suite_name, test_name, parent_class, parent_id, test_matcher) \
|
|
CHECK_TEST_NAME_LENGTH(test_suite_name, test_name) \
|
|
\
|
|
class GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) : public parent_class { \
|
|
\
|
|
public: \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) \
|
|
() {} \
|
|
\
|
|
private: \
|
|
using ContainerType = SupportedProductFamilies; \
|
|
using MatcherType = test_matcher; \
|
|
\
|
|
template <PRODUCT_FAMILY productFamily, GFXCORE_FAMILY gfxCoreFamily, typename FamilyType> \
|
|
void matchBody(); \
|
|
\
|
|
template <PRODUCT_FAMILY productFamily> \
|
|
void matched() { \
|
|
const GFXCORE_FAMILY gfxCoreFamily = \
|
|
static_cast<GFXCORE_FAMILY>(NEO::HwMapper<productFamily>::gfxFamily); \
|
|
using FamilyType = typename NEO::GfxFamilyMapper<gfxCoreFamily>::GfxFamily; \
|
|
matchBody<productFamily, gfxCoreFamily, FamilyType>(); \
|
|
} \
|
|
\
|
|
struct MatcherFalse { \
|
|
template <PRODUCT_FAMILY productFamily> \
|
|
static void matched() {} \
|
|
}; \
|
|
\
|
|
template <unsigned int matcherOrdinal> \
|
|
void checkForMatch(PRODUCT_FAMILY matchProduct); \
|
|
\
|
|
template <unsigned int matcherOrdinal> \
|
|
bool checkMatch(PRODUCT_FAMILY matchProduct); \
|
|
\
|
|
void SetUp() override; \
|
|
void TearDown() override; \
|
|
void TestBody() override; \
|
|
\
|
|
static ::testing::TestInfo *const test_info_ GTEST_ATTRIBUTE_UNUSED_; \
|
|
GTEST_DISALLOW_COPY_AND_ASSIGN_(GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)); \
|
|
}; \
|
|
\
|
|
::testing::TestInfo *const GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::test_info_ = \
|
|
::testing::internal::MakeAndRegisterTestInfo( \
|
|
#test_suite_name, #test_name, nullptr, nullptr, \
|
|
::testing::internal::CodeLocation(__FILE__, __LINE__), (parent_id), \
|
|
::testing::internal::SuiteApiResolver<parent_class>::GetSetUpCaseOrSuite(), \
|
|
::testing::internal::SuiteApiResolver<parent_class>::GetTearDownCaseOrSuite(), \
|
|
new ::testing::internal::TestFactoryImpl<GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)>); \
|
|
\
|
|
template <unsigned int matcherOrdinal> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::checkForMatch(PRODUCT_FAMILY matchProduct) { \
|
|
const PRODUCT_FAMILY productFamily = At<ContainerType, matcherOrdinal>::productFamily; \
|
|
\
|
|
if (matchProduct == productFamily) { \
|
|
const bool isMatched = MatcherType::isMatched<productFamily>(); \
|
|
using Matcher = \
|
|
typename std::conditional<isMatched, \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name), \
|
|
MatcherFalse>::type; \
|
|
Matcher::template matched<productFamily>(); \
|
|
} else { \
|
|
checkForMatch<matcherOrdinal - 1u>(matchProduct); \
|
|
} \
|
|
} \
|
|
\
|
|
template <> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::checkForMatch<0u>(PRODUCT_FAMILY matchProduct) { \
|
|
const int matcherOrdinal = 0u; \
|
|
const PRODUCT_FAMILY productFamily = At<ContainerType, matcherOrdinal>::productFamily; \
|
|
\
|
|
if (matchProduct == productFamily) { \
|
|
const bool isMatched = MatcherType::isMatched<productFamily>(); \
|
|
using Matcher = \
|
|
typename std::conditional<isMatched, \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name), \
|
|
MatcherFalse>::type; \
|
|
Matcher::template matched<productFamily>(); \
|
|
} \
|
|
} \
|
|
template <unsigned int matcherOrdinal> \
|
|
bool GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::checkMatch(PRODUCT_FAMILY matchProduct) { \
|
|
const PRODUCT_FAMILY productFamily = At<ContainerType, matcherOrdinal>::productFamily; \
|
|
\
|
|
if (matchProduct == productFamily) { \
|
|
const bool isMatched = MatcherType::isMatched<productFamily>(); \
|
|
return isMatched; \
|
|
} else { \
|
|
return checkMatch<matcherOrdinal - 1u>(matchProduct); \
|
|
} \
|
|
} \
|
|
\
|
|
template <> \
|
|
bool GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::checkMatch<0>(PRODUCT_FAMILY matchProduct) { \
|
|
const int matcherOrdinal = 0u; \
|
|
const PRODUCT_FAMILY productFamily = At<ContainerType, matcherOrdinal>::productFamily; \
|
|
\
|
|
if (matchProduct == productFamily) { \
|
|
const bool isMatched = MatcherType::isMatched<productFamily>(); \
|
|
return isMatched; \
|
|
} else { \
|
|
return false; \
|
|
} \
|
|
} \
|
|
\
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::SetUp() { \
|
|
if (IS_TEST_EXCLUDED(test_suite_name, test_name)) { \
|
|
GTEST_SKIP(); \
|
|
} \
|
|
if (checkMatch<SupportedProductFamilies::size - 1u>(::productFamily)) { \
|
|
parent_class::SetUp(); \
|
|
} \
|
|
} \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::TearDown() { \
|
|
if (!IS_TEST_EXCLUDED(test_suite_name, test_name)) { \
|
|
if (checkMatch<SupportedProductFamilies::size - 1u>(::productFamily)) { \
|
|
parent_class::TearDown(); \
|
|
} \
|
|
} \
|
|
} \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::TestBody() { \
|
|
if (!IS_TEST_EXCLUDED(test_suite_name, test_name)) { \
|
|
checkForMatch<SupportedProductFamilies::size - 1u>(::productFamily); \
|
|
} \
|
|
} \
|
|
\
|
|
template <PRODUCT_FAMILY productFamily, GFXCORE_FAMILY gfxCoreFamily, typename FamilyType> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::matchBody()
|
|
|
|
#define HWTEST2_F(test_fixture, test_name, test_matcher) \
|
|
HWTEST2_TEST_(test_fixture, test_name##_##test_matcher, test_fixture, \
|
|
::testing::internal::GetTypeId<test_fixture>(), test_matcher)
|
|
|
|
#define HWTEST_TEMPLATED_F(test_fixture, test_name) \
|
|
HWTEST_TEST_(test_fixture, test_name, test_fixture, \
|
|
::testing::internal::GetTypeId<test_fixture>(), setUpT, tearDownT)
|
|
|
|
// Macros to provide template based testing.
|
|
// Test can use FamilyType in the test -- equivalent to Gen9Family
|
|
#define HWCMDTEST_TEST_(cmdset_gen_base, test_suite_name, test_name, parent_class, parent_id) \
|
|
CHECK_TEST_NAME_LENGTH(test_suite_name, test_name) \
|
|
\
|
|
class GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) : public parent_class { \
|
|
public: \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) \
|
|
() {} \
|
|
\
|
|
private: \
|
|
template <typename FamilyType> \
|
|
void testBodyHw(); \
|
|
\
|
|
template <typename FamilyType, bool ShouldBeTested = FamilyType::supportsCmdSet(cmdset_gen_base)> \
|
|
auto runCmdTestHwIfSupported() -> typename std::enable_if<ShouldBeTested>::type { \
|
|
if (!IS_TEST_EXCLUDED(test_suite_name, test_name)) { \
|
|
testBodyHw<FamilyType>(); \
|
|
} \
|
|
} \
|
|
\
|
|
template <typename FamilyType, bool ShouldBeTested = FamilyType::supportsCmdSet(cmdset_gen_base)> \
|
|
auto runCmdTestHwIfSupported() -> typename std::enable_if<false == ShouldBeTested>::type { \
|
|
/* do nothing */ \
|
|
} \
|
|
\
|
|
void TestBody() override { \
|
|
FAMILY_SELECTOR(::renderCoreFamily, runCmdTestHwIfSupported) \
|
|
} \
|
|
void SetUp() override { \
|
|
if (IS_TEST_EXCLUDED(test_suite_name, test_name)) { \
|
|
GTEST_SKIP(); \
|
|
} \
|
|
CALL_IF_SUPPORTED(cmdset_gen_base, parent_class::SetUp()); \
|
|
} \
|
|
void TearDown() override { \
|
|
if (!IS_TEST_EXCLUDED(test_suite_name, test_name)) { \
|
|
CALL_IF_SUPPORTED(cmdset_gen_base, parent_class::TearDown()); \
|
|
} \
|
|
} \
|
|
static ::testing::TestInfo *const test_info_ GTEST_ATTRIBUTE_UNUSED_; \
|
|
GTEST_DISALLOW_COPY_AND_ASSIGN_( \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)); \
|
|
}; \
|
|
\
|
|
::testing::TestInfo *const GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::test_info_ = \
|
|
::testing::internal::MakeAndRegisterTestInfo( \
|
|
#test_suite_name, #test_name, nullptr, nullptr, \
|
|
::testing::internal::CodeLocation(__FILE__, __LINE__), (parent_id), \
|
|
::testing::internal::SuiteApiResolver< \
|
|
parent_class>::GetSetUpCaseOrSuite(), \
|
|
::testing::internal::SuiteApiResolver< \
|
|
parent_class>::GetTearDownCaseOrSuite(), \
|
|
new ::testing::internal::TestFactoryImpl<GTEST_TEST_CLASS_NAME_( \
|
|
test_suite_name, test_name)>); \
|
|
template <typename FamilyType> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::testBodyHw()
|
|
|
|
#define HWCMDTEST_F(cmdset_gen_base, test_fixture, test_name) \
|
|
HWCMDTEST_TEST_(cmdset_gen_base, test_fixture, test_name, test_fixture, \
|
|
::testing::internal::GetTypeId<test_fixture>())
|
|
|
|
// Equivalent Hw specific macro for permuted tests
|
|
// Test can use FamilyType in the test -- equivalent to Gen9Family
|
|
#define HWTEST_P(test_suite_name, test_name) \
|
|
CHECK_TEST_NAME_LENGTH(test_suite_name, test_name) \
|
|
class GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) : public test_suite_name { \
|
|
public: \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) \
|
|
() {} \
|
|
template <typename FamilyType> \
|
|
void testBodyHw(); \
|
|
\
|
|
void TestBody() override { \
|
|
if (!IS_TEST_EXCLUDED(test_suite_name, test_name)) { \
|
|
FAMILY_SELECTOR(::renderCoreFamily, testBodyHw) \
|
|
} \
|
|
} \
|
|
void SetUp() override { \
|
|
if (IS_TEST_EXCLUDED(test_suite_name, test_name)) { \
|
|
GTEST_SKIP(); \
|
|
} \
|
|
test_suite_name::SetUp(); \
|
|
} \
|
|
void TearDown() override { \
|
|
if (!IS_TEST_EXCLUDED(test_suite_name, test_name)) { \
|
|
test_suite_name::TearDown(); \
|
|
} \
|
|
} \
|
|
\
|
|
private: \
|
|
static int AddToRegistry() { \
|
|
::testing::UnitTest::GetInstance()->parameterized_test_registry().GetTestCasePatternHolder<test_suite_name>( \
|
|
#test_suite_name, ::testing::internal::CodeLocation(__FILE__, __LINE__)) \
|
|
->AddTestPattern( \
|
|
#test_suite_name, \
|
|
#test_name, \
|
|
new ::testing::internal::TestMetaFactory< \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)>()); \
|
|
return 0; \
|
|
} \
|
|
static int gtest_registering_dummy_; \
|
|
GTEST_DISALLOW_COPY_AND_ASSIGN_( \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)); \
|
|
}; \
|
|
int GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::gtest_registering_dummy_ = \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::AddToRegistry(); \
|
|
template <typename FamilyType> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::testBodyHw()
|
|
|
|
#define HWCMDTEST_P(cmdset_gen_base, test_suite_name, test_name) \
|
|
CHECK_TEST_NAME_LENGTH(test_suite_name, test_name) \
|
|
\
|
|
class GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) : public test_suite_name { \
|
|
public: \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) \
|
|
() {} \
|
|
\
|
|
template <typename FamilyType> \
|
|
void testBodyHw(); \
|
|
\
|
|
template <typename FamilyType, bool ShouldBeTested = FamilyType::supportsCmdSet(cmdset_gen_base)> \
|
|
auto runCmdTestHwIfSupported() -> typename std::enable_if<ShouldBeTested>::type { \
|
|
testBodyHw<FamilyType>(); \
|
|
} \
|
|
\
|
|
template <typename FamilyType, bool ShouldBeTested = FamilyType::supportsCmdSet(cmdset_gen_base)> \
|
|
auto runCmdTestHwIfSupported() -> typename std::enable_if<false == ShouldBeTested>::type { \
|
|
/* do nothing */ \
|
|
} \
|
|
\
|
|
void TestBody() override { \
|
|
if (!IS_TEST_EXCLUDED(test_suite_name, test_name)) { \
|
|
FAMILY_SELECTOR(::renderCoreFamily, runCmdTestHwIfSupported) \
|
|
} \
|
|
} \
|
|
void SetUp() override { \
|
|
if (IS_TEST_EXCLUDED(test_suite_name, test_name)) { \
|
|
GTEST_SKIP(); \
|
|
} \
|
|
CALL_IF_SUPPORTED(cmdset_gen_base, test_suite_name::SetUp()); \
|
|
} \
|
|
void TearDown() override { \
|
|
if (!IS_TEST_EXCLUDED(test_suite_name, test_name)) { \
|
|
CALL_IF_SUPPORTED(cmdset_gen_base, test_suite_name::TearDown()); \
|
|
} \
|
|
} \
|
|
\
|
|
private: \
|
|
static int AddToRegistry() { \
|
|
::testing::UnitTest::GetInstance()->parameterized_test_registry().GetTestCasePatternHolder<test_suite_name>( \
|
|
#test_suite_name, ::testing::internal::CodeLocation(__FILE__, __LINE__)) \
|
|
->AddTestPattern( \
|
|
#test_suite_name, \
|
|
#test_name, \
|
|
new ::testing::internal::TestMetaFactory< \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)>()); \
|
|
return 0; \
|
|
} \
|
|
static int gtest_registering_dummy_; \
|
|
GTEST_DISALLOW_COPY_AND_ASSIGN_( \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)); \
|
|
}; \
|
|
int GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::gtest_registering_dummy_ = \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::AddToRegistry(); \
|
|
template <typename FamilyType> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::testBodyHw()
|
|
|
|
// Macros to provide template based testing.
|
|
// Test can use productFamily, gfxCoreFamily and FamilyType in the test
|
|
#define HWTEST2_P(test_suite_name, test_name, test_matcher) \
|
|
class GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) : public test_suite_name { \
|
|
\
|
|
public: \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name) \
|
|
() {} \
|
|
\
|
|
template <PRODUCT_FAMILY productFamily, GFXCORE_FAMILY gfxCoreFamily, typename FamilyType> \
|
|
void matchBody(); \
|
|
\
|
|
private: \
|
|
using ContainerType = SupportedProductFamilies; \
|
|
using MatcherType = test_matcher; \
|
|
\
|
|
template <PRODUCT_FAMILY productFamily> \
|
|
void matched() { \
|
|
const GFXCORE_FAMILY gfxCoreFamily = \
|
|
static_cast<GFXCORE_FAMILY>(NEO::HwMapper<productFamily>::gfxFamily); \
|
|
using FamilyType = typename NEO::GfxFamilyMapper<gfxCoreFamily>::GfxFamily; \
|
|
matchBody<productFamily, gfxCoreFamily, FamilyType>(); \
|
|
} \
|
|
\
|
|
struct MatcherFalse { \
|
|
template <PRODUCT_FAMILY productFamily> \
|
|
static void matched() {} \
|
|
}; \
|
|
\
|
|
template <unsigned int matcherOrdinal> \
|
|
void checkForMatch(PRODUCT_FAMILY matchProduct); \
|
|
\
|
|
template <unsigned int matcherOrdinal> \
|
|
bool checkMatch(PRODUCT_FAMILY matchProduct); \
|
|
\
|
|
void SetUp() override; \
|
|
void TearDown() override; \
|
|
\
|
|
void TestBody() override; \
|
|
\
|
|
static int AddToRegistry() { \
|
|
::testing::UnitTest::GetInstance() \
|
|
->parameterized_test_registry() \
|
|
.GetTestCasePatternHolder<test_suite_name>(#test_suite_name, \
|
|
::testing::internal::CodeLocation(__FILE__, __LINE__)) \
|
|
->AddTestPattern(#test_suite_name, #test_name, \
|
|
new ::testing::internal::TestMetaFactory<GTEST_TEST_CLASS_NAME_( \
|
|
test_suite_name, test_name)>()); \
|
|
return 0; \
|
|
} \
|
|
static int gtest_registering_dummy_; \
|
|
GTEST_DISALLOW_COPY_AND_ASSIGN_(GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)); \
|
|
}; \
|
|
\
|
|
template <unsigned int matcherOrdinal> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::checkForMatch(PRODUCT_FAMILY matchProduct) { \
|
|
const PRODUCT_FAMILY productFamily = At<ContainerType, matcherOrdinal>::productFamily; \
|
|
\
|
|
if (matchProduct == productFamily) { \
|
|
const bool isMatched = MatcherType::isMatched<productFamily>(); \
|
|
using Matcher = \
|
|
typename std::conditional<isMatched, \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name), \
|
|
MatcherFalse>::type; \
|
|
Matcher::template matched<productFamily>(); \
|
|
} else { \
|
|
checkForMatch<matcherOrdinal - 1u>(matchProduct); \
|
|
} \
|
|
} \
|
|
\
|
|
template <> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::checkForMatch<0u>(PRODUCT_FAMILY matchProduct) { \
|
|
const int matcherOrdinal = 0u; \
|
|
const PRODUCT_FAMILY productFamily = At<ContainerType, matcherOrdinal>::productFamily; \
|
|
\
|
|
if (matchProduct == productFamily) { \
|
|
const bool isMatched = MatcherType::isMatched<productFamily>(); \
|
|
using Matcher = \
|
|
typename std::conditional<isMatched, \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name), \
|
|
MatcherFalse>::type; \
|
|
Matcher::template matched<productFamily>(); \
|
|
} \
|
|
} \
|
|
template <unsigned int matcherOrdinal> \
|
|
bool GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::checkMatch(PRODUCT_FAMILY matchProduct) { \
|
|
const PRODUCT_FAMILY productFamily = At<ContainerType, matcherOrdinal>::productFamily; \
|
|
\
|
|
if (matchProduct == productFamily) { \
|
|
const bool isMatched = MatcherType::isMatched<productFamily>(); \
|
|
return isMatched; \
|
|
} else { \
|
|
return checkMatch<matcherOrdinal - 1u>(matchProduct); \
|
|
} \
|
|
} \
|
|
\
|
|
template <> \
|
|
bool GTEST_TEST_CLASS_NAME_(test_suite_name, \
|
|
test_name)::checkMatch<0>(PRODUCT_FAMILY matchProduct) { \
|
|
const int matcherOrdinal = 0u; \
|
|
const PRODUCT_FAMILY productFamily = At<ContainerType, matcherOrdinal>::productFamily; \
|
|
\
|
|
if (matchProduct == productFamily) { \
|
|
const bool isMatched = MatcherType::isMatched<productFamily>(); \
|
|
return isMatched; \
|
|
} else { \
|
|
return false; \
|
|
} \
|
|
} \
|
|
\
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::SetUp() { \
|
|
if (IS_TEST_EXCLUDED(test_suite_name, test_name)) { \
|
|
GTEST_SKIP(); \
|
|
} \
|
|
if (checkMatch<SupportedProductFamilies::size - 1u>(::productFamily)) { \
|
|
test_suite_name::SetUp(); \
|
|
} \
|
|
} \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::TearDown() { \
|
|
if (!IS_TEST_EXCLUDED(test_suite_name, test_name)) { \
|
|
if (checkMatch<SupportedProductFamilies::size - 1u>(::productFamily)) { \
|
|
test_suite_name::TearDown(); \
|
|
} \
|
|
} \
|
|
} \
|
|
\
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::TestBody() { \
|
|
if (!IS_TEST_EXCLUDED(test_suite_name, test_name)) { \
|
|
checkForMatch<SupportedProductFamilies::size - 1u>(::productFamily); \
|
|
} \
|
|
} \
|
|
\
|
|
int GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::gtest_registering_dummy_ = \
|
|
GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::AddToRegistry(); \
|
|
template <PRODUCT_FAMILY productFamily, GFXCORE_FAMILY gfxCoreFamily, typename FamilyType> \
|
|
void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::matchBody()
|
|
|
|
#include "per_product_test_definitions.h"
|
|
|
|
#define HWTEST_TYPED_TEST(CaseName, TestName) \
|
|
CHECK_TEST_NAME_LENGTH(CaseName, TestName) \
|
|
template <typename gtest_TypeParam_> \
|
|
class GTEST_TEST_CLASS_NAME_(CaseName, TestName) : public CaseName<gtest_TypeParam_> { \
|
|
private: \
|
|
typedef CaseName<gtest_TypeParam_> TestFixture; \
|
|
typedef gtest_TypeParam_ TypeParam; \
|
|
template <typename FamilyType> \
|
|
void testBodyHw(); \
|
|
\
|
|
void TestBody() override { \
|
|
FAMILY_SELECTOR(::renderCoreFamily, testBodyHw) \
|
|
} \
|
|
}; \
|
|
bool gtest_##CaseName##_##TestName##_registered_ GTEST_ATTRIBUTE_UNUSED_ = \
|
|
::testing::internal::TypeParameterizedTest< \
|
|
CaseName, \
|
|
::testing::internal::TemplateSel< \
|
|
GTEST_TEST_CLASS_NAME_(CaseName, TestName)>, \
|
|
GTEST_TYPE_PARAMS_(CaseName)>::Register("", ::testing::internal::CodeLocation(__FILE__, __LINE__), \
|
|
#CaseName, #TestName, 0); \
|
|
template <typename gtest_TypeParam_> \
|
|
template <typename FamilyType> \
|
|
void GTEST_TEST_CLASS_NAME_(CaseName, TestName)<gtest_TypeParam_>::testBodyHw()
|
|
|
|
template <PRODUCT_FAMILY... args>
|
|
struct SupportedProductFamilyContainer {
|
|
using BaseClass = SupportedProductFamilyContainer<args...>;
|
|
static const PRODUCT_FAMILY productFamily = IGFX_UNKNOWN;
|
|
};
|
|
|
|
template <PRODUCT_FAMILY p, PRODUCT_FAMILY... args>
|
|
struct SupportedProductFamilyContainer<p, args...> : SupportedProductFamilyContainer<args...> {
|
|
using BaseClass = SupportedProductFamilyContainer<args...>;
|
|
|
|
static const PRODUCT_FAMILY productFamily = p;
|
|
static const std::size_t size = sizeof...(args) + 1;
|
|
};
|
|
|
|
using SupportedProductFamilies =
|
|
SupportedProductFamilyContainer<SUPPORTED_TEST_PRODUCT_FAMILIES>;
|
|
|
|
// Static container accessor
|
|
template <typename Container, int index>
|
|
struct At {
|
|
static const PRODUCT_FAMILY productFamily =
|
|
At<typename Container::BaseClass, index - 1>::productFamily;
|
|
};
|
|
|
|
template <typename Container>
|
|
struct At<Container, 0> {
|
|
static const PRODUCT_FAMILY productFamily = Container::productFamily;
|
|
};
|
|
|
|
template <GFXCORE_FAMILY gfxCoreFamily>
|
|
struct IsGfxCore {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() {
|
|
return NEO::ToGfxCoreFamily<productFamily>::get() == gfxCoreFamily;
|
|
}
|
|
};
|
|
|
|
template <GFXCORE_FAMILY gfxCoreFamily>
|
|
struct IsNotGfxCore {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() {
|
|
return NEO::ToGfxCoreFamily<productFamily>::get() != gfxCoreFamily;
|
|
}
|
|
};
|
|
|
|
template <GFXCORE_FAMILY gfxCoreFamily, GFXCORE_FAMILY gfxCoreFamily2>
|
|
struct AreNotGfxCores {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() {
|
|
return NEO::ToGfxCoreFamily<productFamily>::get() != gfxCoreFamily && NEO::ToGfxCoreFamily<productFamily>::get() != gfxCoreFamily2;
|
|
}
|
|
};
|
|
|
|
template <GFXCORE_FAMILY gfxCoreFamily>
|
|
struct IsAtMostGfxCore {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() {
|
|
return NEO::ToGfxCoreFamily<productFamily>::get() <= gfxCoreFamily;
|
|
}
|
|
};
|
|
|
|
template <GFXCORE_FAMILY gfxCoreFamily>
|
|
struct IsBeforeGfxCore {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() {
|
|
return NEO::ToGfxCoreFamily<productFamily>::get() < gfxCoreFamily;
|
|
}
|
|
};
|
|
|
|
template <GFXCORE_FAMILY gfxCoreFamily>
|
|
struct IsAtLeastGfxCore {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() {
|
|
return NEO::ToGfxCoreFamily<productFamily>::get() >= gfxCoreFamily;
|
|
}
|
|
};
|
|
|
|
template <GFXCORE_FAMILY gfxCoreFamilyMin, GFXCORE_FAMILY gfxCoreFamilyMax>
|
|
struct IsWithinGfxCore {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() {
|
|
return NEO::ToGfxCoreFamily<productFamily>::get() >= gfxCoreFamilyMin && NEO::ToGfxCoreFamily<productFamily>::get() <= gfxCoreFamilyMax;
|
|
}
|
|
};
|
|
|
|
template <GFXCORE_FAMILY... args>
|
|
struct IsAnyGfxCores {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() {
|
|
return (... || IsGfxCore<args>::template isMatched<productFamily>());
|
|
}
|
|
};
|
|
|
|
template <GFXCORE_FAMILY... args>
|
|
struct IsNotAnyGfxCores {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() {
|
|
return (... && IsNotGfxCore<args>::template isMatched<productFamily>());
|
|
}
|
|
};
|
|
|
|
template <PRODUCT_FAMILY product>
|
|
struct IsProduct {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() {
|
|
return productFamily == product;
|
|
}
|
|
};
|
|
|
|
template <PRODUCT_FAMILY productFamilyMax>
|
|
struct IsAtMostProduct {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() {
|
|
return productFamily <= productFamilyMax;
|
|
}
|
|
};
|
|
|
|
template <PRODUCT_FAMILY productFamilyMin>
|
|
struct IsAtLeastProduct {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() {
|
|
return productFamily >= productFamilyMin;
|
|
}
|
|
};
|
|
|
|
template <PRODUCT_FAMILY productFamilyMin, PRODUCT_FAMILY productFamilyMax>
|
|
struct IsWithinProducts {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() {
|
|
return productFamily >= productFamilyMin && productFamily <= productFamilyMax;
|
|
}
|
|
};
|
|
|
|
template <PRODUCT_FAMILY productFamilyMin, PRODUCT_FAMILY productFamilyMax>
|
|
struct IsNotWithinProducts {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() {
|
|
return (productFamily < productFamilyMin) || (productFamily > productFamilyMax);
|
|
}
|
|
};
|
|
|
|
template <PRODUCT_FAMILY... args>
|
|
struct IsAnyProducts {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() {
|
|
return (... || IsProduct<args>::template isMatched<productFamily>());
|
|
}
|
|
};
|
|
|
|
struct MatchAny {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() { return true; }
|
|
};
|
|
|
|
struct SupportsSampler {
|
|
template <PRODUCT_FAMILY productFamily>
|
|
static constexpr bool isMatched() {
|
|
return NEO::HwMapper<productFamily>::GfxProduct::supportsSampler;
|
|
}
|
|
};
|
|
|
|
#include "common_matchers.h"
|