blob: f7d9c39d6fc201d6f7f7cbbb0ea64fa8f912b5c3 [file] [log] [blame]
Dmitry V. Levin38a34c92015-12-17 17:56:48 +00001/*
Dmitry V. Levin9b3c77c2016-01-05 23:02:21 +00002 * Copyright (c) 2015-2016 Dmitry V. Levin <ldv@altlinux.org>
Dmitry V. Levin38a34c92015-12-17 17:56:48 +00003 * 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 * notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in the
12 * documentation and/or other materials provided with the distribution.
13 * 3. The name of the author may not be used to endorse or promote products
14 * derived from this software without specific prior written permission.
15 *
16 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
17 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
18 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
19 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
20 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
21 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 */
27
Dmitry V. Levin9b3c77c2016-01-05 23:02:21 +000028#include "tests.h"
Dmitry V. Levin495f5252015-02-01 00:20:32 +000029#include <assert.h>
30#include <string.h>
31#include <unistd.h>
32#include <sys/socket.h>
33#include <sys/wait.h>
34
35static void
36transpose(char *str, int len)
37{
38 int i;
39
40 for (i = 0; i < len / 2; ++i) {
41 char c = str[i];
42 str[i] = str[len - 1 - i];
43 str[len - 1 - i] = c;
44 }
45}
46
47int
48main(int ac, char **av)
49{
50 assert(ac == 2);
51 const int len = strlen(av[1]);
52 assert(len);
53
54 (void) close(0);
55 (void) close(1);
56
57 int sv[2];
Dmitry V. Levin9b3c77c2016-01-05 23:02:21 +000058 if (socketpair(AF_UNIX, SOCK_STREAM, 0, sv))
59 perror_msg_and_skip("socketpair");
Dmitry V. Levin495f5252015-02-01 00:20:32 +000060
61 pid_t pid = fork();
Dmitry V. Levin9b3c77c2016-01-05 23:02:21 +000062 if (pid < 0)
63 perror_msg_and_fail("fork");
Dmitry V. Levin495f5252015-02-01 00:20:32 +000064
65 if (pid) {
66 assert(close(1) == 0);
67 transpose(av[1], len);
68 assert(sendto(0, av[1], len, MSG_DONTROUTE, NULL, 0) == len);
69 assert(recvfrom(0, av[1], len, MSG_WAITALL, NULL, NULL) == len);
70 assert(close(0) == 0);
71
72 int status;
73 assert(waitpid(pid, &status, 0) == pid);
74 assert(status == 0);
75 } else {
76 assert(close(0) == 0);
77 assert(recvfrom(1, av[1], len, MSG_WAITALL, NULL, NULL) == len);
78 transpose(av[1], len);
79 assert(sendto(1, av[1], len, MSG_DONTROUTE, NULL, 0) == len);
80 assert(recvfrom(1, av[1], len, MSG_WAITALL, NULL, NULL) == 0);
81 assert(close(1) == 0);
82 }
83
84 return 0;
85}