]> git.meshlink.io Git - meshlink/blob - test/blackbox/run_blackbox_tests/test_cases_autoconnect.c
Add condition check in auto connect for blacklisted nodes
[meshlink] / test / blackbox / run_blackbox_tests / test_cases_autoconnect.c
1 /*
2     test_cases_blacklist.c -- Execution of specific meshlink black box test cases
3     Copyright (C) 2018  Guus Sliepen <guus@meshlink.io>
4
5     This program is free software; you can redistribute it and/or modify
6     it under the terms of the GNU General Public License as published by
7     the Free Software Foundation; either version 2 of the License, or
8     (at your option) any later version.
9
10     This program is distributed in the hope that it will be useful,
11     but WITHOUT ANY WARRANTY; without even the implied warranty of
12     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13     GNU General Public License for more details.
14
15     You should have received a copy of the GNU General Public License along
16     with this program; if not, write to the Free Software Foundation, Inc.,
17     51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
18 */
19
20 /* Modify this to change the logging level of Meshlink */
21 #define TEST_MESHLINK_LOG_LEVEL MESHLINK_DEBUG
22
23 #include "execute_tests.h"
24 #include "test_cases_autoconnect.h"
25 #include <pthread.h>
26 #include "../common/test_step.h"
27 #include "../common/common_handlers.h"
28 #include "../../utils.h"
29 #include <stdlib.h>
30 #include <stdarg.h>
31 #include <setjmp.h>
32 #include <cmocka.h>
33 #include <assert.h>
34 #include <string.h>
35
36 static void test_case_autoconnect(void **state);
37 static bool test_steps_mesh_autoconnect(void);
38 static meshlink_handle_t *mesh1, *mesh2;
39
40 /* State structure for meshlink_blacklist Test Case #1 */
41 static black_box_state_t test_mesh_autoconnect_state = {
42         .test_case_name = "test_case_mesh_autoconnect",
43 };
44 struct sync_flag test_autoconnect_m1n1_reachable = {.mutex  = PTHREAD_MUTEX_INITIALIZER, .cond = PTHREAD_COND_INITIALIZER, .flag = false};
45 struct sync_flag test_autoconnect_blacklisted = {.mutex  = PTHREAD_MUTEX_INITIALIZER, .cond = PTHREAD_COND_INITIALIZER, .flag = false};
46 struct sync_flag test_autoconnect_successful = {.mutex  = PTHREAD_MUTEX_INITIALIZER, .cond = PTHREAD_COND_INITIALIZER, .flag = false};
47
48 /* Execute meshlink_blacklist Test Case # 1*/
49 void test_case_autoconnect(void **state) {
50         execute_test(test_steps_mesh_autoconnect, state);
51 }
52
53 void callback_logger(meshlink_handle_t *mesh, meshlink_log_level_t level,
54                      const char *text) {
55         (void)level;
56
57         fprintf(stderr, "%s: {%s}\n", mesh->name, text);
58
59         if((check_sync_flag(&test_autoconnect_blacklisted) == true) && (strcmp("m1n2", mesh->name) == 0) && (strcmp("* could not find node for initial connect", text) == 0)) {
60                 fprintf(stderr, "Test case successful\n");
61                 set_sync_flag(&test_autoconnect_successful, true);
62         } else if((check_sync_flag(&test_autoconnect_blacklisted) == true) && (strcmp("m1n2", mesh->name) == 0)) {
63                 assert(strcmp(text, "Autoconnect trying to connect to m1n1") != 0);
64         }
65
66 }
67
68 static void receive(meshlink_handle_t *mesh, meshlink_node_t *src, const void *data, size_t len) {
69         (void)mesh;
70         (void)src;
71         (void)data;
72         assert(len);
73 }
74
75 static bool bar_reachable;
76
77 static void status_cb(meshlink_handle_t *mesh, meshlink_node_t *node, bool reachable) {
78         (void)mesh;
79         fprintf(stderr, "Status of node {%s} is %d\n", node->name, reachable);
80
81         if(!strcmp(node->name, "m1n1") && reachable) {
82                 set_sync_flag(&test_autoconnect_m1n1_reachable, true);
83         }
84 }
85
86
87 /* Test Steps for meshlink_blacklist Test Case # 1
88
89     Test Steps:
90     1. Open both the node instances
91     2. Join bar node with foo and Send & Receive data
92     3. Blacklist bar and Send & Receive data
93
94     Expected Result:
95     When default blacklist is disabled, foo node should receive data from bar
96     but when enabled foo node should not receive data
97 */
98 bool test_steps_mesh_autoconnect(void) {
99         char *invite = NULL;
100         meshlink_node_t *node = NULL;
101
102         meshlink_destroy("m1n1");
103         meshlink_destroy("m1n2");
104
105         // Open two new meshlink instance.
106         mesh1 = meshlink_open("m1n1", "m1n1", "autoconnect", DEV_CLASS_BACKBONE);
107         assert(mesh1 != NULL);
108         meshlink_set_log_cb(mesh1, TEST_MESHLINK_LOG_LEVEL, callback_logger);
109
110         mesh2 = meshlink_open("m1n2", "m1n2", "autoconnect", DEV_CLASS_STATIONARY);
111         assert(mesh2 != NULL);
112         meshlink_set_log_cb(mesh2, TEST_MESHLINK_LOG_LEVEL, callback_logger);
113         meshlink_set_receive_cb(mesh1, receive);
114
115         // Start both instances
116         meshlink_set_node_status_cb(mesh1, status_cb);
117         assert(meshlink_start(mesh1));
118
119         invite = meshlink_invite(mesh1, NULL, "m1n2");
120         assert(invite);
121
122         assert(meshlink_join(mesh2, invite));
123
124         meshlink_set_node_status_cb(mesh2, status_cb);
125         assert(meshlink_start(mesh2));
126
127         assert(wait_sync_flag(&test_autoconnect_m1n1_reachable, 30));
128
129         node = meshlink_get_node(mesh2, "m1n1");
130         meshlink_blacklist(mesh2, node);
131         set_sync_flag(&test_autoconnect_blacklisted, true);
132
133         assert(wait_sync_flag(&test_autoconnect_successful, 60));
134
135         // Clean up.
136         meshlink_close(mesh1);
137         fprintf(stderr, "Meshlink node1 closed\n");
138         meshlink_close(mesh2);
139         fprintf(stderr, "Meshlink node2 closed\n");
140
141         meshlink_destroy("m1n1");
142         meshlink_destroy("m1n2");
143         fprintf(stderr, "Meshlink nodes destroyed\n");
144
145         return true;
146 }
147
148 int test_meshlink_autoconnect(void) {
149         const struct CMUnitTest blackbox_blacklist_tests[] = {
150                 cmocka_unit_test_prestate_setup_teardown(test_case_autoconnect, NULL, NULL,
151                                 (void *)&test_mesh_autoconnect_state)
152         };
153
154         total_tests += sizeof(blackbox_blacklist_tests) / sizeof(blackbox_blacklist_tests[0]);
155
156         return cmocka_run_group_tests(blackbox_blacklist_tests, NULL, NULL);
157 }
158