aboutsummaryrefslogtreecommitdiff
path: root/tests/test_max_sockets.c
blob: b49f9eb03459eec0c0670e088b8b667816297bcc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
#include "torture.h"

#include <errno.h>
#include <stdio.h>
#include <cmocka.h>
#include <unistd.h>
#include <stdlib.h>

#define MAX_SOCKETS 4

static int setup(void **state)
{
	int ret;
	char str[10];

	torture_setup_socket_dir(state);

	ret = snprintf(str, 10, "%d", MAX_SOCKETS);
	if (ret < 0) {
		return ret;
	}

	ret = setenv("SOCKET_WRAPPER_MAX_SOCKETS", str, 1);

	return ret;
}

static int teardown(void **state)
{
	torture_teardown_socket_dir(state);

	return 0;
}

static int _socket(int *_s)
{
	int s;

	s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);

	if (s < 0) {
		return -1;
	}

	*_s = s;

	return 0;
}

static void test_max_sockets(void **state)
{
	int rc;
	int s[MAX_SOCKETS+1] = { 0 };
	int i;

	(void) state; /* unused */

	for (i = 0; i < MAX_SOCKETS; i++) {
		rc = _socket(&s[i]);
		assert_return_code(rc, errno);
	}

	/* no free space for sockets left */
	rc = _socket(&s[MAX_SOCKETS]);
	assert_int_equal(rc, -1);
	assert_int_equal(errno, ENFILE);

	/* closing a socket frees up space */
	close(s[0]);
	rc = _socket(&s[0]);
	assert_return_code(rc, errno);

	/* but just one */
	rc = _socket(&s[MAX_SOCKETS]);
	assert_int_equal(rc, -1);
	assert_int_equal(errno, ENFILE);

	for (i = 0; i < MAX_SOCKETS; i++) {
		close(s[i]);
	}
}

int main(void) {
	int rc;

	const struct CMUnitTest max_sockets_tests[] = {
		cmocka_unit_test_setup_teardown(test_max_sockets,
						setup, teardown),
	};

	rc = cmocka_run_group_tests(max_sockets_tests, NULL, NULL);

	return rc;
}