bridges/bridge_t38: Add a bridging module for managing T.38 state
[asterisk/asterisk.git] / tests / test_websocket_client.c
1 /*
2  * Asterisk -- An open source telephony toolkit.
3  *
4  * Copyright (C) 2014, Digium, Inc.
5  *
6  * Kevin Harwell <kharwell@digium.com>
7  *
8  * See http://www.asterisk.org for more information about
9  * the Asterisk project. Please do not directly contact
10  * any of the maintainers of this project for assistance;
11  * the project provides a web site, mailing lists and IRC
12  * channels for your use.
13  *
14  * This program is free software, distributed under the terms of
15  * the GNU General Public License Version 2. See the LICENSE file
16  * at the top of the source tree.
17  */
18
19 /*!
20  * \file
21  * \brief Websocket Client Unit Tests
22  *
23  * \author Kevin Harwell <kharwell@digium.com>
24  *
25  */
26
27 /*** MODULEINFO
28         <depend>TEST_FRAMEWORK</depend>
29         <depend>res_http_websocket</depend>
30         <support_level>core</support_level>
31  ***/
32
33 #include "asterisk.h"
34
35 ASTERISK_REGISTER_FILE()
36
37 #include "asterisk/test.h"
38 #include "asterisk/module.h"
39 #include "asterisk/astobj2.h"
40 #include "asterisk/pbx.h"
41 #include "asterisk/http_websocket.h"
42
43 #define CATEGORY "/res/websocket/"
44 #define REMOTE_URL "ws://127.0.0.1:8088/ws"
45
46 AST_TEST_DEFINE(websocket_client_create_and_connect)
47 {
48         RAII_VAR(struct ast_websocket *, client, NULL, ao2_cleanup);
49
50         enum ast_websocket_result result;
51         const char write_buf[] = "this is only a test";
52         RAII_VAR(char *, read_buf, NULL, ast_free);
53
54         switch (cmd) {
55         case TEST_INIT:
56                 info->name = __func__;
57                 info->category = CATEGORY;
58                 info->summary = "test creation and connection of a client websocket";
59                 info->description = "test creation and connection of a client websocket";
60                 return AST_TEST_NOT_RUN;
61         case TEST_EXECUTE:
62                 break;
63         }
64
65         ast_test_validate(test, (client = ast_websocket_client_create(
66                                          REMOTE_URL, "echo", NULL, &result)));
67
68         ast_test_validate(test, !ast_websocket_write_string(client, write_buf));
69         ast_test_validate(test, ast_websocket_read_string(client, &read_buf) > 0);
70         ast_test_validate(test, !strcmp(write_buf, read_buf));
71
72         return AST_TEST_PASS;
73 }
74
75 AST_TEST_DEFINE(websocket_client_bad_url)
76 {
77         RAII_VAR(struct ast_websocket *, client, NULL, ao2_cleanup);
78         enum ast_websocket_result result;
79
80         switch (cmd) {
81         case TEST_INIT:
82                 info->name = __func__;
83                 info->category = CATEGORY;
84                 info->summary = "websocket client - test bad url";
85                 info->description = "pass a bad url and make sure it fails";
86                 return AST_TEST_NOT_RUN;
87         case TEST_EXECUTE:
88                 break;
89         }
90
91         ast_test_validate(test, !(client = ast_websocket_client_create(
92                                           "invalid", NULL, NULL, &result)));
93         return AST_TEST_PASS;
94 }
95
96 AST_TEST_DEFINE(websocket_client_unsupported_protocol)
97 {
98         RAII_VAR(struct ast_websocket *, client, NULL, ao2_cleanup);
99         enum ast_websocket_result result;
100
101         switch (cmd) {
102         case TEST_INIT:
103                 info->name = __func__;
104                 info->category = CATEGORY;
105                 info->summary = "websocket client - unsupported protocol";
106                 info->description = "fails on an unsupported protocol";
107                 return AST_TEST_NOT_RUN;
108         case TEST_EXECUTE:
109                 break;
110         }
111
112         ast_test_validate(test, !(client = ast_websocket_client_create(
113                                           REMOTE_URL, "unsupported", NULL, &result)));
114         return AST_TEST_PASS;
115 }
116
117 AST_TEST_DEFINE(websocket_client_multiple_protocols)
118 {
119         RAII_VAR(struct ast_websocket *, client, NULL, ao2_cleanup);
120         const char *accept_protocol;
121         enum ast_websocket_result result;
122
123         switch (cmd) {
124         case TEST_INIT:
125                 info->name = __func__;
126                 info->category = CATEGORY;
127                 info->summary = "websocket client - test multiple protocols";
128                 info->description = "test multi-protocol client";
129                 return AST_TEST_NOT_RUN;
130         case TEST_EXECUTE:
131                 break;
132         }
133
134         ast_test_validate(test, (client = ast_websocket_client_create(
135                                          REMOTE_URL, "echo,unsupported", NULL, &result)));
136
137         accept_protocol = ast_websocket_client_accept_protocol(client);
138         ast_test_validate(test, accept_protocol && !strcmp(accept_protocol, "echo"));
139
140         return AST_TEST_PASS;
141 }
142
143 static int load_module(void)
144 {
145         AST_TEST_REGISTER(websocket_client_create_and_connect);
146         AST_TEST_REGISTER(websocket_client_bad_url);
147         AST_TEST_REGISTER(websocket_client_unsupported_protocol);
148         AST_TEST_REGISTER(websocket_client_multiple_protocols);
149         return AST_MODULE_LOAD_SUCCESS;
150 }
151
152 static int unload_module(void)
153 {
154         AST_TEST_UNREGISTER(websocket_client_multiple_protocols);
155         AST_TEST_UNREGISTER(websocket_client_unsupported_protocol);
156         AST_TEST_UNREGISTER(websocket_client_bad_url);
157         AST_TEST_UNREGISTER(websocket_client_create_and_connect);
158         return 0;
159 }
160
161 AST_MODULE_INFO_STANDARD(ASTERISK_GPL_KEY, "Websocket client test module");