3 ==================================================================================
4 Copyright (c) 2019 Nokia
5 Copyright (c) 2018-2019 AT&T Intellectual Property.
7 Licensed under the Apache License, Version 2.0 (the "License");
8 you may not use this file except in compliance with the License.
9 You may obtain a copy of the License at
11 http://www.apache.org/licenses/LICENSE-2.0
13 Unless required by applicable law or agreed to in writing, software
14 distributed under the License is distributed on an "AS IS" BASIS,
15 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 See the License for the specific language governing permissions and
17 limitations under the License.
18 ==================================================================================
22 Mmemonic: rmr_nng_test.c
23 Abstract: This tests the whole rmr nng implementation. This driver
24 includes all of the module specific unit test static files
25 (e.g. wormhole_static_test.c) and drives the tests contained
26 there. The individual modules allow them to be driven by
27 a standalone driver, and to be maintained separately. We must
28 test by inclusion because of the static nature of the internal
29 functions of the library.
31 Author: E. Scott Daniels
32 Date: 18 January 2018 (IMO HRTL)
53 #include <sys/epoll.h>
55 #include <semaphore.h>
60 #include <nng/protocol/pubsub0/pub.h>
61 #include <nng/protocol/pubsub0/sub.h>
62 #include <nng/protocol/pipeline0/push.h>
63 #include <nng/protocol/pipeline0/pull.h>
65 #define NNG_UNDER_TEST 1
67 #include "test_nng_em.c" // nng/nn emulation (before including things under test)
70 #include "rmr.h" // things the users see
71 #include "rmr_symtab.h"
72 #include "rmr_logging.h"
73 #include "rmr_agnostic.h" // transport agnostic header
80 static void gen_rt( uta_ctx_t* ctx ); // defined in sr_nng_static_test, but used by a few others (eliminate order requirement below)
82 // specific test tools in this directory
83 #include "test_support.c" // things like fail_if()
84 #include "test_ctx_support.c" // specifically geared to creating dummy contex structs
85 #include "test_gen_rt.c"
87 #include "tools_static_test.c" // local test functions pulled directly because of static nature of things
88 #include "symtab_static_test.c"
89 #include "ring_static_test.c"
90 #include "rt_static_test.c"
91 #include "sr_nng_static_test.c"
92 #include "wormhole_static_test.c"
93 #include "rmr_nng_api_static_test.c"
94 #include "mbuf_api_static_test.c"
98 Drive each of the separate tests and report.
103 fprintf( stderr, "\n<INFO> starting tool tests\n" );
104 errors += tools_test();
105 fprintf( stderr, "<INFO> error count: %d\n", errors );
107 fprintf( stderr, "\n<INFO> starting ring tests (%d)\n", errors );
108 errors += ring_test();
109 fprintf( stderr, "<INFO> error count: %d\n", errors );
111 fprintf( stderr, "\n<INFO> starting symtab tests\n" );
112 errors += symtab_test( );
113 fprintf( stderr, "<INFO> error count: %d\n", errors );
115 fprintf( stderr, "\n<INFO> starting rtable tests\n" );
116 errors += rt_test(); // route table tests
117 fprintf( stderr, "<INFO> error count: %d\n", errors );
119 fprintf( stderr, "\n<INFO> starting RMr API tests\n" );
120 errors += rmr_api_test();
122 fprintf( stderr, "\n<INFO> run RMr API tests with src name only env var set\n" );
123 setenv( "RMR_SRC_NAMEONLY", "1", 1 );
124 errors += rmr_api_test();
125 fprintf( stderr, "<INFO> error count: %d\n", errors );
127 fprintf( stderr, "\n<INFO> starting wormhole tests\n" );
128 errors += worm_test(); // test wormhole funcitons
129 fprintf( stderr, "<INFO> error count: %d\n", errors );
131 fprintf( stderr, "\n<INFO> starting send/receive tests\n" );
132 errors += sr_nng_test(); // test the send/receive static functions
133 fprintf( stderr, "<INFO> error count: %d\n", errors );
135 fprintf( stderr, "\n<INFO> starting mbuf api tests\n" );
136 errors += mbuf_api_test( );
137 fprintf( stderr, "<INFO> error count: %d\n", errors );
140 fprintf( stderr, "<PASS> all tests were OK\n\n" );
142 fprintf( stderr, "<FAIL> %d modules reported errors\n\n", errors );