2 * Asterisk -- An open source telephony toolkit.
4 * Copyright (C) 2010, Digium, Inc.
6 * Russell Bryant <russell@digium.com>
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.
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.
21 * \brief Tests for the ast_event API
23 * \author Russell Bryant <russell@digium.com>
27 * \todo API Calls not yet touched by a test: XXX TODO
28 * - ast_event_queue_and_cache()
29 * - ast_event_get_cached()
30 * - ast_event_report_subs()
31 * - ast_event_dump_cache()
32 * - ast_event_get_ie_type_name()
33 * - ast_event_get_ie_pltype()
34 * - ast_event_str_to_event_type()
35 * - ast_event_str_to_ie_type()
36 * - ast_event_iterator_init()
37 * - ast_event_iterator_next()
38 * - ast_event_iterator_get_ie_type()
39 * - ast_event_iterator_get_ie_uint()
40 * - ast_event_iterator_get_ie_bitflags()
41 * - ast_event_iterator_get_ie_str()
42 * - ast_event_iterator_get_ie_raw()
46 <depend>TEST_FRAMEWORK</depend>
51 ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
53 #include "asterisk/module.h"
54 #include "asterisk/utils.h"
55 #include "asterisk/test.h"
56 #include "asterisk/event.h"
58 static int check_event(struct ast_event *event, struct ast_test *test,
59 enum ast_event_type expected_type, const char *type_name,
60 const char *str, uint32_t uint, uint32_t bitflags)
62 enum ast_event_type type;
65 /* Check #1: Ensure event type is set properly. */
66 type = ast_event_get_type(event);
67 if (ast_event_get_type(event) != type) {
68 ast_test_status_update(test, "Expected event type: '%d', got '%d'\n",
73 /* Check #2: Check string representation of event type */
74 if (strcmp(type_name, ast_event_get_type_name(event))) {
75 ast_test_status_update(test, "Didn't get expected type name: '%s' != '%s'\n",
76 type_name, ast_event_get_type_name(event));
80 /* Check #3: Check for automatically included EID */
81 if (memcmp(&ast_eid_default, ast_event_get_ie_raw(event, AST_EVENT_IE_EID), sizeof(ast_eid_default))) {
82 ast_test_status_update(test, "Failed to get EID\n");
86 /* Check #4: Check for the string IE */
87 if (strcmp(str, ast_event_get_ie_str(event, AST_EVENT_IE_MAILBOX))) {
88 ast_test_status_update(test, "Failed to get string IE.\n");
92 /* Check #5: Check for the uint IE */
93 if (uint != ast_event_get_ie_uint(event, AST_EVENT_IE_NEWMSGS)) {
94 ast_test_status_update(test, "Failed to get uint IE.\n");
98 /* Check #6: Check for the bitflags IE */
99 if (bitflags != ast_event_get_ie_bitflags(event, AST_EVENT_IE_OLDMSGS)) {
100 ast_test_status_update(test, "Failed to get bitflags IE.\n");
104 /* Check #7: Check if a check for a str IE that isn't there works */
105 if ((foo = ast_event_get_ie_str(event, AST_EVENT_IE_DEVICE))) {
106 ast_test_status_update(test, "DEVICE IE check returned non-NULL %p\n", foo);
110 /* Check #8: Check if a check for a uint IE that isn't there returns 0 */
111 if (ast_event_get_ie_uint(event, AST_EVENT_IE_STATE)) {
112 ast_test_status_update(test, "OLDMSGS IE should be 0\n");
116 ast_test_status_update(test, "Event looks good.\n");
124 AST_TEST_DEFINE(event_new_test)
126 enum ast_test_result_state res = AST_TEST_PASS;
127 struct ast_event *event = NULL, *event2 = NULL;
129 static const enum ast_event_type type = AST_EVENT_CUSTOM;
130 static const char str[] = "SIP/alligatormittens";
131 static const uint32_t uint = 0xb00bface;
132 static const uint32_t bitflags = 0x12488421;
136 info->name = "ast_event_new_test";
137 info->category = "/main/event/";
138 info->summary = "Test event creation";
140 "This test exercises the API calls that allow allocation "
142 return AST_TEST_NOT_RUN;
148 * Test 2 methods of event creation:
150 * 1) Dynamic via appending each IE individually.
151 * 2) Statically, with all IEs in ast_event_new().
154 ast_test_status_update(test, "First, test dynamic event creation...\n");
156 if (!(event = ast_event_new(type, AST_EVENT_IE_END))) {
157 ast_test_status_update(test, "Failed to allocate ast_event object.\n");
162 if (ast_event_append_ie_str(&event, AST_EVENT_IE_MAILBOX, str)) {
163 ast_test_status_update(test, "Failed to append str IE\n");
168 if (ast_event_append_ie_uint(&event, AST_EVENT_IE_NEWMSGS, uint)) {
169 ast_test_status_update(test, "Failed to append uint IE\n");
174 if (ast_event_append_ie_bitflags(&event, AST_EVENT_IE_OLDMSGS, bitflags)) {
175 ast_test_status_update(test, "Failed to append bitflags IE\n");
180 if (ast_event_append_eid(&event)) {
181 ast_test_status_update(test, "Failed to append EID\n");
186 if (check_event(event, test, type, "Custom", str, uint, bitflags)) {
187 ast_test_status_update(test, "Dynamically generated event broken\n");
192 event2 = ast_event_new(type,
193 AST_EVENT_IE_MAILBOX, AST_EVENT_IE_PLTYPE_STR, str,
194 AST_EVENT_IE_NEWMSGS, AST_EVENT_IE_PLTYPE_UINT, uint,
195 AST_EVENT_IE_OLDMSGS, AST_EVENT_IE_PLTYPE_BITFLAGS, bitflags,
199 ast_test_status_update(test, "Failed to allocate ast_event object.\n");
204 if (check_event(event2, test, type, "Custom", str, uint, bitflags)) {
205 ast_test_status_update(test, "Statically generated event broken\n");
210 if (ast_event_get_size(event) != ast_event_get_size(event2)) {
211 ast_test_status_update(test, "Events expected to be identical have different size: %d != %d\n",
212 (int) ast_event_get_size(event),
213 (int) ast_event_get_size(event2));
220 ast_event_destroy(event);
225 ast_event_destroy(event2);
232 struct event_sub_data {
236 static void event_sub_cb(const struct ast_event *event, void *d)
238 struct event_sub_data *data = d;
243 enum test_subs_class_type {
245 TEST_SUBS_CUSTOM_STR,
246 TEST_SUBS_CUSTOM_RAW,
247 TEST_SUBS_CUSTOM_UINT,
248 TEST_SUBS_CUSTOM_BITFLAGS,
249 TEST_SUBS_CUSTOM_EXISTS,
250 TEST_SUBS_CUSTOM_DYNAMIC,
251 TEST_SUBS_CUSTOM_ANY,
259 * \brief Convert enum test_subs_class_type to string.
261 * \param val Enum value to convert to string.
263 * \return String equivalent of enum value.
265 static const char *test_subs_class_type_str(enum test_subs_class_type val)
268 case TEST_SUBS_ALL_STR:
269 return "TEST_SUBS_ALL_STR";
270 case TEST_SUBS_CUSTOM_STR:
271 return "TEST_SUBS_CUSTOM_STR";
272 case TEST_SUBS_CUSTOM_RAW:
273 return "TEST_SUBS_CUSTOM_RAW";
274 case TEST_SUBS_CUSTOM_UINT:
275 return "TEST_SUBS_CUSTOM_UINT";
276 case TEST_SUBS_CUSTOM_BITFLAGS:
277 return "TEST_SUBS_CUSTOM_BITFLAGS";
278 case TEST_SUBS_CUSTOM_EXISTS:
279 return "TEST_SUBS_CUSTOM_EXISTS";
280 case TEST_SUBS_CUSTOM_DYNAMIC:
281 return "TEST_SUBS_CUSTOM_DYNAMIC";
282 case TEST_SUBS_CUSTOM_ANY:
283 return "TEST_SUBS_CUSTOM_ANY";
284 case TEST_SUBS_TOTAL:
292 * \brief Test event subscriptions
294 * - Query for existing Subscriptions:
295 * - ast_event_check_subscriber()
297 AST_TEST_DEFINE(event_sub_test)
299 enum ast_test_result_state res = AST_TEST_PASS;
300 struct ast_event *event;
302 enum ast_event_subscriber_res sub_res;
304 struct ast_event_sub *sub;
305 struct event_sub_data data;
306 const unsigned int expected_count;
307 } test_subs[TEST_SUBS_TOTAL] = {
308 [TEST_SUBS_ALL_STR] = {
311 [TEST_SUBS_CUSTOM_STR] = {
314 [TEST_SUBS_CUSTOM_RAW] = {
317 [TEST_SUBS_CUSTOM_UINT] = {
320 [TEST_SUBS_CUSTOM_BITFLAGS] = {
323 [TEST_SUBS_CUSTOM_EXISTS] = {
326 [TEST_SUBS_CUSTOM_DYNAMIC] = {
329 [TEST_SUBS_CUSTOM_ANY] = {
336 info->name = "ast_event_subscribe_test";
337 info->category = "/main/event/";
338 info->summary = "Test event subscriptions";
340 "This test exercises the API calls that allow subscriptions "
342 return AST_TEST_NOT_RUN;
348 * Subscription TEST_SUBS_ALL_STR:
349 * - allocate normally
350 * - subscribe to ALL events with a DEVICE STR IE check
352 ast_test_status_update(test, "Adding TEST_SUBS_ALL_STR subscription\n");
353 test_subs[TEST_SUBS_ALL_STR].sub = ast_event_subscribe(AST_EVENT_ALL, event_sub_cb,
354 test_subs_class_type_str(TEST_SUBS_ALL_STR), &test_subs[TEST_SUBS_ALL_STR].data,
355 AST_EVENT_IE_DEVICE, AST_EVENT_IE_PLTYPE_STR, "FOO/bar",
357 if (!test_subs[TEST_SUBS_ALL_STR].sub) {
358 ast_test_status_update(test, "Failed to create TEST_SUBS_ALL_STR subscription\n");
363 if (strcmp(ast_event_subscriber_get_description(test_subs[TEST_SUBS_ALL_STR].sub),
364 test_subs_class_type_str(TEST_SUBS_ALL_STR))) {
365 ast_test_status_update(test,
366 "Unexpected subscription description on TEST_SUBS_ALL_STR subscription\n");
372 * Subscription TEST_SUBS_CUSTOM_STR:
373 * - allocate normally
374 * - subscribe to CUSTOM events with a DEVICE STR IE check
376 ast_test_status_update(test, "Adding TEST_SUBS_CUSTOM_STR subscription\n");
377 test_subs[TEST_SUBS_CUSTOM_STR].sub = ast_event_subscribe(AST_EVENT_CUSTOM, event_sub_cb,
378 test_subs_class_type_str(TEST_SUBS_CUSTOM_STR), &test_subs[TEST_SUBS_CUSTOM_STR].data,
379 AST_EVENT_IE_DEVICE, AST_EVENT_IE_PLTYPE_STR, "FOO/bar",
381 if (!test_subs[TEST_SUBS_CUSTOM_STR].sub) {
382 ast_test_status_update(test, "Failed to create TEST_SUBS_CUSTOM_STR subscription\n");
387 if (strcmp(ast_event_subscriber_get_description(test_subs[TEST_SUBS_CUSTOM_STR].sub),
388 test_subs_class_type_str(TEST_SUBS_CUSTOM_STR))) {
389 ast_test_status_update(test,
390 "Unexpected subscription description on TEST_SUBS_CUSTOM_STR subscription\n");
396 * Subscription TEST_SUBS_CUSTOM_RAW:
397 * - allocate normally
398 * - subscribe to CUSTOM events with a MAILBOX RAW IE check
400 ast_test_status_update(test, "Adding TEST_SUBS_CUSTOM_RAW subscription\n");
401 test_subs[TEST_SUBS_CUSTOM_RAW].sub = ast_event_subscribe(AST_EVENT_CUSTOM, event_sub_cb,
402 test_subs_class_type_str(TEST_SUBS_CUSTOM_RAW), &test_subs[TEST_SUBS_CUSTOM_RAW].data,
403 AST_EVENT_IE_MAILBOX, AST_EVENT_IE_PLTYPE_RAW, "FOO/bar", sizeof("FOO/bar"),
405 if (!test_subs[TEST_SUBS_CUSTOM_RAW].sub) {
406 ast_test_status_update(test, "Failed to create TEST_SUBS_CUSTOM_RAW subscription\n");
411 if (strcmp(ast_event_subscriber_get_description(test_subs[TEST_SUBS_CUSTOM_RAW].sub),
412 test_subs_class_type_str(TEST_SUBS_CUSTOM_RAW))) {
413 ast_test_status_update(test,
414 "Unexpected subscription description on TEST_SUBS_CUSTOM_RAW subscription\n");
420 * Subscription TEST_SUBS_CUSTOM_UINT:
421 * - allocate normally
422 * - subscribe to CUSTOM events with a NEWMSGS UINT IE check
424 ast_test_status_update(test, "Adding TEST_SUBS_CUSTOM_UINT subscription\n");
425 test_subs[TEST_SUBS_CUSTOM_UINT].sub = ast_event_subscribe(AST_EVENT_CUSTOM, event_sub_cb,
426 test_subs_class_type_str(TEST_SUBS_CUSTOM_UINT), &test_subs[TEST_SUBS_CUSTOM_UINT].data,
427 AST_EVENT_IE_NEWMSGS, AST_EVENT_IE_PLTYPE_UINT, 5,
429 if (!test_subs[TEST_SUBS_CUSTOM_UINT].sub) {
430 ast_test_status_update(test, "Failed to create TEST_SUBS_CUSTOM_UINT subscription\n");
435 if (strcmp(ast_event_subscriber_get_description(test_subs[TEST_SUBS_CUSTOM_UINT].sub),
436 test_subs_class_type_str(TEST_SUBS_CUSTOM_UINT))) {
437 ast_test_status_update(test,
438 "Unexpected subscription description on TEST_SUBS_CUSTOM_UINT subscription\n");
444 * Subscription TEST_SUBS_CUSTOM_BITFLAGS:
445 * - allocate normally
446 * - subscribe to CUSTOM events with a NEWMSGS BITFLAGS IE check
448 ast_test_status_update(test, "Adding TEST_SUBS_CUSTOM_BITFLAGS subscription\n");
449 test_subs[TEST_SUBS_CUSTOM_BITFLAGS].sub = ast_event_subscribe(AST_EVENT_CUSTOM, event_sub_cb,
450 test_subs_class_type_str(TEST_SUBS_CUSTOM_BITFLAGS), &test_subs[TEST_SUBS_CUSTOM_BITFLAGS].data,
451 AST_EVENT_IE_NEWMSGS, AST_EVENT_IE_PLTYPE_BITFLAGS, 0x06,
453 if (!test_subs[TEST_SUBS_CUSTOM_BITFLAGS].sub) {
454 ast_test_status_update(test, "Failed to create TEST_SUBS_CUSTOM_BITFLAGS subscription\n");
459 if (strcmp(ast_event_subscriber_get_description(test_subs[TEST_SUBS_CUSTOM_BITFLAGS].sub),
460 test_subs_class_type_str(TEST_SUBS_CUSTOM_BITFLAGS))) {
461 ast_test_status_update(test,
462 "Unexpected subscription description on TEST_SUBS_CUSTOM_BITFLAGS subscription\n");
468 * Subscription TEST_SUBS_CUSTOM_EXISTS:
469 * - allocate normally
470 * - subscribe to CUSTOM events with a NEWMSGS UINT and OLDMSGS EXISTS IE check
472 ast_test_status_update(test, "Adding TEST_SUBS_CUSTOM_EXISTS subscription\n");
473 test_subs[TEST_SUBS_CUSTOM_EXISTS].sub = ast_event_subscribe(AST_EVENT_CUSTOM, event_sub_cb,
474 test_subs_class_type_str(TEST_SUBS_CUSTOM_EXISTS), &test_subs[TEST_SUBS_CUSTOM_EXISTS].data,
475 AST_EVENT_IE_NEWMSGS, AST_EVENT_IE_PLTYPE_UINT, 4,
476 AST_EVENT_IE_OLDMSGS, AST_EVENT_IE_PLTYPE_EXISTS,
478 if (!test_subs[TEST_SUBS_CUSTOM_EXISTS].sub) {
479 ast_test_status_update(test, "Failed to create TEST_SUBS_CUSTOM_EXISTS subscription\n");
484 if (strcmp(ast_event_subscriber_get_description(test_subs[TEST_SUBS_CUSTOM_EXISTS].sub),
485 test_subs_class_type_str(TEST_SUBS_CUSTOM_EXISTS))) {
486 ast_test_status_update(test,
487 "Unexpected subscription description on TEST_SUBS_CUSTOM_EXISTS subscription\n");
492 /* For the sake of exercising destruction before activation */
493 test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub = ast_event_subscribe_new(AST_EVENT_CUSTOM,
494 event_sub_cb, &test_subs[TEST_SUBS_CUSTOM_DYNAMIC].data);
495 if (!test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub) {
496 ast_test_status_update(test, "Failed to create TEST_SUBS_CUSTOM_DYNAMIC subscription\n");
500 ast_event_sub_destroy(test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub);
503 * Subscription TEST_SUBS_CUSTOM_DYNAMIC:
504 * - allocate dynamically
505 * - subscribe to all CUSTOM events
506 * - add IE checks for all types
508 ast_test_status_update(test, "Adding TEST_SUBS_CUSTOM_DYNAMIC subscription\n");
509 test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub = ast_event_subscribe_new(AST_EVENT_CUSTOM,
510 event_sub_cb, &test_subs[TEST_SUBS_CUSTOM_DYNAMIC].data);
511 if (!test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub) {
512 ast_test_status_update(test, "Failed to create TEST_SUBS_CUSTOM_DYNAMIC subscription\n");
517 if (strcmp(ast_event_subscriber_get_description(test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub),
519 ast_event_sub_destroy(test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub);
520 test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub = NULL;
521 ast_test_status_update(test,
522 "Unexpected subscription description on TEST_SUBS_CUSTOM_DYNAMIC subscription\n");
527 if (ast_event_sub_append_ie_uint(test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub, AST_EVENT_IE_NEWMSGS, 4)) {
528 ast_event_sub_destroy(test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub);
529 test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub = NULL;
530 ast_test_status_update(test, "Failed to append UINT IE to TEST_SUBS_CUSTOM_DYNAMIC subscription\n");
535 if (ast_event_sub_append_ie_bitflags(test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub, AST_EVENT_IE_OLDMSGS, 1)) {
536 ast_event_sub_destroy(test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub);
537 test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub = NULL;
538 ast_test_status_update(test, "Failed to append BITFLAGS IE to TEST_SUBS_CUSTOM_DYNAMIC subscription\n");
543 if (ast_event_sub_append_ie_str(test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub, AST_EVENT_IE_DEVICE, "FOO/bar")) {
544 ast_event_sub_destroy(test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub);
545 test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub = NULL;
546 ast_test_status_update(test, "Failed to append STR IE to TEST_SUBS_CUSTOM_DYNAMIC subscription\n");
551 if (ast_event_sub_append_ie_raw(test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub, AST_EVENT_IE_MAILBOX, "800 km",
553 ast_event_sub_destroy(test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub);
554 test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub = NULL;
555 ast_test_status_update(test, "Failed to append RAW IE to TEST_SUBS_CUSTOM_DYNAMIC subscription\n");
560 if (ast_event_sub_append_ie_exists(test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub, AST_EVENT_IE_STATE)) {
561 ast_event_sub_destroy(test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub);
562 test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub = NULL;
563 ast_test_status_update(test, "Failed to append EXISTS IE to TEST_SUBS_CUSTOM_DYNAMIC subscription\n");
568 if (ast_event_sub_activate(test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub)) {
569 ast_event_sub_destroy(test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub);
570 test_subs[TEST_SUBS_CUSTOM_DYNAMIC].sub = NULL;
571 ast_test_status_update(test, "Failed to activate TEST_SUBS_CUSTOM_DYNAMIC subscription\n");
577 * Exercise the API call to check for existing subscriptions.
579 ast_test_status_update(test, "Checking for subscribers to events\n");
581 /* Check STR matching. */
582 sub_res = ast_event_check_subscriber(AST_EVENT_CUSTOM,
583 AST_EVENT_IE_DEVICE, AST_EVENT_IE_PLTYPE_STR, "FOO/bar",
585 if (sub_res != AST_EVENT_SUB_EXISTS) {
586 ast_test_status_update(test, "Str FOO/bar subscription did not exist\n");
590 sub_res = ast_event_check_subscriber(AST_EVENT_CUSTOM,
591 AST_EVENT_IE_DEVICE, AST_EVENT_IE_PLTYPE_STR, "Money",
593 if (sub_res != AST_EVENT_SUB_NONE) {
594 ast_test_status_update(test, "Str Money subscription should not exist! (%d)\n",
599 /* Check RAW matching. */
600 sub_res = ast_event_check_subscriber(AST_EVENT_CUSTOM,
601 AST_EVENT_IE_MAILBOX, AST_EVENT_IE_PLTYPE_RAW, "FOO/bar", sizeof("FOO/bar"),
603 if (sub_res != AST_EVENT_SUB_EXISTS) {
604 ast_test_status_update(test, "Raw FOO/bar subscription did not exist\n");
608 sub_res = ast_event_check_subscriber(AST_EVENT_CUSTOM,
609 AST_EVENT_IE_MAILBOX, AST_EVENT_IE_PLTYPE_RAW, "FOO/bar", sizeof("FOO/bar") - 1,
611 if (sub_res != AST_EVENT_SUB_NONE) {
612 ast_test_status_update(test, "Raw FOO/bar-1 subscription should not exist! (%d)\n",
617 sub_res = ast_event_check_subscriber(AST_EVENT_CUSTOM,
618 AST_EVENT_IE_MAILBOX, AST_EVENT_IE_PLTYPE_RAW, "Monkeys", sizeof("Monkeys"),
620 if (sub_res != AST_EVENT_SUB_NONE) {
621 ast_test_status_update(test, "Raw Monkeys subscription should not exist! (%d)\n",
626 /* Check UINT matching. */
627 sub_res = ast_event_check_subscriber(AST_EVENT_CUSTOM,
628 AST_EVENT_IE_NEWMSGS, AST_EVENT_IE_PLTYPE_UINT, 5,
630 if (sub_res != AST_EVENT_SUB_EXISTS) {
631 ast_test_status_update(test, "UINT=5 subscription did not exist\n");
635 sub_res = ast_event_check_subscriber(AST_EVENT_CUSTOM,
636 AST_EVENT_IE_NEWMSGS, AST_EVENT_IE_PLTYPE_UINT, 1,
638 if (sub_res != AST_EVENT_SUB_NONE) {
639 ast_test_status_update(test, "UINT=1 subscription should not exist! (%d)\n",
644 /* Check BITFLAGS matching. */
645 sub_res = ast_event_check_subscriber(AST_EVENT_CUSTOM,
646 AST_EVENT_IE_NEWMSGS, AST_EVENT_IE_PLTYPE_BITFLAGS, 2,
648 if (sub_res != AST_EVENT_SUB_EXISTS) {
649 ast_test_status_update(test, "BITFLAGS=2 subscription did not exist\n");
653 sub_res = ast_event_check_subscriber(AST_EVENT_CUSTOM,
654 AST_EVENT_IE_NEWMSGS, AST_EVENT_IE_PLTYPE_BITFLAGS, 8,
656 if (sub_res != AST_EVENT_SUB_NONE) {
657 ast_test_status_update(test, "BITFLAGS=8 subscription should not exist! (%d)\n",
662 /* Check EXISTS matching. */
663 sub_res = ast_event_check_subscriber(AST_EVENT_CUSTOM,
664 AST_EVENT_IE_NEWMSGS, AST_EVENT_IE_PLTYPE_UINT, 4,
665 AST_EVENT_IE_OLDMSGS, AST_EVENT_IE_PLTYPE_UINT, 100,
667 if (sub_res != AST_EVENT_SUB_EXISTS) {
668 ast_test_status_update(test, "EXISTS subscription did not exist\n");
672 sub_res = ast_event_check_subscriber(AST_EVENT_CUSTOM,
673 AST_EVENT_IE_NEWMSGS, AST_EVENT_IE_PLTYPE_UINT, 4,
675 if (sub_res != AST_EVENT_SUB_NONE) {
676 ast_test_status_update(test, "EXISTS subscription should not exist! (%d)\n",
682 * Subscription TEST_SUBS_CUSTOM_ANY:
683 * - allocate normally
684 * - subscribe to all CUSTOM events
686 ast_test_status_update(test, "Adding TEST_SUBS_CUSTOM_ANY subscription\n");
687 test_subs[TEST_SUBS_CUSTOM_ANY].sub = ast_event_subscribe(AST_EVENT_CUSTOM, event_sub_cb,
688 test_subs_class_type_str(TEST_SUBS_CUSTOM_ANY), &test_subs[TEST_SUBS_CUSTOM_ANY].data,
690 if (!test_subs[TEST_SUBS_CUSTOM_ANY].sub) {
691 ast_test_status_update(test, "Failed to create TEST_SUBS_CUSTOM_ANY subscription\n");
696 if (strcmp(ast_event_subscriber_get_description(test_subs[TEST_SUBS_CUSTOM_ANY].sub),
697 test_subs_class_type_str(TEST_SUBS_CUSTOM_ANY))) {
698 ast_test_status_update(test,
699 "Unexpected subscription description on TEST_SUBS_CUSTOM_ANY subscription\n");
705 * Fire off some events and track what was received in the callback
707 ast_test_status_update(test, "Posting test events\n");
710 * Event to check STR matching.
712 * Matching subscriptions:
714 * TEST_SUBS_CUSTOM_STR
715 * TEST_SUBS_CUSTOM_ANY
717 event = ast_event_new(AST_EVENT_CUSTOM,
718 AST_EVENT_IE_MAILBOX, AST_EVENT_IE_PLTYPE_RAW, "FOO/bar", sizeof("FOO/bar") - 1,
719 AST_EVENT_IE_DEVICE, AST_EVENT_IE_PLTYPE_STR, "FOO/bar",
722 ast_test_status_update(test, "Failed to create event\n");
726 if (ast_event_queue(event)) {
727 ast_event_destroy(event);
729 ast_test_status_update(test, "Failed to queue event\n");
735 * Event to check RAW matching.
737 * Matching subscriptions:
738 * TEST_SUBS_CUSTOM_RAW
739 * TEST_SUBS_CUSTOM_ANY
741 event = ast_event_new(AST_EVENT_CUSTOM,
742 AST_EVENT_IE_DEVICE, AST_EVENT_IE_PLTYPE_STR, "Misery",
743 AST_EVENT_IE_MAILBOX, AST_EVENT_IE_PLTYPE_RAW, "FOO/bar", sizeof("FOO/bar"),
746 ast_test_status_update(test, "Failed to create event\n");
750 if (ast_event_queue(event)) {
751 ast_event_destroy(event);
753 ast_test_status_update(test, "Failed to queue event\n");
759 * Event to check UINT matching.
761 * Matching subscriptions:
762 * TEST_SUBS_CUSTOM_UINT
763 * TEST_SUBS_CUSTOM_BITFLAGS
764 * TEST_SUBS_CUSTOM_ANY
766 event = ast_event_new(AST_EVENT_CUSTOM,
767 AST_EVENT_IE_NEWMSGS, AST_EVENT_IE_PLTYPE_UINT, 5,
770 ast_test_status_update(test, "Failed to create event\n");
774 if (ast_event_queue(event)) {
775 ast_event_destroy(event);
777 ast_test_status_update(test, "Failed to queue event\n");
783 * Event to check BITFLAGS matching.
785 * Matching subscriptions:
786 * TEST_SUBS_CUSTOM_BITFLAGS
787 * TEST_SUBS_CUSTOM_ANY
789 event = ast_event_new(AST_EVENT_CUSTOM,
790 AST_EVENT_IE_NEWMSGS, AST_EVENT_IE_PLTYPE_UINT, 4,
793 ast_test_status_update(test, "Failed to create event\n");
797 if (ast_event_queue(event)) {
798 ast_event_destroy(event);
800 ast_test_status_update(test, "Failed to queue event\n");
806 * Event to check EXISTS matching.
808 * Matching subscriptions:
809 * TEST_SUBS_CUSTOM_EXISTS
810 * TEST_SUBS_CUSTOM_BITFLAGS
811 * TEST_SUBS_CUSTOM_ANY
813 event = ast_event_new(AST_EVENT_CUSTOM,
814 AST_EVENT_IE_NEWMSGS, AST_EVENT_IE_PLTYPE_UINT, 4,
815 AST_EVENT_IE_OLDMSGS, AST_EVENT_IE_PLTYPE_UINT, 4,
818 ast_test_status_update(test, "Failed to create event\n");
822 if (ast_event_queue(event)) {
823 ast_event_destroy(event);
825 ast_test_status_update(test, "Failed to queue event\n");
831 * Event to get dynamic subscription to have an event.
833 * Matching subscriptions:
834 * TEST_SUBS_CUSTOM_DYNAMIC
835 * TEST_SUBS_CUSTOM_BITFLAGS
836 * TEST_SUBS_CUSTOM_EXISTS
838 * TEST_SUBS_CUSTOM_STR
839 * TEST_SUBS_CUSTOM_ANY
841 event = ast_event_new(AST_EVENT_CUSTOM,
842 AST_EVENT_IE_NEWMSGS, AST_EVENT_IE_PLTYPE_UINT, 4,
843 AST_EVENT_IE_OLDMSGS, AST_EVENT_IE_PLTYPE_UINT, 5,
844 AST_EVENT_IE_MAILBOX, AST_EVENT_IE_PLTYPE_RAW, "800 km", strlen("800 km"),
845 AST_EVENT_IE_DEVICE, AST_EVENT_IE_PLTYPE_STR, "FOO/bar",
846 AST_EVENT_IE_STATE, AST_EVENT_IE_PLTYPE_UINT, 5,
849 ast_test_status_update(test, "Failed to create event\n");
853 if (ast_event_queue(event)) {
854 ast_event_destroy(event);
856 ast_test_status_update(test, "Failed to queue event\n");
864 * Check the results of the test.
866 * First of all, event distribution is asynchronous from the event producer,
867 * so knowing when to continue from here and check results is an instance of
868 * the halting problem. A few seconds really should be more than enough time.
869 * If something was actually blocking event distribution that long, I would call
872 * See test_subs[] initialization for expected results.
875 ast_test_status_update(test, "Sleeping a few seconds to allow event propagation...\n");
878 for (i = 0; i < ARRAY_LEN(test_subs); i++) {
879 if (!test_subs[i].sub) {
880 ast_test_status_update(test, "Missing a test subscription for %s\n",
881 test_subs_class_type_str(i));
884 if (test_subs[i].data.count != test_subs[i].expected_count) {
885 ast_test_status_update(test,
886 "Unexpected callback count, got %u expected %u for %s\n",
887 test_subs[i].data.count, test_subs[i].expected_count,
888 test_subs_class_type_str(i));
894 for (i = 0; i < ARRAY_LEN(test_subs); i++) {
895 if (test_subs[i].sub) {
896 test_subs[i].sub = ast_event_unsubscribe(test_subs[i].sub);
903 static int unload_module(void)
905 AST_TEST_UNREGISTER(event_new_test);
906 AST_TEST_UNREGISTER(event_sub_test);
911 static int load_module(void)
913 AST_TEST_REGISTER(event_new_test);
914 AST_TEST_REGISTER(event_sub_test);
916 return AST_MODULE_LOAD_SUCCESS;
919 AST_MODULE_INFO_STANDARD(ASTERISK_GPL_KEY, "ast_event API Tests");