From 8cdfe9fc37819051187ad02dca20d8b75c701b0b Mon Sep 17 00:00:00 2001 From: Holger Hans Peter Freyther Date: Thu, 1 Apr 2010 03:55:27 +0200 Subject: nat: Add code to find a BSC connection by the given msc multiplex --- openbsc/tests/bsc-nat/bsc_nat_test.c | 45 ++++++++++++++++++++++++++++++++++-- 1 file changed, 43 insertions(+), 2 deletions(-) (limited to 'openbsc/tests') diff --git a/openbsc/tests/bsc-nat/bsc_nat_test.c b/openbsc/tests/bsc-nat/bsc_nat_test.c index 70e98d721..30f1490f1 100644 --- a/openbsc/tests/bsc-nat/bsc_nat_test.c +++ b/openbsc/tests/bsc-nat/bsc_nat_test.c @@ -335,7 +335,7 @@ static void test_paging(void) talloc_free(parsed); } -static void test_mgcp(void) +static void test_mgcp_ass_tracking(void) { struct sccp_connections con; struct bsc_nat_parsed *parsed; @@ -370,6 +370,46 @@ static void test_mgcp(void) } } +/* test the code to find a given connection */ +static void test_mgcp_find(void) +{ + struct bsc_nat *nat; + struct bsc_connection *con; + struct sccp_connections *sccp_con; + + fprintf(stderr, "Testing finding of a BSC Connection\n"); + + nat = bsc_nat_alloc(); + con = bsc_connection_alloc(nat); + llist_add(&con->list_entry, &nat->bsc_connections); + + sccp_con = talloc_zero(con, struct sccp_connections); + sccp_con->msc_timeslot = 12; + sccp_con->bsc_timeslot = 12; + sccp_con->bsc = con; + llist_add(&sccp_con->list_entry, &nat->sccp_connections); + + if (bsc_mgcp_find_con(nat, 11) != NULL) { + fprintf(stderr, "Found the wrong connection.\n"); + abort(); + } + + if (bsc_mgcp_find_con(nat, 12) != con) { + fprintf(stderr, "Didn't find the connection\n"); + abort(); + } + + sccp_con->msc_timeslot = 0; + sccp_con->bsc_timeslot = 0; + if (bsc_mgcp_find_con(nat, 1) != con) { + fprintf(stderr, "Didn't find the connection\n"); + abort(); + } + + /* free everything */ + talloc_free(nat); +} + int main(int argc, char **argv) { struct debug_target *stderr_target; @@ -381,7 +421,8 @@ int main(int argc, char **argv) test_filter(); test_contrack(); test_paging(); - test_mgcp(); + test_mgcp_ass_tracking(); + test_mgcp_find(); return 0; } -- cgit v1.2.3