Просмотр исходного кода

test: full review of entt::any tests

Michele Caini 2 лет назад
Родитель
Сommit
df6da5c208
1 измененных файлов с 131 добавлено и 126 удалено
  1. 131 126
      test/entt/core/any.cpp

+ 131 - 126
test/entt/core/any.cpp

@@ -1,4 +1,5 @@
 #include <algorithm>
+#include <array>
 #include <cstdint>
 #include <cstring>
 #include <iterator>
@@ -16,50 +17,37 @@
 #include "../common/non_comparable.h"
 #include "../common/non_movable.h"
 
-struct empty {
-    empty() = default;
+template<std::size_t Len>
+struct tracker {
+    tracker(int &cnt)
+        : counter{&cnt} {}
 
-    empty(const empty &) = default;
-    empty &operator=(const empty &) = delete;
+    tracker(const tracker &) = default;
+    tracker &operator=(const tracker &) = delete;
 
-    ~empty() {
-        ++counter;
+    ~tracker() {
+        ++(*counter);
     }
 
-    inline static int counter = 0; // NOLINT
+private:
+    std::array<std::byte, Len> buffer{};
+    int *counter{};
 };
 
 struct fat {
     fat(double v1, double v2, double v3, double v4)
         : value{v1, v2, v3, v4} {}
 
-    fat(const fat &) = default;
-    fat &operator=(const fat &) = default;
-
-    ~fat() {
-        ++counter;
-    }
-
     [[nodiscard]] bool operator==(const fat &other) const {
-        return std::equal(std::begin(value), std::end(value), std::begin(other.value), std::end(other.value));
+        return (value == other.value);
     }
 
-    inline static int counter{0}; // NOLINT
-    double value[4];              // NOLINT
+    std::array<double, 4u> value{};
 };
 
 struct alignas(64u) over_aligned {};
 
-struct Any: ::testing::Test {
-    void SetUp() override {
-        fat::counter = 0;
-        empty::counter = 0;
-    }
-};
-
-using AnyDeathTest = Any;
-
-TEST_F(Any, SBO) {
+TEST(Any, SBO) {
     entt::any any{'c'};
 
     ASSERT_TRUE(any);
@@ -69,7 +57,7 @@ TEST_F(Any, SBO) {
     ASSERT_EQ(entt::any_cast<char>(any), 'c');
 }
 
-TEST_F(Any, NoSBO) {
+TEST(Any, NoSBO) {
     const fat instance{.1, .2, .3, .4};
     entt::any any{instance};
 
@@ -80,7 +68,7 @@ TEST_F(Any, NoSBO) {
     ASSERT_EQ(entt::any_cast<fat>(any), instance);
 }
 
-TEST_F(Any, Empty) {
+TEST(Any, Empty) {
     entt::any any{};
 
     ASSERT_FALSE(any);
@@ -90,7 +78,7 @@ TEST_F(Any, Empty) {
     ASSERT_EQ(any.data(), nullptr);
 }
 
-TEST_F(Any, SBOInPlaceTypeConstruction) {
+TEST(Any, SBOInPlaceTypeConstruction) {
     entt::any any{std::in_place_type<int>, 2};
 
     ASSERT_TRUE(any);
@@ -108,7 +96,7 @@ TEST_F(Any, SBOInPlaceTypeConstruction) {
     ASSERT_EQ(other.data(), any.data());
 }
 
-TEST_F(Any, SBOAsRefConstruction) {
+TEST(Any, SBOAsRefConstruction) {
     int value = 2;
     entt::any any{entt::forward_as_any(value)};
 
@@ -144,7 +132,7 @@ TEST_F(Any, SBOAsRefConstruction) {
     ASSERT_EQ(other.data(), any.data());
 }
 
-TEST_F(Any, SBOAsConstRefConstruction) {
+TEST(Any, SBOAsConstRefConstruction) {
     const int value = 2;
     entt::any any{entt::forward_as_any(value)};
 
@@ -180,7 +168,7 @@ TEST_F(Any, SBOAsConstRefConstruction) {
     ASSERT_EQ(other.data(), any.data());
 }
 
-TEST_F(Any, SBOCopyConstruction) {
+TEST(Any, SBOCopyConstruction) {
     const entt::any any{2};
     entt::any other{any};
 
@@ -192,7 +180,7 @@ TEST_F(Any, SBOCopyConstruction) {
     ASSERT_EQ(entt::any_cast<int>(other), 2);
 }
 
-TEST_F(Any, SBOCopyAssignment) {
+TEST(Any, SBOCopyAssignment) {
     const entt::any any{2};
     entt::any other{3};
 
@@ -206,7 +194,7 @@ TEST_F(Any, SBOCopyAssignment) {
     ASSERT_EQ(entt::any_cast<int>(other), 2);
 }
 
-TEST_F(Any, SBOMoveConstruction) {
+TEST(Any, SBOMoveConstruction) {
     entt::any any{2};
     entt::any other{std::move(any)};
 
@@ -220,7 +208,7 @@ TEST_F(Any, SBOMoveConstruction) {
     ASSERT_EQ(entt::any_cast<int>(other), 2);
 }
 
-TEST_F(Any, SBOMoveAssignment) {
+TEST(Any, SBOMoveAssignment) {
     entt::any any{2};
     entt::any other{3};
 
@@ -235,7 +223,7 @@ TEST_F(Any, SBOMoveAssignment) {
     ASSERT_EQ(entt::any_cast<int>(other), 2);
 }
 
-TEST_F(Any, SBODirectAssignment) {
+TEST(Any, SBODirectAssignment) {
     entt::any any{};
     any = 2;
 
@@ -246,7 +234,7 @@ TEST_F(Any, SBODirectAssignment) {
     ASSERT_EQ(entt::any_cast<int>(any), 2);
 }
 
-TEST_F(Any, SBOAssignValue) {
+TEST(Any, SBOAssignValue) {
     entt::any any{2};
     const entt::any other{3};
     const entt::any invalid{'c'};
@@ -259,7 +247,7 @@ TEST_F(Any, SBOAssignValue) {
     ASSERT_EQ(entt::any_cast<int>(any), 3);
 }
 
-TEST_F(Any, SBOAsRefAssignValue) {
+TEST(Any, SBOAsRefAssignValue) {
     int value = 2;
     entt::any any{entt::forward_as_any(value)};
     const entt::any other{3};
@@ -274,7 +262,7 @@ TEST_F(Any, SBOAsRefAssignValue) {
     ASSERT_EQ(value, 3);
 }
 
-TEST_F(Any, SBOAsConstRefAssignValue) {
+TEST(Any, SBOAsConstRefAssignValue) {
     const int value = 2;
     entt::any any{entt::forward_as_any(value)};
     const entt::any other{3};
@@ -289,7 +277,7 @@ TEST_F(Any, SBOAsConstRefAssignValue) {
     ASSERT_EQ(value, 2);
 }
 
-TEST_F(Any, SBOTransferValue) {
+TEST(Any, SBOTransferValue) {
     entt::any any{2};
 
     ASSERT_TRUE(any);
@@ -300,7 +288,7 @@ TEST_F(Any, SBOTransferValue) {
     ASSERT_EQ(entt::any_cast<int>(any), 3);
 }
 
-TEST_F(Any, SBOTransferConstValue) {
+TEST(Any, SBOTransferConstValue) {
     const int value = 3;
     entt::any any{2};
 
@@ -311,7 +299,7 @@ TEST_F(Any, SBOTransferConstValue) {
     ASSERT_EQ(entt::any_cast<int>(any), 3);
 }
 
-TEST_F(Any, SBOAsRefTransferValue) {
+TEST(Any, SBOAsRefTransferValue) {
     int value = 2;
     entt::any any{entt::forward_as_any(value)};
 
@@ -324,7 +312,7 @@ TEST_F(Any, SBOAsRefTransferValue) {
     ASSERT_EQ(value, 3);
 }
 
-TEST_F(Any, SBOAsConstRefTransferValue) {
+TEST(Any, SBOAsConstRefTransferValue) {
     const int value = 2;
     entt::any any{entt::forward_as_any(value)};
 
@@ -337,7 +325,7 @@ TEST_F(Any, SBOAsConstRefTransferValue) {
     ASSERT_EQ(value, 2);
 }
 
-TEST_F(Any, NoSBOInPlaceTypeConstruction) {
+TEST(Any, NoSBOInPlaceTypeConstruction) {
     const fat instance{.1, .2, .3, .4};
     entt::any any{std::in_place_type<fat>, instance};
 
@@ -356,7 +344,7 @@ TEST_F(Any, NoSBOInPlaceTypeConstruction) {
     ASSERT_EQ(other.data(), any.data());
 }
 
-TEST_F(Any, NoSBOAsRefConstruction) {
+TEST(Any, NoSBOAsRefConstruction) {
     fat instance{.1, .2, .3, .4};
     entt::any any{entt::forward_as_any(instance)};
 
@@ -393,7 +381,7 @@ TEST_F(Any, NoSBOAsRefConstruction) {
     ASSERT_EQ(other.data(), any.data());
 }
 
-TEST_F(Any, NoSBOAsConstRefConstruction) {
+TEST(Any, NoSBOAsConstRefConstruction) {
     const fat instance{.1, .2, .3, .4};
     entt::any any{entt::forward_as_any(instance)};
 
@@ -429,7 +417,7 @@ TEST_F(Any, NoSBOAsConstRefConstruction) {
     ASSERT_EQ(other.data(), any.data());
 }
 
-TEST_F(Any, NoSBOCopyConstruction) {
+TEST(Any, NoSBOCopyConstruction) {
     const fat instance{.1, .2, .3, .4};
     const entt::any any{instance};
     entt::any other{any};
@@ -442,7 +430,7 @@ TEST_F(Any, NoSBOCopyConstruction) {
     ASSERT_EQ(entt::any_cast<fat>(other), instance);
 }
 
-TEST_F(Any, NoSBOCopyAssignment) {
+TEST(Any, NoSBOCopyAssignment) {
     const fat instance{.1, .2, .3, .4};
     const entt::any any{instance};
     entt::any other{3};
@@ -457,7 +445,7 @@ TEST_F(Any, NoSBOCopyAssignment) {
     ASSERT_EQ(entt::any_cast<fat>(other), instance);
 }
 
-TEST_F(Any, NoSBOMoveConstruction) {
+TEST(Any, NoSBOMoveConstruction) {
     const fat instance{.1, .2, .3, .4};
     entt::any any{instance};
     entt::any other{std::move(any)};
@@ -472,7 +460,7 @@ TEST_F(Any, NoSBOMoveConstruction) {
     ASSERT_EQ(entt::any_cast<fat>(other), instance);
 }
 
-TEST_F(Any, NoSBOMoveAssignment) {
+TEST(Any, NoSBOMoveAssignment) {
     const fat instance{.1, .2, .3, .4};
     entt::any any{instance};
     entt::any other{3};
@@ -488,7 +476,7 @@ TEST_F(Any, NoSBOMoveAssignment) {
     ASSERT_EQ(entt::any_cast<fat>(other), instance);
 }
 
-TEST_F(Any, NoSBODirectAssignment) {
+TEST(Any, NoSBODirectAssignment) {
     const fat instance{.1, .2, .3, .4};
     entt::any any{};
     any = instance;
@@ -500,7 +488,7 @@ TEST_F(Any, NoSBODirectAssignment) {
     ASSERT_EQ(entt::any_cast<fat>(any), instance);
 }
 
-TEST_F(Any, NoSBOAssignValue) {
+TEST(Any, NoSBOAssignValue) {
     entt::any any{fat{.1, .2, .3, .4}};
     const entt::any other{fat{.0, .1, .2, .3}};
     const entt::any invalid{'c'};
@@ -516,7 +504,7 @@ TEST_F(Any, NoSBOAssignValue) {
     ASSERT_EQ(addr, std::as_const(any).data());
 }
 
-TEST_F(Any, NoSBOAsRefAssignValue) {
+TEST(Any, NoSBOAsRefAssignValue) {
     fat instance{.1, .2, .3, .4};
     entt::any any{entt::forward_as_any(instance)};
     const entt::any other{fat{.0, .1, .2, .3}};
@@ -531,7 +519,7 @@ TEST_F(Any, NoSBOAsRefAssignValue) {
     ASSERT_EQ(instance, (fat{.0, .1, .2, .3}));
 }
 
-TEST_F(Any, NoSBOAsConstRefAssignValue) {
+TEST(Any, NoSBOAsConstRefAssignValue) {
     const fat instance{.1, .2, .3, .4};
     entt::any any{entt::forward_as_any(instance)};
     const entt::any other{fat{.0, .1, .2, .3}};
@@ -546,7 +534,7 @@ TEST_F(Any, NoSBOAsConstRefAssignValue) {
     ASSERT_EQ(instance, (fat{.1, .2, .3, .4}));
 }
 
-TEST_F(Any, NoSBOTransferValue) {
+TEST(Any, NoSBOTransferValue) {
     entt::any any{fat{.1, .2, .3, .4}};
 
     const void *addr = std::as_const(any).data();
@@ -560,7 +548,7 @@ TEST_F(Any, NoSBOTransferValue) {
     ASSERT_EQ(addr, std::as_const(any).data());
 }
 
-TEST_F(Any, NoSBOTransferConstValue) {
+TEST(Any, NoSBOTransferConstValue) {
     const fat instance{.0, .1, .2, .3};
     entt::any any{fat{.1, .2, .3, .4}};
 
@@ -574,7 +562,7 @@ TEST_F(Any, NoSBOTransferConstValue) {
     ASSERT_EQ(addr, std::as_const(any).data());
 }
 
-TEST_F(Any, NoSBOAsRefTransferValue) {
+TEST(Any, NoSBOAsRefTransferValue) {
     fat instance{.1, .2, .3, .4};
     entt::any any{entt::forward_as_any(instance)};
 
@@ -590,7 +578,7 @@ TEST_F(Any, NoSBOAsRefTransferValue) {
     ASSERT_EQ(addr, std::as_const(any).data());
 }
 
-TEST_F(Any, NoSBOAsConstRefTransferValue) {
+TEST(Any, NoSBOAsConstRefTransferValue) {
     const fat instance{.1, .2, .3, .4};
     entt::any any{entt::forward_as_any(instance)};
 
@@ -606,7 +594,7 @@ TEST_F(Any, NoSBOAsConstRefTransferValue) {
     ASSERT_EQ(addr, std::as_const(any).data());
 }
 
-TEST_F(Any, VoidInPlaceTypeConstruction) {
+TEST(Any, VoidInPlaceTypeConstruction) {
     entt::any any{std::in_place_type<void>};
 
     ASSERT_FALSE(any);
@@ -615,7 +603,7 @@ TEST_F(Any, VoidInPlaceTypeConstruction) {
     ASSERT_EQ(entt::any_cast<int>(&any), nullptr);
 }
 
-TEST_F(Any, VoidCopyConstruction) {
+TEST(Any, VoidCopyConstruction) {
     entt::any any{std::in_place_type<void>};
     entt::any other{any};
 
@@ -627,7 +615,7 @@ TEST_F(Any, VoidCopyConstruction) {
     ASSERT_EQ(entt::any_cast<double>(&other), nullptr);
 }
 
-TEST_F(Any, VoidCopyAssignment) {
+TEST(Any, VoidCopyAssignment) {
     entt::any any{std::in_place_type<void>};
     entt::any other{2};
 
@@ -641,7 +629,7 @@ TEST_F(Any, VoidCopyAssignment) {
     ASSERT_EQ(entt::any_cast<double>(&other), nullptr);
 }
 
-TEST_F(Any, VoidMoveConstruction) {
+TEST(Any, VoidMoveConstruction) {
     entt::any any{std::in_place_type<void>};
     entt::any other{std::move(any)};
 
@@ -654,7 +642,7 @@ TEST_F(Any, VoidMoveConstruction) {
     ASSERT_EQ(entt::any_cast<double>(&other), nullptr);
 }
 
-TEST_F(Any, VoidMoveAssignment) {
+TEST(Any, VoidMoveAssignment) {
     entt::any any{std::in_place_type<void>};
     entt::any other{2};
 
@@ -668,7 +656,7 @@ TEST_F(Any, VoidMoveAssignment) {
     ASSERT_EQ(entt::any_cast<double>(&other), nullptr);
 }
 
-TEST_F(Any, SBOMoveValidButUnspecifiedState) {
+TEST(Any, SBOMoveValidButUnspecifiedState) {
     entt::any any{2};
     entt::any other{std::move(any)};
     const entt::any valid = std::move(other);
@@ -681,7 +669,7 @@ TEST_F(Any, SBOMoveValidButUnspecifiedState) {
     ASSERT_TRUE(valid);
 }
 
-TEST_F(Any, NoSBOMoveValidButUnspecifiedState) {
+TEST(Any, NoSBOMoveValidButUnspecifiedState) {
     const fat instance{.1, .2, .3, .4};
     entt::any any{instance};
     entt::any other{std::move(any)};
@@ -695,7 +683,7 @@ TEST_F(Any, NoSBOMoveValidButUnspecifiedState) {
     ASSERT_TRUE(valid);
 }
 
-TEST_F(Any, VoidMoveValidButUnspecifiedState) {
+TEST(Any, VoidMoveValidButUnspecifiedState) {
     entt::any any{std::in_place_type<void>};
     entt::any other{std::move(any)};
     const entt::any valid = std::move(other);
@@ -708,36 +696,44 @@ TEST_F(Any, VoidMoveValidButUnspecifiedState) {
     ASSERT_FALSE(valid);
 }
 
-TEST_F(Any, SBODestruction) {
+TEST(Any, SBODestruction) {
+    using tracker_type = tracker<0u>;
+
+    int counter{};
+
     {
-        entt::any any{std::in_place_type<empty>};
-        any.emplace<empty>();
-        any = empty{};
+        entt::any any{std::in_place_type<tracker_type>, counter};
+        any.emplace<tracker_type>(counter);
+        any = tracker_type{counter};
         entt::any other{std::move(any)};
         any = std::move(other);
     }
 
-    ASSERT_EQ(empty::counter, 6);
+    ASSERT_EQ(counter, 6);
 }
 
-TEST_F(Any, NoSBODestruction) {
+TEST(Any, NoSBODestruction) {
+    using tracker_type = tracker<entt::any::length>;
+
+    int counter{};
+
     {
-        entt::any any{std::in_place_type<fat>, 1., 2., 3., 4.};
-        any.emplace<fat>(1., 2., 3., 4.);
-        any = fat{1., 2., 3., 4.};
+        entt::any any{std::in_place_type<tracker_type>, counter};
+        any.emplace<tracker_type>(counter);
+        any = tracker_type{counter};
         entt::any other{std::move(any)};
         any = std::move(other);
     }
 
-    ASSERT_EQ(fat::counter, 4);
+    ASSERT_EQ(counter, 4);
 }
 
-TEST_F(Any, VoidDestruction) {
+TEST(Any, VoidDestruction) {
     // just let asan tell us if everything is ok here
     [[maybe_unused]] const entt::any any{std::in_place_type<void>};
 }
 
-TEST_F(Any, Emplace) {
+TEST(Any, Emplace) {
     entt::any any{};
     any.emplace<int>(2);
 
@@ -748,7 +744,7 @@ TEST_F(Any, Emplace) {
     ASSERT_EQ(entt::any_cast<int>(any), 2);
 }
 
-TEST_F(Any, EmplaceVoid) {
+TEST(Any, EmplaceVoid) {
     entt::any any{};
     any.emplace<void>();
 
@@ -757,7 +753,7 @@ TEST_F(Any, EmplaceVoid) {
     ASSERT_EQ(any.type(), entt::type_id<void>());
 }
 
-TEST_F(Any, Reset) {
+TEST(Any, Reset) {
     entt::any any{2};
 
     ASSERT_TRUE(any);
@@ -784,7 +780,7 @@ TEST_F(Any, Reset) {
     ASSERT_EQ(any.type(), entt::type_id<void>());
 }
 
-TEST_F(Any, SBOSwap) {
+TEST(Any, SBOSwap) {
     entt::any lhs{'c'};
     entt::any rhs{2};
 
@@ -801,7 +797,7 @@ TEST_F(Any, SBOSwap) {
     ASSERT_EQ(entt::any_cast<char>(rhs), 'c');
 }
 
-TEST_F(Any, NoSBOSwap) {
+TEST(Any, NoSBOSwap) {
     entt::any lhs{fat{.1, .2, .3, .4}};
     entt::any rhs{fat{.4, .3, .2, .1}};
 
@@ -814,7 +810,7 @@ TEST_F(Any, NoSBOSwap) {
     ASSERT_EQ(entt::any_cast<fat>(rhs), (fat{.1, .2, .3, .4}));
 }
 
-TEST_F(Any, VoidSwap) {
+TEST(Any, VoidSwap) {
     entt::any lhs{std::in_place_type<void>};
     entt::any rhs{std::in_place_type<void>};
     const auto *pre = lhs.data();
@@ -827,7 +823,7 @@ TEST_F(Any, VoidSwap) {
     ASSERT_EQ(pre, lhs.data());
 }
 
-TEST_F(Any, SBOWithNoSBOSwap) {
+TEST(Any, SBOWithNoSBOSwap) {
     entt::any lhs{fat{.1, .2, .3, .4}};
     entt::any rhs{'c'};
 
@@ -844,7 +840,7 @@ TEST_F(Any, SBOWithNoSBOSwap) {
     ASSERT_EQ(entt::any_cast<fat>(rhs), (fat{.1, .2, .3, .4}));
 }
 
-TEST_F(Any, SBOWithRefSwap) {
+TEST(Any, SBOWithRefSwap) {
     int value = 3;
     entt::any lhs{entt::forward_as_any(value)};
     entt::any rhs{'c'};
@@ -863,7 +859,7 @@ TEST_F(Any, SBOWithRefSwap) {
     ASSERT_EQ(rhs.data(), &value);
 }
 
-TEST_F(Any, SBOWithConstRefSwap) {
+TEST(Any, SBOWithConstRefSwap) {
     const int value = 3;
     entt::any lhs{entt::forward_as_any(value)};
     entt::any rhs{'c'};
@@ -883,7 +879,7 @@ TEST_F(Any, SBOWithConstRefSwap) {
     ASSERT_EQ(std::as_const(rhs).data(), &value);
 }
 
-TEST_F(Any, SBOWithEmptySwap) {
+TEST(Any, SBOWithEmptySwap) {
     entt::any lhs{'c'};
     entt::any rhs{};
 
@@ -906,7 +902,7 @@ TEST_F(Any, SBOWithEmptySwap) {
     ASSERT_EQ(entt::any_cast<char>(lhs), 'c');
 }
 
-TEST_F(Any, SBOWithVoidSwap) {
+TEST(Any, SBOWithVoidSwap) {
     entt::any lhs{'c'};
     entt::any rhs{std::in_place_type<void>};
 
@@ -929,7 +925,7 @@ TEST_F(Any, SBOWithVoidSwap) {
     ASSERT_EQ(entt::any_cast<char>(lhs), 'c');
 }
 
-TEST_F(Any, NoSBOWithRefSwap) {
+TEST(Any, NoSBOWithRefSwap) {
     int value = 3;
     entt::any lhs{entt::forward_as_any(value)};
     entt::any rhs{fat{.1, .2, .3, .4}};
@@ -948,7 +944,7 @@ TEST_F(Any, NoSBOWithRefSwap) {
     ASSERT_EQ(rhs.data(), &value);
 }
 
-TEST_F(Any, NoSBOWithConstRefSwap) {
+TEST(Any, NoSBOWithConstRefSwap) {
     const int value = 3;
     entt::any lhs{entt::forward_as_any(value)};
     entt::any rhs{fat{.1, .2, .3, .4}};
@@ -968,7 +964,7 @@ TEST_F(Any, NoSBOWithConstRefSwap) {
     ASSERT_EQ(std::as_const(rhs).data(), &value);
 }
 
-TEST_F(Any, NoSBOWithEmptySwap) {
+TEST(Any, NoSBOWithEmptySwap) {
     entt::any lhs{fat{.1, .2, .3, .4}};
     entt::any rhs{};
 
@@ -991,7 +987,7 @@ TEST_F(Any, NoSBOWithEmptySwap) {
     ASSERT_EQ(entt::any_cast<fat>(lhs), (fat{.1, .2, .3, .4}));
 }
 
-TEST_F(Any, NoSBOWithVoidSwap) {
+TEST(Any, NoSBOWithVoidSwap) {
     entt::any lhs{fat{.1, .2, .3, .4}};
     entt::any rhs{std::in_place_type<void>};
 
@@ -1014,7 +1010,7 @@ TEST_F(Any, NoSBOWithVoidSwap) {
     ASSERT_EQ(entt::any_cast<fat>(lhs), (fat{.1, .2, .3, .4}));
 }
 
-TEST_F(Any, AsRef) {
+TEST(Any, AsRef) {
     entt::any any{2};
     auto ref = any.as_ref();
     auto cref = std::as_const(any).as_ref();
@@ -1092,7 +1088,7 @@ TEST_F(Any, AsRef) {
     ASSERT_NE(entt::any_cast<int>(&cref), any.data());
 }
 
-TEST_F(Any, Comparable) {
+TEST(Any, Comparable) {
     const entt::any any{'c'};
     const entt::any other{'a'};
 
@@ -1106,7 +1102,7 @@ TEST_F(Any, Comparable) {
     ASSERT_TRUE(entt::any{} != any);
 }
 
-TEST_F(Any, NoSBOComparable) {
+TEST(Any, NoSBOComparable) {
     const entt::any any{fat{.1, .2, .3, .4}};
     const entt::any other{fat{.0, .1, .2, .3}};
 
@@ -1120,7 +1116,7 @@ TEST_F(Any, NoSBOComparable) {
     ASSERT_TRUE(entt::any{} != any);
 }
 
-TEST_F(Any, RefComparable) {
+TEST(Any, RefComparable) {
     int value = 2;
     const entt::any any{entt::forward_as_any(value)};
     const entt::any other{3};
@@ -1135,7 +1131,7 @@ TEST_F(Any, RefComparable) {
     ASSERT_TRUE(entt::any{} != any);
 }
 
-TEST_F(Any, ConstRefComparable) {
+TEST(Any, ConstRefComparable) {
     int value = 2;
     const entt::any any{3};
     const entt::any other{entt::make_any<const int &>(value)};
@@ -1150,7 +1146,7 @@ TEST_F(Any, ConstRefComparable) {
     ASSERT_TRUE(entt::any{} != any);
 }
 
-TEST_F(Any, UnrelatedComparable) {
+TEST(Any, UnrelatedComparable) {
     const entt::any any{'c'};
     const entt::any other{2};
 
@@ -1164,7 +1160,7 @@ TEST_F(Any, UnrelatedComparable) {
     ASSERT_TRUE(entt::any{} != any);
 }
 
-TEST_F(Any, NonComparable) {
+TEST(Any, NonComparable) {
     const test::non_comparable instance{};
     auto any = entt::forward_as_any(instance);
 
@@ -1177,7 +1173,7 @@ TEST_F(Any, NonComparable) {
     ASSERT_TRUE(entt::any{} != any);
 }
 
-TEST_F(Any, AssociativeContainerOfNonComparable) {
+TEST(Any, AssociativeContainerOfNonComparable) {
     const std::unordered_map<int, test::non_comparable> instance{};
     auto any = entt::forward_as_any(instance);
 
@@ -1190,7 +1186,7 @@ TEST_F(Any, AssociativeContainerOfNonComparable) {
     ASSERT_TRUE(entt::any{} != any);
 }
 
-TEST_F(Any, SequenceContainerOfNonComparable) {
+TEST(Any, SequenceContainerOfNonComparable) {
     const std::vector<test::non_comparable> instance{};
     auto any = entt::forward_as_any(instance);
 
@@ -1203,7 +1199,7 @@ TEST_F(Any, SequenceContainerOfNonComparable) {
     ASSERT_TRUE(entt::any{} != any);
 }
 
-TEST_F(Any, CompareVoid) {
+TEST(Any, CompareVoid) {
     const entt::any any{std::in_place_type<void>};
 
     ASSERT_EQ(any, any);
@@ -1218,7 +1214,7 @@ TEST_F(Any, CompareVoid) {
     ASSERT_FALSE(entt::any{} != any);
 }
 
-TEST_F(Any, AnyCast) {
+TEST(Any, AnyCast) {
     entt::any any{2};
     const auto &cany = any;
 
@@ -1238,7 +1234,7 @@ TEST_F(Any, AnyCast) {
     ASSERT_EQ(entt::any_cast<int>(entt::any{2}), 2);
 }
 
-ENTT_DEBUG_TEST_F(AnyDeathTest, AnyCast) {
+ENTT_DEBUG_TEST(AnyDeathTest, AnyCast) {
     entt::any any{2};
     const auto &cany = any;
 
@@ -1253,7 +1249,7 @@ ENTT_DEBUG_TEST_F(AnyDeathTest, AnyCast) {
     ASSERT_DEATH([[maybe_unused]] auto elem = entt::any_cast<double>(entt::any{2}), "");
 }
 
-TEST_F(Any, MakeAny) {
+TEST(Any, MakeAny) {
     int value = 2;
     auto any = entt::make_any<int>(value);
     auto ext = entt::make_any<int, sizeof(int), alignof(int)>(value);
@@ -1280,7 +1276,7 @@ TEST_F(Any, MakeAny) {
     ASSERT_EQ(ref.data(), &value);
 }
 
-TEST_F(Any, ForwardAsAny) {
+TEST(Any, ForwardAsAny) {
     int value = 2;
     auto ref = entt::forward_as_any(value);
     auto cref = entt::forward_as_any(std::as_const(value));
@@ -1306,7 +1302,7 @@ TEST_F(Any, ForwardAsAny) {
     ASSERT_EQ(ref.data(), &value);
 }
 
-TEST_F(Any, NonCopyableType) {
+TEST(Any, NonCopyableType) {
     const std::unique_ptr<int> value{};
     entt::any any{std::in_place_type<std::unique_ptr<int>>};
     entt::any other = entt::forward_as_any(value);
@@ -1338,7 +1334,7 @@ TEST_F(Any, NonCopyableType) {
     ASSERT_EQ(copy.policy(), entt::any_policy::owner);
 }
 
-TEST_F(Any, NonCopyableValueType) {
+TEST(Any, NonCopyableValueType) {
     std::vector<entt::any> vec{};
     vec.emplace_back(std::in_place_type<std::unique_ptr<int>>);
     vec.shrink_to_fit();
@@ -1355,7 +1351,7 @@ TEST_F(Any, NonCopyableValueType) {
     ASSERT_TRUE(vec[1u]);
 }
 
-TEST_F(Any, NonMovableType) {
+TEST(Any, NonMovableType) {
     entt::any any{std::in_place_type<test::non_movable>};
     entt::any other{std::in_place_type<test::non_movable>};
 
@@ -1386,24 +1382,29 @@ TEST_F(Any, NonMovableType) {
     ASSERT_EQ(copy.policy(), entt::any_policy::owner);
 }
 
-TEST_F(Any, Array) {
-    entt::any any{std::in_place_type<int[1]>}; // NOLINT
+TEST(Any, Array) {
+    // NOLINTNEXTLINE(*-avoid-c-arrays)
+    entt::any any{std::in_place_type<int[1]>};
     const entt::any copy{any};
 
     ASSERT_TRUE(any);
     ASSERT_FALSE(copy);
 
-    ASSERT_EQ(any.type(), entt::type_id<int[1]>());   // NOLINT
-    ASSERT_NE(entt::any_cast<int[1]>(&any), nullptr); // NOLINT
-    ASSERT_EQ(entt::any_cast<int[2]>(&any), nullptr); // NOLINT
+    // NOLINTBEGIN(*-avoid-c-arrays)
+    ASSERT_EQ(any.type(), entt::type_id<int[1]>());
+    ASSERT_NE(entt::any_cast<int[1]>(&any), nullptr);
+    ASSERT_EQ(entt::any_cast<int[2]>(&any), nullptr);
+    // NOLINTEND(*-avoid-c-arrays)
     ASSERT_EQ(entt::any_cast<int *>(&any), nullptr);
 
-    entt::any_cast<int(&)[1]>(any)[0] = 2; // NOLINT
+    // NOLINTNEXTLINE(*-avoid-c-arrays)
+    entt::any_cast<int(&)[1]>(any)[0] = 2;
 
-    ASSERT_EQ(entt::any_cast<const int(&)[1]>(std::as_const(any))[0], 2); // NOLINT
+    // NOLINTNEXTLINE(*-avoid-c-arrays)
+    ASSERT_EQ(entt::any_cast<const int(&)[1]>(std::as_const(any))[0], 2);
 }
 
-TEST_F(Any, CopyMoveReference) {
+TEST(Any, CopyMoveReference) {
     int value = 3;
     auto any = entt::forward_as_any(value);
     entt::any move = std::move(any);
@@ -1433,7 +1434,7 @@ TEST_F(Any, CopyMoveReference) {
     ASSERT_EQ(entt::any_cast<int &>(copy), 3);
 }
 
-TEST_F(Any, CopyMoveConstReference) {
+TEST(Any, CopyMoveConstReference) {
     int value = 3;
     auto any = entt::forward_as_any(std::as_const(value));
     entt::any move = std::move(any);
@@ -1463,7 +1464,7 @@ TEST_F(Any, CopyMoveConstReference) {
     ASSERT_EQ(entt::any_cast<const int &>(copy), 3);
 }
 
-TEST_F(Any, SBOVsZeroedSBOSize) {
+TEST(Any, SBOVsZeroedSBOSize) {
     entt::any sbo{2};
     const auto *broken = sbo.data();
     entt::any other = std::move(sbo);
@@ -1477,9 +1478,11 @@ TEST_F(Any, SBOVsZeroedSBOSize) {
     ASSERT_EQ(valid, same.data());
 }
 
-TEST_F(Any, SboAlignment) {
+TEST(Any, SboAlignment) {
     constexpr auto alignment = alignof(over_aligned);
-    entt::basic_any<alignment, alignment> sbo[2] = {over_aligned{}, over_aligned{}}; // NOLINT
+    using any_type = entt::basic_any<alignment, alignment>;
+
+    std::array<any_type, 2u> sbo = {over_aligned{}, over_aligned{}};
     const auto *data = sbo[0].data();
 
     // NOLINTBEGIN(*-reinterpret-cast)
@@ -1497,9 +1500,11 @@ TEST_F(Any, SboAlignment) {
     ASSERT_NE(data, sbo[1].data());
 }
 
-TEST_F(Any, NoSboAlignment) {
+TEST(Any, NoSboAlignment) {
     constexpr auto alignment = alignof(over_aligned);
-    entt::basic_any<alignment> nosbo[2] = {over_aligned{}, over_aligned{}}; // NOLINT
+    using any_type = entt::basic_any<alignment>;
+
+    std::array<any_type, 2u> nosbo = {over_aligned{}, over_aligned{}};
     const auto *data = nosbo[0].data();
 
     // NOLINTBEGIN(*-reinterpret-cast)
@@ -1517,12 +1522,12 @@ TEST_F(Any, NoSboAlignment) {
     ASSERT_EQ(data, nosbo[1].data());
 }
 
-TEST_F(Any, AggregatesMustWork) {
+TEST(Any, AggregatesMustWork) {
     // the goal of this test is to enforce the requirements for aggregate types
     entt::any{std::in_place_type<test::aggregate>, 2}.emplace<test::aggregate>(2);
 }
 
-TEST_F(Any, DeducedArrayType) {
+TEST(Any, DeducedArrayType) {
     entt::any any{"array of char"};
 
     ASSERT_TRUE(any);