[libsigcplusplus] test_retype: Break into smaller tests.
- From: Murray Cumming <murrayc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [libsigcplusplus] test_retype: Break into smaller tests.
- Date: Wed, 16 Mar 2016 11:39:03 +0000 (UTC)
commit 954cb8443f370dc91c006e737738b3087f455401
Author: Murray Cumming <murrayc murrayc com>
Date: Wed Mar 16 12:32:07 2016 +0100
test_retype: Break into smaller tests.
tests/test_retype.cc | 60 ++++++++++++++++++++++++++++++++++++++++---------
1 files changed, 49 insertions(+), 11 deletions(-)
---
diff --git a/tests/test_retype.cc b/tests/test_retype.cc
index 848731f..647afe0 100644
--- a/tests/test_retype.cc
+++ b/tests/test_retype.cc
@@ -10,6 +10,8 @@
namespace
{
+
+TestUtilities* util = nullptr;
std::ostringstream result_stream;
struct foo : public sigc::trackable
@@ -32,40 +34,76 @@ void bar(short s)
result_stream << "bar(short " << s << ")";
}
-} // end anonymous namespace
-
-int main(int argc, char* argv[])
+void test_member_int()
{
- auto util = TestUtilities::get_instance();
-
- if (!util->check_command_args(argc, argv))
- return util->get_result_and_delete_instance() ? EXIT_SUCCESS : EXIT_FAILURE;
-
foo foo_;
result_stream << sigc::retype(sigc::mem_fun(foo_, &foo::test_int))(1.234f);
util->check_result(result_stream, "foo::test_int(int 1) 1.5");
+}
+void test_member_float()
+{
+ foo foo_;
result_stream << sigc::retype(sigc::mem_fun(foo_, &foo::test_float))(5);
util->check_result(result_stream, "foo::test_float(float 5) 25");
+}
+void test_ptr_fun()
+{
sigc::retype(sigc::ptr_fun(&bar))(6.789f);
util->check_result(result_stream, "bar(short 6)");
+}
+void test_member_int_with_slot()
+{
+ foo foo_;
sigc::slot<float,float> s1 = sigc::retype(sigc::mem_fun(foo_, &foo::test_int));
- sigc::slot<float,int> s2 = sigc::retype(sigc::mem_fun(foo_, &foo::test_float));
- sigc::slot<void,double> s3 = sigc::retype(sigc::ptr_fun(&bar));
result_stream << s1(1.234f);
util->check_result(result_stream, "foo::test_int(int 1) 1.5");
+}
+void test_member_float_with_slot()
+{
+ foo foo_;
+ sigc::slot<float,int> s2 = sigc::retype(sigc::mem_fun(foo_, &foo::test_float));
result_stream << s2(5);
util->check_result(result_stream, "foo::test_float(float 5) 25");
+}
+void test_ptr_fun_with_slot()
+{
+ sigc::slot<void,double> s3 = sigc::retype(sigc::ptr_fun(&bar));
s3(6.789);
util->check_result(result_stream, "bar(short 6)");
+}
- s2 = sigc::retype(s1);
+void test_retype_slot()
+{
+ foo foo_;
+ sigc::slot<float,float> s1 = sigc::retype(sigc::mem_fun(foo_, &foo::test_int));
+ sigc::slot<float,int> s2 = sigc::retype(s1);
result_stream << s2(5);
util->check_result(result_stream, "foo::test_int(int 5) 7.5");
+}
+
+} // end anonymous namespace
+
+int main(int argc, char* argv[])
+{
+ util = TestUtilities::get_instance();
+
+ if (!util->check_command_args(argc, argv))
+ return util->get_result_and_delete_instance() ? EXIT_SUCCESS : EXIT_FAILURE;
+
+ test_member_int();
+ test_member_float();
+ test_ptr_fun();
+
+ test_member_int_with_slot();
+ test_member_float_with_slot();
+ test_ptr_fun_with_slot();
+
+ test_retype_slot();
return util->get_result_and_delete_instance() ? EXIT_SUCCESS : EXIT_FAILURE;
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]