blob: 17c2f97c5a5689fb91454fb832e8b7414883a3a4 [file] [log] [blame]
/*
* Copyright (c) 2015-2023 The Khronos Group Inc.
* Copyright (c) 2015-2023 Valve Corporation
* Copyright (c) 2015-2023 LunarG, Inc.
* Copyright (c) 2015-2023 Google, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*/
#include "../framework/layer_validation_tests.h"
#include "generated/vk_extension_helper.h"
TEST_F(PositiveTooling, BasicUsage) {
TEST_DESCRIPTION("Call Tooling Extension and verify layer results");
RETURN_IF_SKIP(InitFramework())
RETURN_IF_SKIP(InitState())
if (IsPlatformMockICD()) {
GTEST_SKIP() << "Test not supported by MockICD";
}
auto fpGetPhysicalDeviceToolPropertiesEXT =
(PFN_vkGetPhysicalDeviceToolPropertiesEXT)vk::GetInstanceProcAddr(instance(), "vkGetPhysicalDeviceToolPropertiesEXT");
uint32_t tool_count = 0;
auto result = fpGetPhysicalDeviceToolPropertiesEXT(gpu(), &tool_count, nullptr);
if (tool_count <= 0) {
m_errorMonitor->SetError("Expected layer tooling data but received none");
}
std::vector<VkPhysicalDeviceToolPropertiesEXT> tool_properties(tool_count);
for (uint32_t i = 0; i < tool_count; i++) {
tool_properties[i] = vku::InitStructHelper();
}
bool found_validation_layer = false;
if (result == VK_SUCCESS) {
result = fpGetPhysicalDeviceToolPropertiesEXT(gpu(), &tool_count, tool_properties.data());
for (uint32_t i = 0; i < tool_count; i++) {
if (strcmp(tool_properties[0].name, "Khronos Validation Layer") == 0) {
found_validation_layer = true;
break;
}
}
}
if (!found_validation_layer) {
m_errorMonitor->SetError("Expected layer tooling data but received none");
}
}