Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
L
libzmq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
libzmq
Commits
929d295e
Commit
929d295e
authored
Aug 23, 2018
by
Simon Giesecke
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Problem: test_timers not yet using unity
Solution: migrate to unity
parent
980791d1
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
86 additions
and
102 deletions
+86
-102
Makefile.am
Makefile.am
+2
-1
test_timers.cpp
tests/test_timers.cpp
+84
-101
No files found.
Makefile.am
View file @
929d295e
...
@@ -920,7 +920,8 @@ tests_test_thread_safe_LDADD = src/libzmq.la ${UNITY_LIBS}
...
@@ -920,7 +920,8 @@ tests_test_thread_safe_LDADD = src/libzmq.la ${UNITY_LIBS}
tests_test_thread_safe_CPPFLAGS
=
${
UNITY_CPPFLAGS
}
tests_test_thread_safe_CPPFLAGS
=
${
UNITY_CPPFLAGS
}
tests_test_timers_SOURCES
=
tests/test_timers.cpp
tests_test_timers_SOURCES
=
tests/test_timers.cpp
tests_test_timers_LDADD
=
src/libzmq.la
tests_test_timers_LDADD
=
src/libzmq.la
${
UNITY_LIBS
}
tests_test_timers_CPPFLAGS
=
${
UNITY_CPPFLAGS
}
tests_test_radio_dish_SOURCES
=
tests/test_radio_dish.cpp
tests_test_radio_dish_SOURCES
=
tests/test_radio_dish.cpp
tests_test_radio_dish_LDADD
=
src/libzmq.la
${
UNITY_LIBS
}
tests_test_radio_dish_LDADD
=
src/libzmq.la
${
UNITY_LIBS
}
...
...
tests/test_timers.cpp
View file @
929d295e
...
@@ -29,6 +29,15 @@
...
@@ -29,6 +29,15 @@
#define __STDC_LIMIT_MACROS // to define SIZE_MAX with older compilers
#define __STDC_LIMIT_MACROS // to define SIZE_MAX with older compilers
#include "testutil.hpp"
#include "testutil.hpp"
#include "testutil_unity.hpp"
void
setUp
()
{
}
void
tearDown
()
{
}
void
handler
(
int
timer_id_
,
void
*
arg_
)
void
handler
(
int
timer_id_
,
void
*
arg_
)
{
{
...
@@ -53,193 +62,167 @@ void test_null_timer_pointers ()
...
@@ -53,193 +62,167 @@ void test_null_timer_pointers ()
{
{
void
*
timers
=
NULL
;
void
*
timers
=
NULL
;
int
rc
=
zmq_timers_destroy
(
&
timers
);
TEST_ASSERT_FAILURE_ERRNO
(
EFAULT
,
zmq_timers_destroy
(
&
timers
));
assert
(
rc
==
-
1
&&
errno
==
EFAULT
);
// TODO this currently triggers an access violation
// TODO this currently triggers an access violation
#if 0
#if 0
rc = zmq_timers_destroy (NULL);
TEST_ASSERT_FAILURE_ERRNO(EFAULT, zmq_timers_destroy (NULL));
assert (rc == -1 && errno == EFAULT);
#endif
#endif
const
size_t
dummy_interval
=
100
;
const
size_t
dummy_interval
=
100
;
const
int
dummy_timer_id
=
1
;
const
int
dummy_timer_id
=
1
;
rc
=
zmq_timers_add
(
timers
,
dummy_interval
,
&
handler
,
NULL
);
TEST_ASSERT_FAILURE_ERRNO
(
assert
(
rc
==
-
1
&&
errno
==
EFAULT
);
EFAULT
,
zmq_timers_add
(
timers
,
dummy_interval
,
&
handler
,
NULL
));
TEST_ASSERT_FAILURE_ERRNO
(
rc
=
zmq_timers_add
(
&
timers
,
dummy_interval
,
&
handler
,
NULL
);
EFAULT
,
zmq_timers_add
(
&
timers
,
dummy_interval
,
&
handler
,
NULL
));
assert
(
rc
==
-
1
&&
errno
==
EFAULT
);
rc
=
zmq_timers_cancel
(
timers
,
dummy_timer_id
);
assert
(
rc
==
-
1
&&
errno
==
EFAULT
);
rc
=
zmq_timers_cancel
(
&
timers
,
dummy_timer_id
);
assert
(
rc
==
-
1
&&
errno
==
EFAULT
);
rc
=
zmq_timers_set_interval
(
timers
,
dummy_timer_id
,
dummy_interval
);
TEST_ASSERT_FAILURE_ERRNO
(
EFAULT
,
assert
(
rc
==
-
1
&&
errno
==
EFAULT
);
zmq_timers_cancel
(
timers
,
dummy_timer_id
));
TEST_ASSERT_FAILURE_ERRNO
(
EFAULT
,
zmq_timers_cancel
(
&
timers
,
dummy_timer_id
));
rc
=
zmq_timers_set_interval
(
&
timers
,
dummy_timer_id
,
dummy_interval
);
TEST_ASSERT_FAILURE_ERRNO
(
assert
(
rc
==
-
1
&&
errno
==
EFAULT
);
EFAULT
,
zmq_timers_set_interval
(
timers
,
dummy_timer_id
,
dummy_interval
));
TEST_ASSERT_FAILURE_ERRNO
(
EFAULT
,
zmq_timers_set_interval
(
&
timers
,
dummy_timer_id
,
dummy_interval
));
rc
=
zmq_timers_reset
(
timers
,
dummy_timer_id
);
TEST_ASSERT_FAILURE_ERRNO
(
EFAULT
,
assert
(
rc
==
-
1
&&
errno
==
EFAULT
);
zmq_timers_reset
(
timers
,
dummy_timer_id
));
TEST_ASSERT_FAILURE_ERRNO
(
EFAULT
,
zmq_timers_reset
(
&
timers
,
dummy_timer_id
));
rc
=
zmq_timers_reset
(
&
timers
,
dummy_timer_id
);
TEST_ASSERT_FAILURE_ERRNO
(
EFAULT
,
zmq_timers_timeout
(
timers
)
);
assert
(
rc
==
-
1
&&
errno
==
EFAULT
);
TEST_ASSERT_FAILURE_ERRNO
(
EFAULT
,
zmq_timers_timeout
(
&
timers
)
);
rc
=
zmq_timers_timeout
(
timers
);
TEST_ASSERT_FAILURE_ERRNO
(
EFAULT
,
zmq_timers_execute
(
timers
));
assert
(
rc
==
-
1
&&
errno
==
EFAULT
);
TEST_ASSERT_FAILURE_ERRNO
(
EFAULT
,
zmq_timers_execute
(
&
timers
));
rc
=
zmq_timers_timeout
(
&
timers
);
assert
(
rc
==
-
1
&&
errno
==
EFAULT
);
rc
=
zmq_timers_execute
(
timers
);
assert
(
rc
==
-
1
&&
errno
==
EFAULT
);
rc
=
zmq_timers_execute
(
&
timers
);
assert
(
rc
==
-
1
&&
errno
==
EFAULT
);
}
}
void
test_corner_cases
()
void
test_corner_cases
()
{
{
void
*
timers
=
zmq_timers_new
();
void
*
timers
=
zmq_timers_new
();
assert
(
timers
);
TEST_ASSERT_NOT_NULL
(
timers
);
const
size_t
dummy_interval
=
SIZE_MAX
;
const
size_t
dummy_interval
=
SIZE_MAX
;
const
int
dummy_timer_id
=
1
;
const
int
dummy_timer_id
=
1
;
// attempt to cancel non-existent timer
// attempt to cancel non-existent timer
int
rc
=
zmq_timers_cancel
(
timers
,
dummy_timer_id
);
TEST_ASSERT_FAILURE_ERRNO
(
EINVAL
,
assert
(
rc
==
-
1
&&
errno
==
EINVAL
);
zmq_timers_cancel
(
timers
,
dummy_timer_id
)
);
// attempt to set interval of non-existent timer
// attempt to set interval of non-existent timer
rc
=
zmq_timers_set_interval
(
timers
,
dummy_timer_id
,
dummy_interval
);
TEST_ASSERT_FAILURE_ERRNO
(
assert
(
rc
==
-
1
&&
errno
==
EINVAL
);
EINVAL
,
zmq_timers_set_interval
(
timers
,
dummy_timer_id
,
dummy_interval
)
);
// attempt to reset non-existent timer
// attempt to reset non-existent timer
rc
=
zmq_timers_reset
(
timers
,
dummy_timer_id
);
TEST_ASSERT_FAILURE_ERRNO
(
EINVAL
,
assert
(
rc
==
-
1
&&
errno
==
EINVAL
);
zmq_timers_reset
(
timers
,
dummy_timer_id
)
);
// attempt to add NULL handler
// attempt to add NULL handler
rc
=
zmq_timers_add
(
timers
,
dummy_interval
,
NULL
,
NULL
);
TEST_ASSERT_FAILURE_ERRNO
(
assert
(
rc
==
-
1
&&
errno
==
EFAULT
);
EFAULT
,
zmq_timers_add
(
timers
,
dummy_interval
,
NULL
,
NULL
)
);
int
timer_id
=
zmq_timers_add
(
timers
,
dummy_interval
,
handler
,
NULL
);
const
int
timer_id
=
TEST_ASSERT_SUCCESS_ERRNO
(
assert
(
timer_id
!=
-
1
);
zmq_timers_add
(
timers
,
dummy_interval
,
handler
,
NULL
)
);
// attempt to cancel timer twice
// attempt to cancel timer twice
// TODO should this case really be an error? canceling twice could be allowed
// TODO should this case really be an error? canceling twice could be allowed
rc
=
zmq_timers_cancel
(
timers
,
timer_id
);
TEST_ASSERT_SUCCESS_ERRNO
(
zmq_timers_cancel
(
timers
,
timer_id
));
assert
(
rc
==
0
);
rc
=
zmq_timers_cancel
(
timers
,
timer_id
);
TEST_ASSERT_FAILURE_ERRNO
(
EINVAL
,
zmq_timers_cancel
(
timers
,
timer_id
));
assert
(
rc
==
-
1
&&
errno
==
EINVAL
);
// timeout without any timers active
// timeout without any timers active
rc
=
zmq_timers_timeout
(
timers
);
TEST_ASSERT_FAILURE_ERRNO
(
EINVAL
,
zmq_timers_timeout
(
timers
));
assert
(
rc
==
-
1
);
rc
=
zmq_timers_destroy
(
&
timers
);
// cleanup
assert
(
rc
==
0
);
TEST_ASSERT_SUCCESS_ERRNO
(
zmq_timers_destroy
(
&
timers
)
);
}
}
int
main
(
void
)
void
test_timers
(
)
{
{
setup_test_environment
();
void
*
timers
=
zmq_timers_new
();
void
*
timers
=
zmq_timers_new
();
assert
(
timers
);
TEST_ASSERT_NOT_NULL
(
timers
);
bool
timer_invoked
=
false
;
bool
timer_invoked
=
false
;
const
unsigned
long
full_timeout
=
100
;
const
unsigned
long
full_timeout
=
100
;
void
*
const
stopwatch
=
zmq_stopwatch_start
();
void
*
const
stopwatch
=
zmq_stopwatch_start
();
int
timer_id
=
const
int
timer_id
=
TEST_ASSERT_SUCCESS_ERRNO
(
zmq_timers_add
(
timers
,
full_timeout
,
handler
,
&
timer_invoked
);
zmq_timers_add
(
timers
,
full_timeout
,
handler
,
&
timer_invoked
));
assert
(
timer_id
);
// Timer should not have been invoked yet
// Timer should not have been invoked yet
int
rc
=
zmq_timers_execute
(
timers
);
TEST_ASSERT_SUCCESS_ERRNO
(
zmq_timers_execute
(
timers
));
assert
(
rc
==
0
);
#ifdef ZMQ_BUILD_DRAFT_API
#ifdef ZMQ_BUILD_DRAFT_API
if
(
zmq_stopwatch_intermediate
(
stopwatch
)
<
full_timeout
)
{
if
(
zmq_stopwatch_intermediate
(
stopwatch
)
<
full_timeout
)
{
assert
(
!
timer_invoked
);
TEST_ASSERT_FALSE
(
timer_invoked
);
}
}
#endif
#endif
// Wait half the time and check again
// Wait half the time and check again
long
timeout
=
zmq_timers_timeout
(
timers
);
long
timeout
=
TEST_ASSERT_SUCCESS_ERRNO
(
zmq_timers_timeout
(
timers
));
assert
(
rc
!=
-
1
);
msleep
(
timeout
/
2
);
msleep
(
timeout
/
2
);
rc
=
zmq_timers_execute
(
timers
);
TEST_ASSERT_SUCCESS_ERRNO
(
zmq_timers_execute
(
timers
));
assert
(
rc
==
0
);
#ifdef ZMQ_BUILD_DRAFT_API
#ifdef ZMQ_BUILD_DRAFT_API
if
(
zmq_stopwatch_intermediate
(
stopwatch
)
<
full_timeout
)
{
if
(
zmq_stopwatch_intermediate
(
stopwatch
)
<
full_timeout
)
{
assert
(
!
timer_invoked
);
TEST_ASSERT_FALSE
(
timer_invoked
);
}
}
#endif
#endif
// Wait until the end
// Wait until the end
rc
=
sleep_and_execute
(
timers
);
TEST_ASSERT_SUCCESS_ERRNO
(
sleep_and_execute
(
timers
));
assert
(
rc
==
0
);
TEST_ASSERT_TRUE
(
timer_invoked
);
assert
(
timer_invoked
);
timer_invoked
=
false
;
timer_invoked
=
false
;
// Wait half the time and check again
// Wait half the time and check again
timeout
=
zmq_timers_timeout
(
timers
);
timeout
=
TEST_ASSERT_SUCCESS_ERRNO
(
zmq_timers_timeout
(
timers
));
assert
(
rc
!=
-
1
);
msleep
(
timeout
/
2
);
msleep
(
timeout
/
2
);
rc
=
zmq_timers_execute
(
timers
);
TEST_ASSERT_SUCCESS_ERRNO
(
zmq_timers_execute
(
timers
));
assert
(
rc
==
0
);
#ifdef ZMQ_BUILD_DRAFT_API
#ifdef ZMQ_BUILD_DRAFT_API
if
(
zmq_stopwatch_intermediate
(
stopwatch
)
<
2
*
full_timeout
)
{
if
(
zmq_stopwatch_intermediate
(
stopwatch
)
<
2
*
full_timeout
)
{
assert
(
!
timer_invoked
);
TEST_ASSERT_FALSE
(
timer_invoked
);
}
}
#endif
#endif
// Reset timer and wait half of the time left
// Reset timer and wait half of the time left
rc
=
zmq_timers_reset
(
timers
,
timer_id
);
TEST_ASSERT_SUCCESS_ERRNO
(
zmq_timers_reset
(
timers
,
timer_id
));
assert
(
rc
==
0
);
msleep
(
timeout
/
2
);
msleep
(
timeout
/
2
);
rc
=
zmq_timers_execute
(
timers
);
TEST_ASSERT_SUCCESS_ERRNO
(
zmq_timers_execute
(
timers
));
assert
(
rc
==
0
);
if
(
zmq_stopwatch_stop
(
stopwatch
)
<
2
*
full_timeout
)
{
if
(
zmq_stopwatch_stop
(
stopwatch
)
<
2
*
full_timeout
)
{
assert
(
!
timer_invoked
);
TEST_ASSERT_FALSE
(
timer_invoked
);
}
}
// Wait until the end
// Wait until the end
rc
=
sleep_and_execute
(
timers
);
TEST_ASSERT_SUCCESS_ERRNO
(
sleep_and_execute
(
timers
));
assert
(
rc
==
0
);
TEST_ASSERT_TRUE
(
timer_invoked
);
assert
(
timer_invoked
);
timer_invoked
=
false
;
timer_invoked
=
false
;
// reschedule
// reschedule
rc
=
zmq_timers_set_interval
(
timers
,
timer_id
,
50
);
TEST_ASSERT_SUCCESS_ERRNO
(
zmq_timers_set_interval
(
timers
,
timer_id
,
50
));
assert
(
rc
==
0
);
TEST_ASSERT_SUCCESS_ERRNO
(
sleep_and_execute
(
timers
));
rc
=
sleep_and_execute
(
timers
);
TEST_ASSERT_TRUE
(
timer_invoked
);
assert
(
rc
==
0
);
assert
(
timer_invoked
);
timer_invoked
=
false
;
timer_invoked
=
false
;
// cancel timer
// cancel timer
timeout
=
zmq_timers_timeout
(
timers
);
timeout
=
TEST_ASSERT_SUCCESS_ERRNO
(
zmq_timers_timeout
(
timers
));
assert
(
rc
!=
-
1
);
TEST_ASSERT_SUCCESS_ERRNO
(
zmq_timers_cancel
(
timers
,
timer_id
));
rc
=
zmq_timers_cancel
(
timers
,
timer_id
);
assert
(
rc
==
0
);
msleep
(
timeout
*
2
);
msleep
(
timeout
*
2
);
rc
=
zmq_timers_execute
(
timers
);
TEST_ASSERT_SUCCESS_ERRNO
(
zmq_timers_execute
(
timers
));
assert
(
rc
==
0
);
TEST_ASSERT_FALSE
(
timer_invoked
);
assert
(
!
timer_invoked
);
rc
=
zmq_timers_destroy
(
&
timers
);
TEST_ASSERT_SUCCESS_ERRNO
(
zmq_timers_destroy
(
&
timers
)
);
assert
(
rc
==
0
);
}
test_null_timer_pointers
();
int
main
()
test_corner_cases
();
{
setup_test_environment
();
return
0
;
UNITY_BEGIN
();
RUN_TEST
(
test_timers
);
RUN_TEST
(
test_null_timer_pointers
);
RUN_TEST
(
test_corner_cases
);
return
UNITY_END
();
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment