diff options
| author | Holger Weiss <holger@zedat.fu-berlin.de> | 2013-09-12 21:37:20 +0200 | 
|---|---|---|
| committer | Holger Weiss <holger@zedat.fu-berlin.de> | 2013-09-12 21:37:20 +0200 | 
| commit | e8044713d41f5ef1d9ce814df4a079d8f92306b0 (patch) | |
| tree | e4b6f3d068c850774b9cda16f7c5830b9fc15774 /lib/tests | |
| parent | 662997251d4fc43f4155784f9e7df827f193305e (diff) | |
| download | monitoring-plugins-e8044713d41f5ef1d9ce814df4a079d8f92306b0.tar.gz | |
check_tcp: Properly deal will partial recv(3)s
The np_expect_match() function now returns one of three possible states
instead of just TRUE or FALSE:
- NP_MATCH_SUCCESS
- NP_MATCH_FAILURE
- NP_MATCH_RETRY
The NP_MATCH_RETRY state indicates that matching might succeed if
np_expect_match() is called with a longer input string.  This allows
check_tcp to decide whether it makes sense to wait for additional data
from the server.
Diffstat (limited to 'lib/tests')
| -rw-r--r-- | lib/tests/test_tcp.c | 20 | 
1 files changed, 11 insertions, 9 deletions
| diff --git a/lib/tests/test_tcp.c b/lib/tests/test_tcp.c index 8e9d43c8..ae6dc1f4 100644 --- a/lib/tests/test_tcp.c +++ b/lib/tests/test_tcp.c | |||
| @@ -25,7 +25,7 @@ main (int argc, char **argv) | |||
| 25 | { | 25 | { | 
| 26 | char** server_expect; | 26 | char** server_expect; | 
| 27 | int server_expect_count = 3; | 27 | int server_expect_count = 3; | 
| 28 | plan_tests(8); | 28 | plan_tests(9); | 
| 29 | 29 | ||
| 30 | server_expect = malloc(sizeof(char*) * server_expect_count); | 30 | server_expect = malloc(sizeof(char*) * server_expect_count); | 
| 31 | 31 | ||
| @@ -33,21 +33,23 @@ main (int argc, char **argv) | |||
| 33 | server_expect[1] = strdup("bb"); | 33 | server_expect[1] = strdup("bb"); | 
| 34 | server_expect[2] = strdup("CC"); | 34 | server_expect[2] = strdup("CC"); | 
| 35 | 35 | ||
| 36 | ok(np_expect_match("AA bb CC XX", server_expect, server_expect_count, NP_MATCH_EXACT) == TRUE, | 36 | ok(np_expect_match("AA bb CC XX", server_expect, server_expect_count, NP_MATCH_EXACT) == NP_MATCH_SUCCESS, | 
| 37 | "Test matching any string at the beginning (first expect string)"); | 37 | "Test matching any string at the beginning (first expect string)"); | 
| 38 | ok(np_expect_match("bb AA CC XX", server_expect, server_expect_count, NP_MATCH_EXACT) == TRUE, | 38 | ok(np_expect_match("bb AA CC XX", server_expect, server_expect_count, NP_MATCH_EXACT) == NP_MATCH_SUCCESS, | 
| 39 | "Test matching any string at the beginning (second expect string)"); | 39 | "Test matching any string at the beginning (second expect string)"); | 
| 40 | ok(np_expect_match("XX bb AA CC XX", server_expect, server_expect_count, NP_MATCH_EXACT) == FALSE, | 40 | ok(np_expect_match("b", server_expect, server_expect_count, NP_MATCH_EXACT) == NP_MATCH_RETRY, | 
| 41 | "Test matching any string at the beginning (substring match)"); | ||
| 42 | ok(np_expect_match("XX bb AA CC XX", server_expect, server_expect_count, NP_MATCH_EXACT) == NP_MATCH_FAILURE, | ||
| 41 | "Test with strings not matching at the beginning"); | 43 | "Test with strings not matching at the beginning"); | 
| 42 | ok(np_expect_match("XX CC XX", server_expect, server_expect_count, NP_MATCH_EXACT) == FALSE, | 44 | ok(np_expect_match("XX CC XX", server_expect, server_expect_count, NP_MATCH_EXACT) == NP_MATCH_FAILURE, | 
| 43 | "Test matching any string"); | 45 | "Test matching any string"); | 
| 44 | ok(np_expect_match("XX", server_expect, server_expect_count, 0) == FALSE, | 46 | ok(np_expect_match("XX", server_expect, server_expect_count, 0) == NP_MATCH_RETRY, | 
| 45 | "Test not matching any string"); | 47 | "Test not matching any string"); | 
| 46 | ok(np_expect_match("XX AA bb CC XX", server_expect, server_expect_count, NP_MATCH_ALL) == TRUE, | 48 | ok(np_expect_match("XX AA bb CC XX", server_expect, server_expect_count, NP_MATCH_ALL) == NP_MATCH_SUCCESS, | 
| 47 | "Test matching all strings"); | 49 | "Test matching all strings"); | 
| 48 | ok(np_expect_match("XX bb CC XX", server_expect, server_expect_count, NP_MATCH_ALL) == FALSE, | 50 | ok(np_expect_match("XX bb CC XX", server_expect, server_expect_count, NP_MATCH_ALL) == NP_MATCH_RETRY, | 
| 49 | "Test not matching all strings"); | 51 | "Test not matching all strings"); | 
| 50 | ok(np_expect_match("XX XX", server_expect, server_expect_count, NP_MATCH_ALL) == FALSE, | 52 | ok(np_expect_match("XX XX", server_expect, server_expect_count, NP_MATCH_ALL) == NP_MATCH_RETRY, | 
| 51 | "Test not matching any string (testing all)"); | 53 | "Test not matching any string (testing all)"); | 
| 52 | 54 | ||
| 53 | 55 | ||
