Skip to content

Commit

Permalink
Add Jason's tests to repository
Browse files Browse the repository at this point in the history
Co-authored-by: Jason Cohen <[email protected]>
  • Loading branch information
evanramos-nvidia and jcohen-nvidia committed Jul 3, 2024
1 parent ec62091 commit 6957108
Show file tree
Hide file tree
Showing 30 changed files with 4,255 additions and 0 deletions.
1 change: 1 addition & 0 deletions tests/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
/build
204 changes: 204 additions & 0 deletions tests/Attributes.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,204 @@
#include <nvtx3/nvtx3.hpp>
// Include again to catch bad guards
#include <nvtx3/nvtx3.hpp>

#include <iostream>
#include <string>

#include "PrettyPrintersNvtxCpp.h"

struct a_lib
{
static constexpr const char* name{"Library A"};
};

#include "DllHelper.h"

extern "C" DLL_EXPORT
int RunTest(int argc, const char** argv)
{
(void)argc;
(void)argv;

{
std::cout << "Default attributes:\n";
nvtx3::event_attributes attr;
std::cout << attr;
}
std::cout << "-------------------------------------\n";

{
std::cout << "Set a payload:\n";
nvtx3::event_attributes attr{nvtx3::payload{5.0f}};
std::cout << attr;
}
std::cout << "-------------------------------------\n";

{
std::cout << "Set a color with RGB hex code 0xFF7F00:\n";
nvtx3::event_attributes attr{nvtx3::color{0xFFFF7F00}};
std::cout << attr;
}
std::cout << "-------------------------------------\n";


{
std::cout << "Set a color with RGB=255,127,0:\n";
nvtx3::event_attributes attr{nvtx3::rgb{255,127,0}};
std::cout << attr;
}
std::cout << "-------------------------------------\n";


{
std::cout << "Set a color & payload:\n";
nvtx3::event_attributes attr{nvtx3::rgb{255,127,0}, nvtx3::payload{5.0f}};
std::cout << attr;
}
std::cout << "-------------------------------------\n";

{
std::cout << "Set a color (red), payload, color again (green)... first color wins:\n";

nvtx3::event_attributes attr{
nvtx3::rgb{255,0,0},
nvtx3::payload{5.0f},
nvtx3::rgb{0, 255, 0}};

std::cout << attr;
}
std::cout << "-------------------------------------\n";

{
std::cout << "Set a message (ascii), payload, color, and category:\n";

nvtx3::event_attributes attr{
nvtx3::message{"Hello"},
nvtx3::category{11},
nvtx3::payload{5.0f},
nvtx3::rgb{0,255,0}};

std::cout << attr;
}
std::cout << "-------------------------------------\n";

{
std::cout << "Set a message with different string types:\n";

nvtx3::event_attributes a{nvtx3::message{"Hello"}};
std::cout << a;

nvtx3::event_attributes wa{nvtx3::message{L"Hello"}};
std::cout << wa;

std::string hello{"Hello"};
nvtx3::event_attributes b{nvtx3::message{hello}};
std::cout << b;

std::wstring whello{L"Hello"};
nvtx3::event_attributes wb{nvtx3::message{whello}};
std::cout << wb;

// Important! Neither of following will compile:
//
// nvtx3::event_attributes c{nvtx3::message{std::string{"foo"}}};
// std::cout << c;
//
// std::string foo{"foo"};
// nvtx3::event_attributes d{nvtx3::message{hello + "bar"}};
// std::cout << d;
//
// Both of those usages fail with:
// "error C2280: 'nvtx3::message::message(std::string &&)':
// attempting to reference a deleted function"
//
// nvtx3::message is a "view" class, not an owning class.
// It cannot take ownership of a temporary string and
// destroy it when it goes out of scope. Similarly,
// nvtx3::event_attributes is not an owning class, so it cannot take
// ownership of an nvtx3::message either.
//
// TODO: Could we add implicit support for this?
}
std::cout << "-------------------------------------\n";

{
std::cout << "Set a message (registered):\n";
auto hTacobell = reinterpret_cast<nvtxStringHandle_t>(0x7ac0be11);
nvtx3::event_attributes attr{nvtx3::message{hTacobell}};
std::cout << attr;
}
std::cout << "-------------------------------------\n";

{
std::cout << "Set category/message/payload/color, with \"using\":\n";

using namespace nvtx3;

event_attributes a{
category{11},
message{"Hello"},
payload{5.0f},
rgb{1,2,3}};

std::cout << a;
}
std::cout << "-------------------------------------\n";

{
std::cout << "Convenience: Set a message without the helper type:\n";

nvtx3::event_attributes a{"Hello"};
std::cout << a;

std::string hello{"Hello"};
nvtx3::event_attributes b{hello};
std::cout << b;
}
std::cout << "-------------------------------------\n";

{
std::cout << "Examples: \"using\", skip helper type for msg, set other fields:\n";

using namespace nvtx3;

event_attributes a{"Hello", payload{7.0}};
std::cout << a;

event_attributes b{"Hello", rgb{255,255,0}};
std::cout << b;

event_attributes c{"Hello", category{4}};
std::cout << c;

// Order doesn't matter
event_attributes d{"Hello", rgb{255,255,0}, payload{7.0}, category{4}};
std::cout << d;

event_attributes e{payload{7.0}, "Hello", category{4}, rgb{255,255,0}};
std::cout << e;

event_attributes f{category{4}, rgb{255,255,0}, payload{7.0}, "Hello"};
std::cout << f;

// Vertical formatting is nice too:
event_attributes g{
"Hello",
category{4},
rgb{255,255,0},
payload{7.0}};
std::cout << g;

event_attributes h
{
"Hello",
category{4},
rgb{255,255,0},
payload{7.0}
};
std::cout << h;
}
std::cout << "-------------------------------------\n";

return 0;
}
138 changes: 138 additions & 0 deletions tests/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,138 @@
cmake_minimum_required (VERSION 3.19)

project ("NvtxTests" LANGUAGES C CXX CUDA)

# Enforce standard C/C++ with sensible warnings and minimal compiler output on all platforms
set(CMAKE_C_STANDARD 90)
set(CMAKE_C_EXTENSIONS OFF)
set(CMAKE_CXX_STANDARD 11)
set(CMAKE_CXX_EXTENSIONS OFF)
if(${MSVC})
# Must use - instead of / for option prefix when using NVCC, because it forwards args
# it doesn't know to the host compiler, but being a UNIX-heritage program, it thinks
# an argument like "/nologo" is an input file path. Luckily, MSVC accepts - prefixes.
if(${CMAKE_C_COMPILER_VERSION} VERSION_LESS "19.14.0.0")
# Enable options to behave closer to standard
else()
add_compile_options(-permissive-)
endif()
# The following line can be uncommented to test with WIN32_LEAN_AND_MEAN
#add_compile_definitions(WIN32_LEAN_AND_MEAN)
endif()

# Build with minimal or no dependencies on installed C/C++ runtime libraries
if (${MSVC})
# For Non-debug, change /MD (MultiThreadedDLL) to /MT (MultiThreaded)
# For Debug, change /MDd (MultiThreadedDebugDLL) to /MTd ((MultiThreadedDebug)
set(CMAKE_MSVC_RUNTIME_LIBRARY "MultiThreaded$<$<CONFIG:Debug>:Debug>")
else()
# Statically link libstdc++ and libgcc. Do not statically link libc, though.
# Use an old sysroot if compatibility with old GLIBC versions is required.
# In non-DEBUG builds, use -s to strip unneeded symbols
add_link_options(
-static-libstdc++
-static-libgcc
$<$<NOT:$<CONFIG:DEBUG>>:-s>
)
endif()

# Compiler-specific idiosyncracies
if(${MSVC})
# Must use - instead of / for option prefix when using NVCC, because it forwards args
# it doesn't know to the host compiler, but being a UNIX-heritage program, it thinks
# an argument like "/nologo" is an input file path. Luckily, MSVC accepts - prefixes.
add_compile_options(-nologo)
#add_compile_options(-wd26812) # Disable warning: prefer enum class over unscoped enum
add_link_options(-NOLOGO -INCREMENTAL:NO)
# On some platforms, CMake doesn't automatically add C++ flags to enable RTTI (/GR) or
# configure C++ exceptions to the commonly preferred value (/EHsc or /GX). Add these
# if they are missing.
if(NOT CMAKE_CXX_FLAGS MATCHES "(/|-)GR( |$)")
string(APPEND CMAKE_CXX_FLAGS " -GR")
endif()
if(NOT CMAKE_CXX_FLAGS MATCHES "(/|-)(EHsc|GX)( |$)")
string(APPEND CMAKE_CXX_FLAGS " -EHsc")
endif()
# Improve debugging
if (${CMAKE_BUILD_TYPE} STREQUAL "Debug")
# This for some reason also adds "MDd" even though above we asked for MTd,
# so add the /JMC option manually
#set(CMAKE_VS_JUST_MY_CODE_DEBUGGING ON)
add_compile_options(-JMC)
endif()
else()
# Stop compiling immediately after first error
add_compile_options(-Wfatal-errors)
# Check for initializing unions without required braces
add_compile_options(-Wmissing-braces)
endif()


add_subdirectory("../c" "ImportNvtx")

#if(${DOMAINS_ERROR_TEST_NAME_IS_MISSING})
# target_compile_definitions(domains PRIVATE ERROR_TEST_NAME_IS_MISSING)
#endif()

add_executable(runtest "RunTest.cpp")
target_link_libraries(runtest PRIVATE nvtx3-cpp)

add_library(inj SHARED "PrintInjection.cpp")
target_link_libraries(inj PRIVATE nvtx3-cpp)
set_target_properties(inj PROPERTIES C_VISIBILITY_PRESET hidden CXX_VISIBILITY_PRESET hidden)

add_library(self SHARED "TestSelfInjection.cpp" "SelfInjection.cpp")
target_link_libraries(self PRIVATE nvtx3-cpp)
set_target_properties(self PROPERTIES C_VISIBILITY_PRESET hidden CXX_VISIBILITY_PRESET hidden)

add_library(calls SHARED "Calls.cpp" "SelfInjection.cpp")
target_link_libraries(calls PRIVATE nvtx3-cpp)
set_target_properties(calls PROPERTIES C_VISIBILITY_PRESET hidden CXX_VISIBILITY_PRESET hidden)

add_library(coverage SHARED "Coverage.cpp")
target_link_libraries(coverage PRIVATE nvtx3-cpp)
set_target_properties(coverage PROPERTIES C_VISIBILITY_PRESET hidden CXX_VISIBILITY_PRESET hidden)

add_library(coveragec SHARED "CoverageC.c")
target_link_libraries(coveragec PRIVATE nvtx3-c)
set_target_properties(coveragec PROPERTIES C_VISIBILITY_PRESET hidden CXX_VISIBILITY_PRESET hidden)

add_library(coverage-cu SHARED "CoverageCuda.cu")
target_link_libraries(coverage-cu PRIVATE nvtx3-cpp)
set_target_properties(coverage-cu PROPERTIES C_VISIBILITY_PRESET hidden CXX_VISIBILITY_PRESET hidden)

add_library(coverage-mem SHARED "CoverageMem.c")
target_link_libraries(coverage-mem PRIVATE nvtx3-c)
set_target_properties(coverage-mem PROPERTIES C_VISIBILITY_PRESET hidden CXX_VISIBILITY_PRESET hidden)

add_library(coverage-memcudart SHARED "CoverageMemCudaRt.cu")
target_link_libraries(coverage-memcudart PRIVATE nvtx3-c)
set_target_properties(coverage-memcudart PROPERTIES C_VISIBILITY_PRESET hidden CXX_VISIBILITY_PRESET hidden)

add_library(coverage-payload SHARED "CoveragePayload.c")
target_link_libraries(coverage-payload PRIVATE nvtx3-c)
set_target_properties(coverage-payload PROPERTIES C_VISIBILITY_PRESET hidden CXX_VISIBILITY_PRESET hidden)

add_library(coverage-counter SHARED "CoverageCounter.c")
target_link_libraries(coverage-counter PRIVATE nvtx3-c)
set_target_properties(coverage-counter PROPERTIES C_VISIBILITY_PRESET hidden CXX_VISIBILITY_PRESET hidden)

add_library(attributes SHARED "Attributes.cpp")
target_link_libraries(attributes PRIVATE nvtx3-cpp)
set_target_properties(attributes PROPERTIES C_VISIBILITY_PRESET hidden CXX_VISIBILITY_PRESET hidden)

add_library(domains SHARED "Domains.cpp")
target_link_libraries(domains PRIVATE nvtx3-cpp)
set_target_properties(domains PROPERTIES C_VISIBILITY_PRESET hidden CXX_VISIBILITY_PRESET hidden)

add_library(categories SHARED "NamedCategories.cpp")
target_link_libraries(categories PRIVATE nvtx3-cpp)
set_target_properties(categories PROPERTIES C_VISIBILITY_PRESET hidden CXX_VISIBILITY_PRESET hidden)

add_library(regstrings SHARED "RegisteredStrings.cpp")
target_link_libraries(regstrings PRIVATE nvtx3-cpp)
set_target_properties(regstrings PROPERTIES C_VISIBILITY_PRESET hidden CXX_VISIBILITY_PRESET hidden)

add_library(linkerdupes SHARED "LinkerDupesMain.cpp" "LinkerDupesFileA.cpp" "LinkerDupesFileB.cpp")
target_link_libraries(linkerdupes PRIVATE nvtx3-cpp)
set_target_properties(linkerdupes PROPERTIES C_VISIBILITY_PRESET hidden CXX_VISIBILITY_PRESET hidden)
40 changes: 40 additions & 0 deletions tests/CMakeSettings.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
{
"configurations": [
{
"name": "x64-Debug",
"generator": "Ninja",
"configurationType": "Debug",
"inheritEnvironments": [ "msvc_x64_x64" ],
"buildRoot": "${projectDir}\\out\\build\\${name}",
"installRoot": "${projectDir}\\out\\install\\${name}",
"cmakeCommandArgs": "",
"buildCommandArgs": "-v",
"ctestCommandArgs": ""
},
{
"name": "x64-Release",
"generator": "Ninja",
"configurationType": "RelWithDebInfo",
"buildRoot": "${projectDir}\\out\\build\\${name}",
"installRoot": "${projectDir}\\out\\install\\${name}",
"cmakeCommandArgs": "",
"buildCommandArgs": "-v",
"ctestCommandArgs": "",
"inheritEnvironments": [ "msvc_x64_x64" ]
},
{
"name": "WSL-GCC-Debug",
"generator": "Ninja",
"configurationType": "Debug",
"buildRoot": "${projectDir}\\out\\build\\${name}",
"installRoot": "${projectDir}\\out\\install\\${name}",
"cmakeExecutable": "cmake",
"cmakeCommandArgs": "",
"buildCommandArgs": "",
"ctestCommandArgs": "",
"inheritEnvironments": [ "linux_x64" ],
"wslPath": "${defaultWSLPath}",
"variables": []
}
]
}
Loading

0 comments on commit 6957108

Please sign in to comment.