strerror_test.c (220376) | strerror_test.c (263085) |
---|---|
1/*- 2 * Copyright (c) 2001 Wes Peters <wes@FreeBSD.org> 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * 1. Redistributions of source code must retain the above copyright --- 9 unchanged lines hidden (view full) --- 18 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24 * SUCH DAMAGE. 25 * | 1/*- 2 * Copyright (c) 2001 Wes Peters <wes@FreeBSD.org> 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * 1. Redistributions of source code must retain the above copyright --- 9 unchanged lines hidden (view full) --- 18 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24 * SUCH DAMAGE. 25 * |
26 * $FreeBSD: head/tools/regression/lib/libc/string/test-strerror.c 220376 2011-04-05 21:56:05Z jilles $ | 26 * $FreeBSD: head/tools/regression/lib/libc/string/test-strerror.c 263085 2014-03-12 10:45:22Z jmmv $ |
27 */ 28 29#include <assert.h> 30#include <errno.h> 31#include <limits.h> 32#include <stdio.h> 33#include <stdlib.h> 34#include <string.h> 35 | 27 */ 28 29#include <assert.h> 30#include <errno.h> 31#include <limits.h> 32#include <stdio.h> 33#include <stdlib.h> 34#include <string.h> 35 |
36#include <tap.h> | 36static int test_count = 1; 37static int exit_status = EXIT_SUCCESS; |
37 | 38 |
39#define CHECK(x) \ 40 do { \ 41 if (x) { \ 42 printf("ok %d\n", test_count); \ 43 } else { \ 44 printf("not ok %d # %s\n", test_count, #x); \ 45 exit_status = EXIT_FAILURE; \ 46 } \ 47 ++test_count; \ 48 } while (0) 49 |
|
38int 39main(void) 40{ 41 char buf[64]; 42 char *sret; 43 int iret; 44 | 50int 51main(void) 52{ 53 char buf[64]; 54 char *sret; 55 int iret; 56 |
45 plan_tests(27); | 57 printf("1..27\n"); |
46 47 /* 48 * strerror() failure tests. 49 */ 50 errno = 0; 51 sret = strerror(INT_MAX); 52 snprintf(buf, sizeof(buf), "Unknown error: %d", INT_MAX); | 58 59 /* 60 * strerror() failure tests. 61 */ 62 errno = 0; 63 sret = strerror(INT_MAX); 64 snprintf(buf, sizeof(buf), "Unknown error: %d", INT_MAX); |
53 ok1(strcmp(sret, buf) == 0); 54 ok1(errno == EINVAL); | 65 CHECK(strcmp(sret, buf) == 0); 66 CHECK(errno == EINVAL); |
55 56 /* 57 * strerror() success tests. 58 */ 59 errno = 0; 60 sret = strerror(0); | 67 68 /* 69 * strerror() success tests. 70 */ 71 errno = 0; 72 sret = strerror(0); |
61 ok1(strcmp(sret, "No error: 0") == 0); 62 ok1(errno == 0); | 73 CHECK(strcmp(sret, "No error: 0") == 0); 74 CHECK(errno == 0); |
63 64 errno = 0; 65 sret = strerror(EPERM); | 75 76 errno = 0; 77 sret = strerror(EPERM); |
66 ok1(strcmp(sret, "Operation not permitted") == 0); 67 ok1(errno == 0); | 78 CHECK(strcmp(sret, "Operation not permitted") == 0); 79 CHECK(errno == 0); |
68 69 errno = 0; 70 sret = strerror(EPFNOSUPPORT); | 80 81 errno = 0; 82 sret = strerror(EPFNOSUPPORT); |
71 ok1(strcmp(sret, "Protocol family not supported") == 0); 72 ok1(errno == 0); | 83 CHECK(strcmp(sret, "Protocol family not supported") == 0); 84 CHECK(errno == 0); |
73 74 errno = 0; 75 sret = strerror(ELAST); | 85 86 errno = 0; 87 sret = strerror(ELAST); |
76 ok1(errno == 0); | 88 CHECK(errno == 0); |
77 78 /* 79 * strerror_r() failure tests. 80 */ 81 memset(buf, '*', sizeof(buf)); 82 iret = strerror_r(-1, buf, sizeof(buf)); | 89 90 /* 91 * strerror_r() failure tests. 92 */ 93 memset(buf, '*', sizeof(buf)); 94 iret = strerror_r(-1, buf, sizeof(buf)); |
83 ok1(strcmp(buf, "Unknown error: -1") == 0); 84 ok1(iret == EINVAL); | 95 CHECK(strcmp(buf, "Unknown error: -1") == 0); 96 CHECK(iret == EINVAL); |
85 86 memset(buf, '*', sizeof(buf)); 87 /* One byte too short. */ 88 iret = strerror_r(EPERM, buf, strlen("Operation not permitted")); | 97 98 memset(buf, '*', sizeof(buf)); 99 /* One byte too short. */ 100 iret = strerror_r(EPERM, buf, strlen("Operation not permitted")); |
89 ok1(strcmp(buf, "Operation not permitte") == 0); 90 ok1(iret == ERANGE); | 101 CHECK(strcmp(buf, "Operation not permitte") == 0); 102 CHECK(iret == ERANGE); |
91 92 memset(buf, '*', sizeof(buf)); 93 /* One byte too short. */ 94 iret = strerror_r(-1, buf, strlen("Unknown error: -1")); | 103 104 memset(buf, '*', sizeof(buf)); 105 /* One byte too short. */ 106 iret = strerror_r(-1, buf, strlen("Unknown error: -1")); |
95 ok1(strcmp(buf, "Unknown error: -") == 0); 96 ok1(iret == EINVAL); | 107 CHECK(strcmp(buf, "Unknown error: -") == 0); 108 CHECK(iret == EINVAL); |
97 98 memset(buf, '*', sizeof(buf)); 99 /* Two bytes too short. */ 100 iret = strerror_r(-2, buf, strlen("Unknown error: -2") - 1); | 109 110 memset(buf, '*', sizeof(buf)); 111 /* Two bytes too short. */ 112 iret = strerror_r(-2, buf, strlen("Unknown error: -2") - 1); |
101 ok1(strcmp(buf, "Unknown error: ") == 0); 102 ok1(iret == EINVAL); | 113 CHECK(strcmp(buf, "Unknown error: ") == 0); 114 CHECK(iret == EINVAL); |
103 104 memset(buf, '*', sizeof(buf)); 105 /* Three bytes too short. */ 106 iret = strerror_r(-2, buf, strlen("Unknown error: -2") - 2); | 115 116 memset(buf, '*', sizeof(buf)); 117 /* Three bytes too short. */ 118 iret = strerror_r(-2, buf, strlen("Unknown error: -2") - 2); |
107 ok1(strcmp(buf, "Unknown error:") == 0); 108 ok1(iret == EINVAL); | 119 CHECK(strcmp(buf, "Unknown error:") == 0); 120 CHECK(iret == EINVAL); |
109 110 memset(buf, '*', sizeof(buf)); 111 /* One byte too short. */ 112 iret = strerror_r(12345, buf, strlen("Unknown error: 12345")); | 121 122 memset(buf, '*', sizeof(buf)); 123 /* One byte too short. */ 124 iret = strerror_r(12345, buf, strlen("Unknown error: 12345")); |
113 ok1(strcmp(buf, "Unknown error: 1234") == 0); 114 ok1(iret == EINVAL); | 125 CHECK(strcmp(buf, "Unknown error: 1234") == 0); 126 CHECK(iret == EINVAL); |
115 116 /* 117 * strerror_r() success tests. 118 */ 119 memset(buf, '*', sizeof(buf)); 120 iret = strerror_r(0, buf, sizeof(buf)); | 127 128 /* 129 * strerror_r() success tests. 130 */ 131 memset(buf, '*', sizeof(buf)); 132 iret = strerror_r(0, buf, sizeof(buf)); |
121 ok1(strcmp(buf, "No error: 0") == 0); 122 ok1(iret == 0); | 133 CHECK(strcmp(buf, "No error: 0") == 0); 134 CHECK(iret == 0); |
123 124 memset(buf, '*', sizeof(buf)); 125 iret = strerror_r(EDEADLK, buf, sizeof(buf)); | 135 136 memset(buf, '*', sizeof(buf)); 137 iret = strerror_r(EDEADLK, buf, sizeof(buf)); |
126 ok1(strcmp(buf, "Resource deadlock avoided") == 0); 127 ok1(iret == 0); | 138 CHECK(strcmp(buf, "Resource deadlock avoided") == 0); 139 CHECK(iret == 0); |
128 129 memset(buf, '*', sizeof(buf)); 130 iret = strerror_r(EPROCLIM, buf, sizeof(buf)); | 140 141 memset(buf, '*', sizeof(buf)); 142 iret = strerror_r(EPROCLIM, buf, sizeof(buf)); |
131 ok1(strcmp(buf, "Too many processes") == 0); 132 ok1(iret == 0); | 143 CHECK(strcmp(buf, "Too many processes") == 0); 144 CHECK(iret == 0); |
133 | 145 |
134 return exit_status(); | 146 return exit_status; |
135} | 147} |