mirror of
https://github.com/NVIDIA/nvbench.git
synced 2026-04-25 09:18:53 +00:00
Replace params class with nvbench::named_values.
Refactor nvbench::state to use this for axis parameters. These will also be useful for summaries and measurements. Also adds a new ASSERT_THROWS_ANY macro to test some of the new API.
This commit is contained in:
94
testing/named_values.cu
Normal file
94
testing/named_values.cu
Normal file
@@ -0,0 +1,94 @@
|
||||
#include <nvbench/named_values.cuh>
|
||||
|
||||
#include "test_asserts.cuh"
|
||||
|
||||
#include <algorithm>
|
||||
|
||||
void test_empty()
|
||||
{
|
||||
nvbench::named_values vals;
|
||||
ASSERT(vals.get_size() == 0);
|
||||
ASSERT(vals.get_names().size() == 0);
|
||||
ASSERT(vals.has_value("Nope") == false);
|
||||
ASSERT_THROWS_ANY([[maybe_unused]] auto val = vals.get_value("Nope"));
|
||||
ASSERT_THROWS_ANY([[maybe_unused]] auto type = vals.get_type("Nope"));
|
||||
// Removing non-existent entries shouldn't cause a problem:
|
||||
vals.remove_value("Nope");
|
||||
}
|
||||
|
||||
void test_basic()
|
||||
{
|
||||
auto sort = [](auto &&vec) {
|
||||
std::sort(vec.begin(), vec.end());
|
||||
return std::forward<decltype(vec)>(vec);
|
||||
};
|
||||
|
||||
nvbench::named_values vals;
|
||||
vals.set_int64("Int", 32);
|
||||
vals.set_float64("Float", 34.5);
|
||||
vals.set_string("String", "string!");
|
||||
vals.set_value("IntVar", nvbench::named_values::value_type{36ll});
|
||||
|
||||
std::vector<std::string> names{"Float", "Int", "IntVar", "String"};
|
||||
|
||||
ASSERT(vals.get_size() == 4);
|
||||
ASSERT(sort(vals.get_names()) == names);
|
||||
|
||||
ASSERT(vals.has_value("Float"));
|
||||
ASSERT(vals.has_value("Int"));
|
||||
ASSERT(vals.has_value("IntVar"));
|
||||
ASSERT(vals.has_value("String"));
|
||||
|
||||
ASSERT(std::get<nvbench::float64_t>(vals.get_value("Float")) == 34.5);
|
||||
ASSERT(std::get<nvbench::int64_t>(vals.get_value("Int")) == 32);
|
||||
ASSERT(std::get<nvbench::int64_t>(vals.get_value("IntVar")) == 36);
|
||||
ASSERT(std::get<std::string>(vals.get_value("String")) == "string!");
|
||||
|
||||
ASSERT(vals.get_type("Float") == nvbench::named_values::type::float64);
|
||||
ASSERT(vals.get_type("Int") == nvbench::named_values::type::int64);
|
||||
ASSERT(vals.get_type("IntVar") == nvbench::named_values::type::int64);
|
||||
ASSERT(vals.get_type("String") == nvbench::named_values::type::string);
|
||||
|
||||
ASSERT(vals.get_int64("Int") == 32);
|
||||
ASSERT(vals.get_int64("IntVar") == 36);
|
||||
ASSERT_THROWS_ANY([[maybe_unused]] auto v = vals.get_int64("Float"));
|
||||
ASSERT_THROWS_ANY([[maybe_unused]] auto v = vals.get_int64("String"));
|
||||
|
||||
ASSERT(vals.get_float64("Float") == 34.5);
|
||||
ASSERT_THROWS_ANY([[maybe_unused]] auto v = vals.get_float64("Int"));
|
||||
ASSERT_THROWS_ANY([[maybe_unused]] auto v = vals.get_float64("IntVar"));
|
||||
ASSERT_THROWS_ANY([[maybe_unused]] auto v = vals.get_float64("String"));
|
||||
|
||||
ASSERT(vals.get_string("String") == "string!");
|
||||
ASSERT_THROWS_ANY([[maybe_unused]] auto v = vals.get_string("Int"));
|
||||
ASSERT_THROWS_ANY([[maybe_unused]] auto v = vals.get_string("IntVar"));
|
||||
ASSERT_THROWS_ANY([[maybe_unused]] auto v = vals.get_string("Float"));
|
||||
|
||||
vals.remove_value("IntVar");
|
||||
names = {"Float", "Int", "String"};
|
||||
|
||||
ASSERT(vals.get_size() == 3);
|
||||
ASSERT(sort(vals.get_names()) == names);
|
||||
|
||||
ASSERT(!vals.has_value("IntVar"));
|
||||
ASSERT(vals.has_value("Float"));
|
||||
ASSERT(vals.has_value("Int"));
|
||||
ASSERT(vals.has_value("String"));
|
||||
|
||||
vals.clear();
|
||||
names = {};
|
||||
|
||||
ASSERT(vals.get_size() == 0);
|
||||
ASSERT(sort(vals.get_names()) == names);
|
||||
|
||||
ASSERT(!vals.has_value("IntVar"));
|
||||
ASSERT(!vals.has_value("Float"));
|
||||
ASSERT(!vals.has_value("Int"));
|
||||
ASSERT(!vals.has_value("String"));
|
||||
}
|
||||
|
||||
int main()
|
||||
{
|
||||
test_empty();
|
||||
test_basic();
|
||||
}
|
||||
Reference in New Issue
Block a user