commit a52bfa8: [Test] Separate local_ptr unit tests

Vsevolod Stakhov vsevolod at highsecure.ru
Thu Jul 22 17:28:04 UTC 2021


Author: Vsevolod Stakhov
Date: 2021-07-22 18:21:31 +0100
URL: https://github.com/rspamd/rspamd/commit/a52bfa87d61294bb93df3b916f008c72ae23b9c9 (HEAD -> master)

[Test] Separate local_ptr unit tests

---
 ...cxx_unit_utils.hxx => rspamd_cxx_local_ptr.hxx} |  44 +---
 test/rspamd_cxx_unit.cxx                           |   1 +
 test/rspamd_cxx_unit_utils.hxx                     | 262 +--------------------
 3 files changed, 7 insertions(+), 300 deletions(-)

diff --git a/test/rspamd_cxx_unit_utils.hxx b/test/rspamd_cxx_local_ptr.hxx
similarity index 84%
copy from test/rspamd_cxx_unit_utils.hxx
copy to test/rspamd_cxx_local_ptr.hxx
index 47e6c889b..c04c3f93d 100644
--- a/test/rspamd_cxx_unit_utils.hxx
+++ b/test/rspamd_cxx_local_ptr.hxx
@@ -14,50 +14,15 @@
  * limitations under the License.
  */
 
-/* Detached unit tests for the utils */
-
-#ifndef RSPAMD_RSPAMD_CXX_UNIT_UTILS_HXX
-#define RSPAMD_RSPAMD_CXX_UNIT_UTILS_HXX
+#ifndef RSPAMD_RSPAMD_CXX_LOCAL_PTR_HXX
+#define RSPAMD_RSPAMD_CXX_LOCAL_PTR_HXX
 
 #define DOCTEST_CONFIG_IMPLEMENTATION_IN_DLL
 #include "doctest/doctest.h"
 
-#include "libmime/mime_headers.h"
 #include "libutil/cxx/local_shared_ptr.hxx"
-#include <vector>
-#include <utility>
-#include <string>
-
-TEST_SUITE("rspamd utils") {
-
-TEST_CASE("rspamd_strip_smtp_comments_inplace")
-{
-	std::vector<std::pair<std::string, std::string>> cases{
-			{"abc",                    "abc"},
-			{"abc(foo)",               "abc"},
-			{"abc(foo()",              "abc"},
-			{"abc(foo))",              "abc)"},
-			{"abc(foo(bar))",          "abc"},
-			{"(bar)abc(foo)",          "abc"},
-			{"ab(ololo)c(foo)",        "abc"},
-			{"ab(olo\\)lo)c(foo)",     "abc"},
-			{"ab(trol\\\1lo)c(foo)",   "abc"},
-			{"\\ab(trol\\\1lo)c(foo)", "abc"},
-			{"",                       ""},
-	};
-
-	for (const auto &c : cases) {
-		SUBCASE (("strip comments in " + c.first).c_str()) {
-			auto *cpy = new char[c.first.size()];
-			memcpy(cpy, c.first.data(), c.first.size());
-			auto nlen = rspamd_strip_smtp_comments_inplace(cpy, c.first.size());
-			CHECK(std::string{cpy, nlen} == c.second);
-			delete[] cpy;
-		}
-	}
-}
-
 
+TEST_SUITE("local_ptr") {
 TEST_CASE("shared_ptr from nullptr")
 {
 	rspamd::local_shared_ptr<int const> pi(static_cast<int *>(nullptr));
@@ -314,7 +279,6 @@ TEST_CASE("weak_ptr") {
 	CHECK(t == true);
 	CHECK(wp.expired());
 }
-
 }
 
-#endif
+#endif //RSPAMD_RSPAMD_CXX_LOCAL_PTR_HXX
diff --git a/test/rspamd_cxx_unit.cxx b/test/rspamd_cxx_unit.cxx
index cf3271d96..37aa45b6f 100644
--- a/test/rspamd_cxx_unit.cxx
+++ b/test/rspamd_cxx_unit.cxx
@@ -22,6 +22,7 @@
 #include "doctest/doctest.h"
 
 #include "rspamd_cxx_unit_utils.hxx"
+#include "rspamd_cxx_local_ptr.hxx"
 
 static gboolean verbose = false;
 static const GOptionEntry entries[] =
diff --git a/test/rspamd_cxx_unit_utils.hxx b/test/rspamd_cxx_unit_utils.hxx
index 47e6c889b..d83af5010 100644
--- a/test/rspamd_cxx_unit_utils.hxx
+++ b/test/rspamd_cxx_unit_utils.hxx
@@ -23,12 +23,12 @@
 #include "doctest/doctest.h"
 
 #include "libmime/mime_headers.h"
-#include "libutil/cxx/local_shared_ptr.hxx"
+
 #include <vector>
 #include <utility>
 #include <string>
 
-TEST_SUITE("rspamd utils") {
+TEST_SUITE("rspamd_utils") {
 
 TEST_CASE("rspamd_strip_smtp_comments_inplace")
 {
@@ -57,264 +57,6 @@ TEST_CASE("rspamd_strip_smtp_comments_inplace")
 	}
 }
 
-
-TEST_CASE("shared_ptr from nullptr")
-{
-	rspamd::local_shared_ptr<int const> pi(static_cast<int *>(nullptr));
-	CHECK((!!pi ? false : true));
-	CHECK(!pi);
-	CHECK(pi.get() == nullptr);
-	CHECK(pi.use_count() == 1);
-	CHECK(pi.unique());
-
-
-}
-TEST_CASE("shared_ptr from ptr")
-{
-	int *p = new int(7);
-	rspamd::local_shared_ptr<int> pi(p);
-	CHECK((pi? true: false));
-	CHECK(!!pi);
-	CHECK(pi.get() == p);
-	CHECK(pi.use_count() == 1);
-	CHECK(pi.unique());
-	CHECK(*pi == 7);
-}
-
-TEST_CASE("shared_ptr copy")
-{
-	rspamd::local_shared_ptr<int> pi;
-
-	rspamd::local_shared_ptr<int> pi2(pi);
-	CHECK(pi2 == pi);
-	CHECK((pi2? false: true));
-	CHECK(!pi2);
-	CHECK(pi2.get() == nullptr);
-	CHECK(pi2.use_count() == pi.use_count());
-
-	rspamd::local_shared_ptr<int> pi3(pi);
-	CHECK(pi3 == pi);
-	CHECK((pi3? false: true));
-	CHECK(!pi3);
-	CHECK(pi3.get() == nullptr);
-	CHECK(pi3.use_count() == pi.use_count());
-
-	rspamd::local_shared_ptr<int> pi4(pi3);
-	CHECK(pi4 == pi3);
-	CHECK((pi4? false: true));
-	CHECK(!pi4);
-	CHECK(pi4.get() == nullptr);
-	CHECK(pi4.use_count() == pi3.use_count());
-
-	int * p = new int(7);
-	rspamd::local_shared_ptr<int> pi5(p);
-
-	rspamd::local_shared_ptr<int> pi6(pi5);
-	CHECK(pi5 == pi6);
-	CHECK((pi6? true: false));
-	CHECK(!!pi6);
-	CHECK(pi6.get() == p);
-	CHECK(pi6.use_count() == 2);
-	CHECK(!pi6.unique());
-	CHECK(*pi6 == 7);
-	CHECK(pi6.use_count() == pi6.use_count());
-	CHECK(!(pi5 < pi6 || pi5 < pi6)); // shared ownership test
-
-	auto pi7 = pi6;
-	CHECK(pi5 == pi7);
-	CHECK((pi7? true: false));
-	CHECK(!!pi7);
-	CHECK(pi7.get() == p);
-	CHECK(pi7.use_count() == 3);
-	CHECK(!pi7.unique());
-	CHECK(*pi7 == 7);
-	CHECK(pi7.use_count() == pi7.use_count());
-	CHECK(!(pi5 < pi7 || pi5 < pi7)); // shared ownership test
-}
-
-TEST_CASE("shared_ptr move")
-{
-	rspamd::local_shared_ptr<int> pi(new int);
-
-	rspamd::local_shared_ptr<int> pi2(std::move(pi));
-	CHECK(!(pi2 == pi));
-	CHECK((!pi2? false: true));
-	CHECK(!pi);
-	CHECK(pi.get() == nullptr);
-	CHECK(pi2.get() != nullptr);
-	CHECK(pi.use_count() != pi2.use_count());
-
-	std::swap(pi, pi2);
-	CHECK(!(pi2 == pi));
-	CHECK((!pi? false: true));
-	CHECK(!pi2);
-	CHECK(pi.get() != nullptr);
-	CHECK(pi2.get() == nullptr);
-	CHECK(pi.use_count() != pi2.use_count());
-}
-
-struct deleter_test {
-	bool *pv;
-	deleter_test(bool &v) {
-		v = false;
-		pv = &v;
-	}
-	~deleter_test() {
-		*pv = true;
-	}
-};
-TEST_CASE("shared_ptr dtor") {
-	bool t;
-
-	{
-		rspamd::local_shared_ptr<deleter_test> pi(new deleter_test{t});
-
-		CHECK((!pi ? false : true));
-		CHECK(!!pi);
-		CHECK(pi.get() != nullptr);
-		CHECK(pi.use_count() == 1);
-		CHECK(pi.unique());
-		CHECK(t == false);
-	}
-
-	CHECK(t == true);
-
-	{
-		rspamd::local_shared_ptr<deleter_test> pi(new deleter_test{t});
-
-		CHECK((!pi ? false : true));
-		CHECK(!!pi);
-		CHECK(pi.get() != nullptr);
-		CHECK(pi.use_count() == 1);
-		CHECK(pi.unique());
-		CHECK(t == false);
-
-		rspamd::local_shared_ptr<deleter_test> pi2(pi);
-		CHECK(pi2 == pi);
-		CHECK(pi.use_count() == 2);
-		pi.reset();
-		CHECK(!(pi2 == pi));
-		CHECK(pi2.use_count() == 1);
-		CHECK(t == false);
-
-		pi = pi2;
-		CHECK(pi2 == pi);
-		CHECK(pi.use_count() == 2);
-		CHECK(t == false);
-	}
-
-	CHECK(t == true);
-}
-
-TEST_CASE("make_shared dtor") {
-	bool t;
-
-	{
-		auto pi = rspamd::local_make_shared<deleter_test>(t);
-
-		CHECK((!pi ? false : true));
-		CHECK(!!pi);
-		CHECK(pi.get() != nullptr);
-		CHECK(pi.use_count() == 1);
-		CHECK(pi.unique());
-		CHECK(t == false);
-
-		rspamd::local_shared_ptr<deleter_test> pi2(pi);
-		CHECK(pi2 == pi);
-		CHECK(pi.use_count() == 2);
-		pi.reset();
-		CHECK(!(pi2 == pi));
-		CHECK(pi2.use_count() == 1);
-		CHECK(t == false);
-
-		pi = pi2;
-		CHECK(pi2 == pi);
-		CHECK(pi.use_count() == 2);
-		CHECK(t == false);
-	}
-
-	CHECK(t == true);
-}
-
-TEST_CASE("shared_ptr dtor") {
-	bool t;
-
-	{
-		rspamd::local_shared_ptr<deleter_test> pi(new deleter_test{t});
-
-		CHECK((!pi ? false : true));
-		CHECK(!!pi);
-		CHECK(pi.get() != nullptr);
-		CHECK(pi.use_count() == 1);
-		CHECK(pi.unique());
-		CHECK(t == false);
-	}
-
-	CHECK(t == true);
-
-	{
-		rspamd::local_shared_ptr<deleter_test> pi(new deleter_test{t});
-
-		CHECK((!pi ? false : true));
-		CHECK(!!pi);
-		CHECK(pi.get() != nullptr);
-		CHECK(pi.use_count() == 1);
-		CHECK(pi.unique());
-		CHECK(t == false);
-
-		rspamd::local_shared_ptr<deleter_test> pi2(pi);
-		CHECK(pi2 == pi);
-		CHECK(pi.use_count() == 2);
-		pi.reset();
-		CHECK(!(pi2 == pi));
-		CHECK(pi2.use_count() == 1);
-		CHECK(t == false);
-
-		pi = pi2;
-		CHECK(pi2 == pi);
-		CHECK(pi.use_count() == 2);
-		CHECK(t == false);
-	}
-
-	CHECK(t == true);
-}
-
-TEST_CASE("weak_ptr") {
-	bool t;
-
-	{
-		rspamd::local_shared_ptr<deleter_test> pi(new deleter_test{t});
-
-		CHECK((!pi ? false : true));
-		CHECK(!!pi);
-		CHECK(pi.get() != nullptr);
-		CHECK(pi.use_count() == 1);
-		CHECK(pi.unique());
-		CHECK(t == false);
-
-		rspamd::local_weak_ptr<deleter_test> wp(pi);
-		CHECK(wp.lock().get() != nullptr);
-		CHECK(pi.use_count() == 1);
-		CHECK(wp.use_count() == 1);
-		pi.reset();
-		CHECK(pi.use_count() == 0);
-		CHECK(wp.use_count() == 0);
-	}
-
-	CHECK(t == true);
-
-	rspamd::local_weak_ptr<deleter_test> wp;
-	{
-		rspamd::local_shared_ptr<deleter_test> pi(new deleter_test{t});
-		wp = pi;
-		CHECK(!wp.expired());
-		CHECK(wp.lock().get() != nullptr);
-	}
-
-	CHECK(t == true);
-	CHECK(wp.expired());
-}
-
 }
 
 #endif


More information about the Commits mailing list