| File: | pr/Linux6.7_x86_64_gcc_glibc_PTH_64_DBG.OBJ/pr/tests/../../../pr/tests/poll_to.c |
| Warning: | line 164, column 5 Value stored to 'other_pds' is never read |
Press '?' to see keyboard shortcuts
Keyboard shortcuts:
| 1 | /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ |
| 2 | /* This Source Code Form is subject to the terms of the Mozilla Public |
| 3 | * License, v. 2.0. If a copy of the MPL was not distributed with this |
| 4 | * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ |
| 5 | |
| 6 | /*********************************************************************** |
| 7 | ** |
| 8 | ** Name: prpoll_to.c |
| 9 | ** |
| 10 | ** Description: This program tests PR_Poll with sockets. |
| 11 | ** Timeout operation is tested |
| 12 | ** |
| 13 | ** Modification History: |
| 14 | ** 14-May-97 AGarcia- Converted the test to accomodate the debug_mode flag. |
| 15 | ** The debug mode will print all of the printfs associated with this test. |
| 16 | ** The regress mode will be the default mode. Since the regress tool limits |
| 17 | ** the output to a one line status:PASS or FAIL,all of the printf statements |
| 18 | ** have been handled with an if (debug_mode) statement. |
| 19 | ** 04-June-97 AGarcia removed the Test_Result function. Regress tool has been updated to |
| 20 | ** recognize the return code from tha main program. |
| 21 | ***********************************************************************/ |
| 22 | |
| 23 | /*********************************************************************** |
| 24 | ** Includes |
| 25 | ***********************************************************************/ |
| 26 | /* Used to get the command line option */ |
| 27 | #include "plgetopt.h" |
| 28 | |
| 29 | #include "prinit.h" |
| 30 | #include "prio.h" |
| 31 | #include "prlog.h" |
| 32 | #include "prprf.h" |
| 33 | #include "prnetdb.h" |
| 34 | |
| 35 | #include "private/pprio.h" |
| 36 | |
| 37 | #include <stdio.h> |
| 38 | #include <string.h> |
| 39 | #include <stdlib.h> |
| 40 | |
| 41 | PRIntn failed_already=0; |
| 42 | PRIntn debug_mode; |
| 43 | |
| 44 | int main(int argc, char **argv) |
| 45 | { |
| 46 | PRFileDesc *listenSock1 = NULL((void*)0), *listenSock2 = NULL((void*)0); |
| 47 | PRUint16 listenPort1, listenPort2; |
| 48 | PRNetAddr addr; |
| 49 | char buf[128]; |
| 50 | PRPollDesc pds0[10], pds1[10], *pds, *other_pds; |
| 51 | PRIntn npds; |
| 52 | PRInt32 retVal; |
| 53 | |
| 54 | /* The command line argument: -d is used to determine if the test is being run |
| 55 | in debug mode. The regress tool requires only one line output:PASS or FAIL. |
| 56 | All of the printfs associated with this test has been handled with a if (debug_mode) |
| 57 | test. |
| 58 | Usage: test_name -d |
| 59 | */ |
| 60 | PLOptStatus os; |
| 61 | PLOptState *opt = PL_CreateOptState(argc, argv, "d:"); |
| 62 | while (PL_OPT_EOL != (os = PL_GetNextOpt(opt))) |
| 63 | { |
| 64 | if (PL_OPT_BAD == os) { |
| 65 | continue; |
| 66 | } |
| 67 | switch (opt->option) |
| 68 | { |
| 69 | case 'd': /* debug mode */ |
| 70 | debug_mode = 1; |
| 71 | break; |
| 72 | default: |
| 73 | break; |
| 74 | } |
| 75 | } |
| 76 | PL_DestroyOptState(opt); |
| 77 | |
| 78 | /* main test */ |
| 79 | |
| 80 | PR_Init(PR_USER_THREAD, PR_PRIORITY_NORMAL, 0); |
| 81 | PR_STDIO_INIT(); |
| 82 | |
| 83 | if (debug_mode) { |
| 84 | printf("This program tests PR_Poll with sockets.\n"); |
| 85 | printf("Timeout is tested.\n\n"); |
| 86 | } |
| 87 | |
| 88 | /* Create two listening sockets */ |
| 89 | if ((listenSock1 = PR_NewTCPSocket()) == NULL((void*)0)) { |
| 90 | fprintf(stderrstderr, "Can't create a new TCP socket\n"); |
| 91 | if (!debug_mode) { |
| 92 | failed_already=1; |
| 93 | } |
| 94 | goto exit_now; |
| 95 | } |
| 96 | memset(&addr, 0, sizeof(addr)); |
| 97 | addr.inet.family = PR_AF_INET2; |
| 98 | addr.inet.ip = PR_htonl(PR_INADDR_ANY((in_addr_t) 0x00000000)); |
| 99 | addr.inet.port = PR_htons(0); |
| 100 | if (PR_Bind(listenSock1, &addr) == PR_FAILURE) { |
| 101 | fprintf(stderrstderr, "Can't bind socket\n"); |
| 102 | if (!debug_mode) { |
| 103 | failed_already=1; |
| 104 | } |
| 105 | goto exit_now; |
| 106 | } |
| 107 | if (PR_GetSockName(listenSock1, &addr) == PR_FAILURE) { |
| 108 | fprintf(stderrstderr, "PR_GetSockName failed\n"); |
| 109 | if (!debug_mode) { |
| 110 | failed_already=1; |
| 111 | } |
| 112 | goto exit_now; |
| 113 | } |
| 114 | listenPort1 = PR_ntohs(addr.inet.port); |
| 115 | if (PR_Listen(listenSock1, 5) == PR_FAILURE) { |
| 116 | fprintf(stderrstderr, "Can't listen on a socket\n"); |
| 117 | if (!debug_mode) { |
| 118 | failed_already=1; |
| 119 | } |
| 120 | goto exit_now; |
| 121 | } |
| 122 | |
| 123 | if ((listenSock2 = PR_NewTCPSocket()) == NULL((void*)0)) { |
| 124 | fprintf(stderrstderr, "Can't create a new TCP socket\n"); |
| 125 | if (!debug_mode) { |
| 126 | failed_already=1; |
| 127 | } |
| 128 | goto exit_now; |
| 129 | } |
| 130 | addr.inet.family = PR_AF_INET2; |
| 131 | addr.inet.ip = PR_htonl(PR_INADDR_ANY((in_addr_t) 0x00000000)); |
| 132 | addr.inet.port = PR_htons(0); |
| 133 | if (PR_Bind(listenSock2, &addr) == PR_FAILURE) { |
| 134 | fprintf(stderrstderr, "Can't bind socket\n"); |
| 135 | if (!debug_mode) { |
| 136 | failed_already=1; |
| 137 | } |
| 138 | goto exit_now; |
| 139 | } |
| 140 | if (PR_GetSockName(listenSock2, &addr) == PR_FAILURE) { |
| 141 | fprintf(stderrstderr, "PR_GetSockName failed\n"); |
| 142 | if (!debug_mode) { |
| 143 | failed_already=1; |
| 144 | } |
| 145 | goto exit_now; |
| 146 | } |
| 147 | listenPort2 = PR_ntohs(addr.inet.port); |
| 148 | if (PR_Listen(listenSock2, 5) == PR_FAILURE) { |
| 149 | fprintf(stderrstderr, "Can't listen on a socket\n"); |
| 150 | if (!debug_mode) { |
| 151 | failed_already=1; |
| 152 | } |
| 153 | goto exit_now; |
| 154 | } |
| 155 | PR_snprintf(buf, sizeof(buf), |
| 156 | "The server thread is listening on ports %hu and %hu\n\n", |
| 157 | listenPort1, listenPort2); |
| 158 | if (debug_mode) { |
| 159 | printf("%s", buf); |
| 160 | } |
| 161 | |
| 162 | /* Set up the poll descriptor array */ |
| 163 | pds = pds0; |
| 164 | other_pds = pds1; |
Value stored to 'other_pds' is never read | |
| 165 | memset(pds, 0, sizeof(pds)); |
| 166 | pds[0].fd = listenSock1; |
| 167 | pds[0].in_flags = PR_POLL_READ0x1; |
| 168 | pds[1].fd = listenSock2; |
| 169 | pds[1].in_flags = PR_POLL_READ0x1; |
| 170 | npds = 2; |
| 171 | |
| 172 | /* Testing timeout */ |
| 173 | if (debug_mode) { |
| 174 | printf("PR_Poll should time out in 5 seconds\n"); |
| 175 | } |
| 176 | retVal = PR_Poll(pds, npds, PR_SecondsToInterval(5)); |
| 177 | if (retVal != 0) { |
| 178 | PR_snprintf(buf, sizeof(buf), |
| 179 | "PR_Poll should time out and return 0, but it returns %ld\n", |
| 180 | retVal); |
| 181 | fprintf(stderrstderr, "%s", buf); |
| 182 | if (!debug_mode) { |
| 183 | failed_already=1; |
| 184 | } |
| 185 | goto exit_now; |
| 186 | } |
| 187 | if (debug_mode) { |
| 188 | printf("PR_Poll timed out. Test passed.\n\n"); |
| 189 | } |
| 190 | |
| 191 | exit_now: |
| 192 | |
| 193 | if (listenSock1) { |
| 194 | PR_Close(listenSock1); |
| 195 | } |
| 196 | if (listenSock2) { |
| 197 | PR_Close(listenSock2); |
| 198 | } |
| 199 | |
| 200 | PR_Cleanup(); |
| 201 | |
| 202 | if(failed_already) { |
| 203 | return 1; |
| 204 | } |
| 205 | else { |
| 206 | return 0; |
| 207 | } |
| 208 | |
| 209 | } |