1 /* Licensed to the Apache Software Foundation (ASF) under one or more
2 * contributor license agreements. See the NOTICE file distributed with
3 * this work for additional information regarding copyright ownership.
4 * The ASF licenses this file to You under the Apache License, Version 2.0
5 * (the "License"); you may not use this file except in compliance with
6 * the License. You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
18 #include "apr_network_io.h"
19 #include "apr_errno.h"
20 #include "apr_general.h"
25 int main(int argc, char *argv[])
31 char datasend[STRLEN] = "Send data test";
32 char datarecv[STRLEN];
34 char *local_ipaddr, *remote_ipaddr;
35 char *dest = "127.0.0.1";
36 apr_port_t local_port, remote_port;
37 apr_interval_time_t timeout = apr_time_from_sec(2);
38 apr_sockaddr_t *local_sa, *remote_sa;
46 timeout = atoi(argv[2]);
49 fprintf(stdout, "Initializing.........");
50 if (apr_initialize() != APR_SUCCESS) {
51 fprintf(stderr, "Something went wrong\n");
54 fprintf(stdout, "OK\n");
55 atexit(apr_terminate);
57 fprintf(stdout, "Creating context.......");
58 if (apr_pool_create(&context, NULL) != APR_SUCCESS) {
59 fprintf(stderr, "Something went wrong\n");
62 fprintf(stdout, "OK\n");
64 fprintf(stdout,"\tClient: Making socket address...............");
65 if ((stat = apr_sockaddr_info_get(&remote_sa, dest, APR_UNSPEC, 8021, 0, context))
67 fprintf(stdout, "Failed!\n");
68 fprintf(stdout, "Address resolution failed for %s: %s\n",
69 dest, apr_strerror(stat, msgbuf, sizeof(msgbuf)));
72 fprintf(stdout,"OK\n");
74 fprintf(stdout, "\tClient: Creating new socket.......");
75 if (apr_socket_create(&sock, remote_sa->family, SOCK_STREAM,
76 context) != APR_SUCCESS) {
77 fprintf(stderr, "Couldn't create socket\n");
80 fprintf(stdout, "OK\n");
82 fprintf(stdout, "\tClient: Setting socket timeout.......");
83 stat = apr_socket_timeout_set(sock, timeout);
85 fprintf(stderr, "Problem setting timeout: %d\n", stat);
88 fprintf(stdout, "OK\n");
90 fprintf(stdout, "\tClient: Connecting to socket.......");
92 stat = apr_socket_connect(sock, remote_sa);
94 if (stat != APR_SUCCESS) {
95 apr_socket_close(sock);
96 fprintf(stderr, "Could not connect: %s (%d)\n",
97 apr_strerror(stat, msgbuf, sizeof(msgbuf)), stat);
101 fprintf(stdout, "OK\n");
103 apr_socket_addr_get(&remote_sa, APR_REMOTE, sock);
104 apr_sockaddr_ip_get(&remote_ipaddr, remote_sa);
105 apr_sockaddr_port_get(&remote_port, remote_sa);
106 apr_socket_addr_get(&local_sa, APR_LOCAL, sock);
107 apr_sockaddr_ip_get(&local_ipaddr, local_sa);
108 apr_sockaddr_port_get(&local_port, local_sa);
109 fprintf(stdout, "\tClient socket: %s:%u -> %s:%u\n", local_ipaddr, local_port, remote_ipaddr, remote_port);
111 fprintf(stdout, "\tClient: Trying to send data over socket.......");
113 if ((stat = apr_socket_send(sock, datasend, &length) != APR_SUCCESS)) {
114 apr_socket_close(sock);
115 fprintf(stderr, "Problem sending data: %s (%d)\n",
116 apr_strerror(stat, msgbuf, sizeof(msgbuf)), stat);
119 fprintf(stdout, "OK\n");
122 fprintf(stdout, "\tClient: Trying to receive data over socket.......");
124 if ((stat = apr_socket_recv(sock, datarecv, &length)) != APR_SUCCESS) {
125 apr_socket_close(sock);
126 fprintf(stderr, "Problem receiving data: %s (%d)\n",
127 apr_strerror(stat, msgbuf, sizeof(msgbuf)), stat);
130 if (strcmp(datarecv, "Recv data test")) {
131 apr_socket_close(sock);
132 fprintf(stderr, "I did not receive the correct data %s\n", datarecv);
135 fprintf(stdout, "OK\n");
137 fprintf(stdout, "\tClient: Shutting down socket.......");
138 if (apr_socket_shutdown(sock, APR_SHUTDOWN_WRITE) != APR_SUCCESS) {
139 apr_socket_close(sock);
140 fprintf(stderr, "Could not shutdown socket\n");
143 fprintf(stdout, "OK\n");
145 fprintf(stdout, "\tClient: Closing down socket.......");
146 if (apr_socket_close(sock) != APR_SUCCESS) {
147 fprintf(stderr, "Could not shutdown socket\n");
150 fprintf(stdout, "OK\n");