1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/tests/unittests/tests-fib_sr/tests-fib_sr.c

736 lines
28 KiB
C
Raw Normal View History

2015-08-05 14:40:49 +02:00
/*
* Copyright (C) 2015 Martin Landsmann
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
2015-08-05 14:40:49 +02:00
#include <stdio.h> /**< required for snprintf() */
#include <string.h>
#include <errno.h>
#include "embUnit.h"
#include "tests-fib_sr.h"
#include "thread.h"
#include "net/fib.h"
#include "universal_address.h"
/**
* @brief maximum number of source routes
*/
#define TEST_MAX_FIB_SR (20)
/**
* @brief maximum number of entries in all source routes
*/
#define TEST_MAX_FIB_SR_ENTRIES (TEST_MAX_FIB_SR * 20)
/**
* @brief the FIB source route headers
*/
static fib_sr_t _sr_headers[TEST_MAX_FIB_SR];
/**
* @brief the FIB source route table entries pool
*/
static fib_sr_entry_t _sr_datapool[TEST_MAX_FIB_SR_ENTRIES];
/**
* @brief the FIB source route table "glue container"
*/
static fib_sr_meta_t _entries_sr = { .headers = _sr_headers,
.entry_pool = _sr_datapool,
.entry_pool_size = TEST_MAX_FIB_SR_ENTRIES };
2015-08-05 14:40:49 +02:00
/**
* @brief the FIB source route table
* @note is initialized in the entry function of this unittest
*/
static fib_table_t test_fib_sr_table;
2015-12-19 21:56:50 +01:00
/*
* @brief helper function to create source routes.
2019-10-23 21:14:18 +02:00
* The entries are constructed with the given prefix and numbers
* counted from the given count borders (from and to).
* @param[in] pre prefix string to use
* @param[in] from starting index to count from
* @param[in] to last index to count to
* @param[in] sr the source route to append the created entries
* @param[in] buf_size the size in bytes for each address to be created
*/
static int _create_sr(const char *pre, size_t from, size_t to, fib_sr_t *sr, size_t buf_size)
2015-12-19 21:56:50 +01:00
{
char addr_nxt[buf_size];
2015-12-19 21:56:50 +01:00
strncpy(addr_nxt, pre, strlen(pre));
for (size_t i = from; i < to; ++i) {
int res;
snprintf(&(addr_nxt[strlen(pre)]), buf_size, "%d", (int)i);
/* append a hop */
res = fib_sr_entry_append(&test_fib_sr_table, sr, (uint8_t *)&addr_nxt, buf_size);
if (res != 0) {
return res;
}
}
return 0;
}
2015-08-05 14:40:49 +02:00
/*
* @brief create a new empty source route and check the parameters
* It is expected to have a new source route with the given parameters
*/
2015-08-05 14:40:49 +02:00
static void test_fib_sr_01_create_empty_sr(void)
{
fib_sr_t *local_sourceroutes[1];
TEST_ASSERT_EQUAL_INT(0, fib_sr_create(&test_fib_sr_table, &local_sourceroutes[0],
42, 0x0, 10000));
kernel_pid_t sr_iface_id;
uint32_t sr_flags;
uint32_t sr_lifetime;
TEST_ASSERT_EQUAL_INT(0, fib_sr_read_head(&test_fib_sr_table, local_sourceroutes[0],
&sr_iface_id, &sr_flags,
&sr_lifetime)
);
2015-08-05 14:40:49 +02:00
TEST_ASSERT_EQUAL_INT(42, sr_iface_id);
TEST_ASSERT_EQUAL_INT(0x0, sr_flags);
/* the lifetime should decrease
* Since the FIB uses timex under the hood which has a finer grained resolution
* testing the lifetime requires to active wait a bit, say 5 ms.
* Uncomment the following two lines if you want to test the temporal behaviour
* @note this may fail since unittests are currently not thread-friendly
*/
//xtimer_usleep(5 * US_PER_MS);
2015-08-05 14:40:49 +02:00
//TEST_ASSERT(sr_lifetime<10000);
fib_deinit(&test_fib_sr_table);
}
/*
* @brief create a new empty source route, change its parameters
* and check the change
* It is expected to have a new source route with the given adjusted parameters
*/
2015-08-05 14:40:49 +02:00
static void test_fib_sr_02_change_sr_parameters(void)
{
fib_sr_t *local_sourceroutes[1];
TEST_ASSERT_EQUAL_INT(0, fib_sr_create(&test_fib_sr_table, &local_sourceroutes[0],
42, 0x0, 10000));
/* Case 01 - re-set all parameters */
kernel_pid_t sr_iface_id = 43;
uint32_t sr_flags = 0x99;
uint32_t sr_lifetime = 20000;
TEST_ASSERT_EQUAL_INT(0, fib_sr_set(&test_fib_sr_table, local_sourceroutes[0],
&sr_iface_id, &sr_flags, &sr_lifetime));
TEST_ASSERT_EQUAL_INT(0, fib_sr_read_head(&test_fib_sr_table, local_sourceroutes[0],
&sr_iface_id, &sr_flags,
&sr_lifetime)
);
2015-08-05 14:40:49 +02:00
TEST_ASSERT_EQUAL_INT(43, sr_iface_id);
TEST_ASSERT_EQUAL_INT(0x99, sr_flags);
/* the lifetime should be slightly below 20000
* Since the FIB uses timex under the hood which has a finer grained resolution
* testing the lifetime requires to active wait a bit, say 5 ms.
* Uncomment the following three lines if you want to test the temporal behaviour
* @note this may fail since unittests are currently not thread-friendly
*/
//xtimer_usleep(5 * US_PER_MS);
2015-08-05 14:40:49 +02:00
//TEST_ASSERT(sr_lifetime>10000);
//TEST_ASSERT(sr_lifetime<20000);
fib_deinit(&test_fib_sr_table);
}
/*
* @brief check errors on reading sr parameters and trying to access an expired sr
*/
2015-08-05 14:40:49 +02:00
static void test_fib_sr_03_read_sr_parameters(void)
{
fib_sr_t *local_sourceroutes[1];
TEST_ASSERT_EQUAL_INT(0, fib_sr_create(&test_fib_sr_table, &local_sourceroutes[0],
42, 0x0, 10000));
kernel_pid_t sr_iface_id;
uint32_t sr_flags;
uint32_t sr_lifetime;
TEST_ASSERT_EQUAL_INT(-EFAULT, fib_sr_read_head(&test_fib_sr_table, NULL,
&sr_iface_id, &sr_flags,
&sr_lifetime)
);
2015-08-05 14:40:49 +02:00
TEST_ASSERT_EQUAL_INT(-EFAULT, fib_sr_read_head(&test_fib_sr_table, local_sourceroutes[0],
NULL, &sr_flags,
&sr_lifetime)
);
2015-08-05 14:40:49 +02:00
/* we set the lifetime to 1 ms and expect it to expire */
sr_lifetime = 1;
TEST_ASSERT_EQUAL_INT(0, fib_sr_set(&test_fib_sr_table, local_sourceroutes[0],
&sr_iface_id, &sr_flags, &sr_lifetime)
);
2015-08-05 14:40:49 +02:00
/*
* Since the FIB uses timex under the hood which has a finer grained resolution
* testing the lifetime requires to active wait a bit, say 1 ms.
* Uncomment the following lines if you want to test the temporal behaviour
* @note this may fail since unittests are currently not thread-friendly
*/
2015-08-05 14:40:49 +02:00
/*
xtimer_usleep(1 * US_PER_MS);
TEST_ASSERT_EQUAL_INT(-ENOENT, fib_sr_read_head(&test_fib_sr_table, local_sourceroutes[0],
2015-08-05 14:40:49 +02:00
&sr_iface_id, &sr_flags,
&sr_lifetime)
);
*/
2015-08-05 14:40:49 +02:00
fib_deinit(&test_fib_sr_table);
}
/*
* @brief create a new empty source route and delete it
* It is expected to have no source route
*/
2015-08-05 14:40:49 +02:00
static void test_fib_sr_04_create_and_delete_sr(void)
{
fib_sr_t *local_sourceroutes[1];
TEST_ASSERT_EQUAL_INT(0, fib_sr_create(&test_fib_sr_table, &local_sourceroutes[0],
42, 0x0, 10000));
/* test wrong parameter */
TEST_ASSERT_EQUAL_INT(-EFAULT, fib_sr_delete(&test_fib_sr_table, NULL));
TEST_ASSERT_EQUAL_INT(0, fib_sr_delete(&test_fib_sr_table, local_sourceroutes[0]));
kernel_pid_t sr_iface_id;
uint32_t sr_flags;
uint32_t sr_lifetime;
TEST_ASSERT_EQUAL_INT(-ENOENT, fib_sr_read_head(&test_fib_sr_table, local_sourceroutes[0],
&sr_iface_id, &sr_flags,
&sr_lifetime)
);
2015-08-05 14:40:49 +02:00
fib_deinit(&test_fib_sr_table);
}
/*
* @brief create a new empty source route and append two hops on its path
*/
2015-08-05 14:40:49 +02:00
static void test_fib_sr_05_create_sr_and_append_hop(void)
{
fib_sr_t *local_sourceroutes[1];
size_t add_buf_size = 16;
char addr_nxt[add_buf_size];
2015-08-05 14:40:49 +02:00
snprintf(addr_nxt, add_buf_size, "Some address X1");
TEST_ASSERT_EQUAL_INT(0, fib_sr_create(&test_fib_sr_table, &local_sourceroutes[0],
42, 0x0, 10000));
/* append a first hop */
TEST_ASSERT_EQUAL_INT(0, fib_sr_entry_append(&test_fib_sr_table, local_sourceroutes[0],
(uint8_t *)&addr_nxt,
add_buf_size)
);
2015-08-05 14:40:49 +02:00
snprintf(addr_nxt, add_buf_size, "Some address X2");
/* append a hop behind the first hop */
TEST_ASSERT_EQUAL_INT(0, fib_sr_entry_append(&test_fib_sr_table, local_sourceroutes[0],
(uint8_t *)&addr_nxt,
add_buf_size)
);
2015-08-05 14:40:49 +02:00
/* the destination should be now X2 */
char addr_out[add_buf_size];
TEST_ASSERT_EQUAL_INT(0, fib_sr_read_destination(&test_fib_sr_table, local_sourceroutes[0],
(uint8_t *)&addr_out,
&add_buf_size)
);
2015-08-05 14:40:49 +02:00
TEST_ASSERT_EQUAL_INT(0, memcmp(addr_nxt, addr_out, add_buf_size));
/* try to append the address twice */
TEST_ASSERT_EQUAL_INT(-EINVAL, fib_sr_entry_append(&test_fib_sr_table, local_sourceroutes[0],
(uint8_t *)&addr_nxt,
add_buf_size)
);
2015-08-05 14:40:49 +02:00
/* remove the source route */
TEST_ASSERT_EQUAL_INT(0, fib_sr_delete(&test_fib_sr_table, local_sourceroutes[0]));
fib_deinit(&test_fib_sr_table);
}
/*
* @brief create a new source route with a number of hops on its path
* Search entry and add a new entry after the found one
*/
2015-08-05 14:40:49 +02:00
static void test_fib_sr_06_create_sr_with_hops(void)
{
fib_sr_t *local_sourceroutes[1];
size_t add_buf_size = 16;
char addr_nxt[add_buf_size];
TEST_ASSERT_EQUAL_INT(0, fib_sr_create(&test_fib_sr_table, &local_sourceroutes[0],
42, 0x0, 10000));
2015-12-19 21:56:50 +01:00
TEST_ASSERT_EQUAL_INT(0, _create_sr("Some address X", 0, 10, local_sourceroutes[0], 16));
2015-08-05 14:40:49 +02:00
/* now we search for a specific entry, e.g. X6 */
fib_sr_entry_t *sr_path_entry[1];
snprintf(addr_nxt, add_buf_size, "Some address X6");
TEST_ASSERT_EQUAL_INT(0, fib_sr_search(&test_fib_sr_table, local_sourceroutes[0],
(uint8_t *)&addr_nxt, add_buf_size,
&sr_path_entry[0])
);
2015-08-05 14:40:49 +02:00
/* and move on to the next entry (just because we can) */
TEST_ASSERT_EQUAL_INT(0, fib_sr_next(&test_fib_sr_table, local_sourceroutes[0],
&sr_path_entry[0]));
/* now we add a new entry behind sr_path_entry[0] and drop the remaining route */
snprintf(addr_nxt, add_buf_size, "Some address XY");
TEST_ASSERT_EQUAL_INT(0, fib_sr_entry_add(&test_fib_sr_table, local_sourceroutes[0],
sr_path_entry[0],
(uint8_t *)&addr_nxt,
add_buf_size, false)
);
2015-08-05 14:40:49 +02:00
/* so entries X8 and X9 should be gone */
snprintf(addr_nxt, add_buf_size, "Some address X8");
TEST_ASSERT_EQUAL_INT(-EHOSTUNREACH, fib_sr_search(&test_fib_sr_table, local_sourceroutes[0],
(uint8_t *)&addr_nxt, add_buf_size,
&sr_path_entry[0])
);
2015-08-05 14:40:49 +02:00
snprintf(addr_nxt, add_buf_size, "Some address X9");
TEST_ASSERT_EQUAL_INT(-EHOSTUNREACH, fib_sr_search(&test_fib_sr_table, local_sourceroutes[0],
(uint8_t *)&addr_nxt, add_buf_size,
&sr_path_entry[0])
);
2015-08-05 14:40:49 +02:00
/* now we go to a earlier entry and add a new entry not dropping the remaining ones */
snprintf(addr_nxt, add_buf_size, "Some address X2");
TEST_ASSERT_EQUAL_INT(0, fib_sr_search(&test_fib_sr_table, local_sourceroutes[0],
(uint8_t *)&addr_nxt, add_buf_size,
&sr_path_entry[0])
);
2015-08-05 14:40:49 +02:00
snprintf(addr_nxt, add_buf_size, "Some address XZ");
TEST_ASSERT_EQUAL_INT(0, fib_sr_entry_add(&test_fib_sr_table, local_sourceroutes[0],
sr_path_entry[0],
(uint8_t *)&addr_nxt,
add_buf_size, true)
);
2015-08-05 14:40:49 +02:00
/*
* @note uncomment the following line to print the source route.
* expected X0, .., X2, XZ, X3, .., X7, XY
*/
2015-08-05 14:40:49 +02:00
/* fib_print_sr( local_sourceroutes[0]); */
/* remove the source route */
TEST_ASSERT_EQUAL_INT(0, fib_sr_delete(&test_fib_sr_table, local_sourceroutes[0]));
fib_deinit(&test_fib_sr_table);
}
/*
* @brief create a new source route with a number of hops on its path,
* and delete several entries
*/
2015-08-05 14:40:49 +02:00
static void test_fib_sr_07_create_sr_with_hops_and_delete_one(void)
{
fib_sr_t *local_sourceroutes[1];
size_t add_buf_size = 16;
char addr_nxt[add_buf_size];
TEST_ASSERT_EQUAL_INT(0, fib_sr_create(&test_fib_sr_table, &local_sourceroutes[0],
42, 0x0, 10000));
2015-12-19 21:56:50 +01:00
TEST_ASSERT_EQUAL_INT(0, _create_sr("Some address X", 0, 10, local_sourceroutes[0], 16));
2015-08-05 14:40:49 +02:00
snprintf(addr_nxt, add_buf_size, "Some address X6");
/* we delete X6 keeping the remaining entries */
TEST_ASSERT_EQUAL_INT(0, fib_sr_entry_delete(&test_fib_sr_table, local_sourceroutes[0],
(uint8_t *)&addr_nxt, add_buf_size,
true)
);
2015-08-05 14:40:49 +02:00
snprintf(addr_nxt, add_buf_size, "Some address X9");
/* now the destination */
TEST_ASSERT_EQUAL_INT(0, fib_sr_entry_delete(&test_fib_sr_table, local_sourceroutes[0],
(uint8_t *)&addr_nxt, add_buf_size,
true)
);
2015-08-05 14:40:49 +02:00
snprintf(addr_nxt, add_buf_size, "Some address X0");
/* and now the first hop on the path */
TEST_ASSERT_EQUAL_INT(0, fib_sr_entry_delete(&test_fib_sr_table, local_sourceroutes[0],
(uint8_t *)&addr_nxt, add_buf_size,
true)
);
2015-08-05 14:40:49 +02:00
/*
* @note uncomment the following line to print the source route.
* expected X1, .., X5, X7, .., X8
*/
2015-08-05 14:40:49 +02:00
/* fib_print_sr( local_sourceroutes[0]); */
/* remove the source route */
TEST_ASSERT_EQUAL_INT(0, fib_sr_delete(&test_fib_sr_table, local_sourceroutes[0]));
fib_deinit(&test_fib_sr_table);
}
/*
* @brief create a new source route with a number of hops on its path,
* and overwrite the address of one entry
*/
2015-08-05 14:40:49 +02:00
static void test_fib_sr_08_create_sr_with_hops_and_overwrite_one(void)
{
fib_sr_t *local_sourceroutes[1];
size_t add_buf_size = 16;
char addr_nxt[add_buf_size];
char addr_exc[add_buf_size];
TEST_ASSERT_EQUAL_INT(0, fib_sr_create(&test_fib_sr_table, &local_sourceroutes[0],
42, 0x0, 10000));
2015-12-19 21:56:50 +01:00
TEST_ASSERT_EQUAL_INT(0, _create_sr("Some address X", 0, 10, local_sourceroutes[0], 16));
2015-08-05 14:40:49 +02:00
/* now we search for a specific entry, e.g. X6 */
snprintf(addr_nxt, add_buf_size, "Some address X6");
snprintf(addr_exc, add_buf_size, "Some address XY");
TEST_ASSERT_EQUAL_INT(0, fib_sr_entry_overwrite(&test_fib_sr_table, local_sourceroutes[0],
(uint8_t *)&addr_nxt, add_buf_size,
(uint8_t *)&addr_exc, add_buf_size)
);
2015-08-05 14:40:49 +02:00
/*
* @note uncomment the following line to print the source route.
* expected X0, .., X5, XY, X7, .., X9
*/
2015-08-05 14:40:49 +02:00
/* fib_print_sr( local_sourceroutes[0]); */
/* remove the source route */
TEST_ASSERT_EQUAL_INT(0, fib_sr_delete(&test_fib_sr_table, local_sourceroutes[0]));
fib_deinit(&test_fib_sr_table);
}
/*
* @brief create a new source route with a number of hops on its path,
* search an entry and copy the address to the caller
*/
2015-08-05 14:40:49 +02:00
static void test_fib_sr_09_create_sr_with_hops_and_get_one(void)
{
fib_sr_t *local_sourceroutes[1];
size_t add_buf_size = 16;
char addr_nxt[add_buf_size];
char addr_out[add_buf_size];
TEST_ASSERT_EQUAL_INT(0, fib_sr_create(&test_fib_sr_table, &local_sourceroutes[0],
42, 0x0, 10000));
2015-12-19 21:56:50 +01:00
TEST_ASSERT_EQUAL_INT(0, _create_sr("Some address X", 0, 10, local_sourceroutes[0], 16));
2015-08-05 14:40:49 +02:00
/* first we have an empty iterator */
fib_sr_entry_t *sr_path_entry[1];
sr_path_entry[0] = NULL;
/* now we move on to a specific hop, i.e. the 6th one (X5) */
for (size_t i = 0; i < 6; ++i) {
TEST_ASSERT_EQUAL_INT(0, fib_sr_next(&test_fib_sr_table, local_sourceroutes[0],
&sr_path_entry[0]));
}
TEST_ASSERT_EQUAL_INT(0, fib_sr_entry_get_address(&test_fib_sr_table, local_sourceroutes[0],
sr_path_entry[0],
(uint8_t *)&addr_out, &add_buf_size)
);
2015-08-05 14:40:49 +02:00
/* we ecpect the X5 address */
snprintf(addr_nxt, add_buf_size, "Some address X5");
TEST_ASSERT_EQUAL_INT(0, memcmp(addr_nxt, addr_out, add_buf_size));
/*
* @note uncomment the following line to print the source route.
*/
2015-08-05 14:40:49 +02:00
/* fib_print_sr( local_sourceroutes[0]); */
/* remove the source route */
TEST_ASSERT_EQUAL_INT(0, fib_sr_delete(&test_fib_sr_table, local_sourceroutes[0]));
fib_deinit(&test_fib_sr_table);
}
/*
* @brief create a new source route with a number of hops on its path,
* and get it (also in reverse order)
*/
2015-08-05 14:40:49 +02:00
static void test_fib_sr_10_create_sr_with_hops_and_get_a_route(void)
{
fib_sr_t *local_sourceroutes[1];
size_t add_buf_size = 16;
char addr_nxt[add_buf_size];
TEST_ASSERT_EQUAL_INT(0, fib_sr_create(&test_fib_sr_table, &local_sourceroutes[0],
42, 0x0, 10000));
2015-12-19 21:56:50 +01:00
TEST_ASSERT_EQUAL_INT(0, _create_sr("Some address X", 0, 10, local_sourceroutes[0], 16));
2015-08-05 14:40:49 +02:00
size_t addr_list_elements = 10;
size_t element_size = 16;
uint8_t addr_list[ addr_list_elements * element_size ];
kernel_pid_t sr_iface_id;
uint32_t sr_flags = 0x0;
snprintf(addr_nxt, add_buf_size, "Some address X9");
TEST_ASSERT_EQUAL_INT(0, fib_sr_get_route(&test_fib_sr_table, (uint8_t *)&addr_nxt,
add_buf_size, &sr_iface_id, &sr_flags,
addr_list, &addr_list_elements, &element_size,
false, NULL)
);
2015-08-05 14:40:49 +02:00
/*
* @note uncomment the following lines to print the source route and the result.
* expected X0, .., X9
*/
2015-08-05 14:40:49 +02:00
/*
fib_print_sr( local_sourceroutes[0]);
2015-08-05 14:40:49 +02:00
for (size_t i = 0; i < addr_list_elements; ++i) {
2015-08-05 14:40:49 +02:00
printf("[");
for (size_t j = 0; j < element_size; j++) {
printf("%c", addr_list[(i*element_size)+j]);
}printf("] ");
}puts("");
*/
2015-08-05 14:40:49 +02:00
/* now we get the addresses in reverse order */
TEST_ASSERT_EQUAL_INT(0, fib_sr_get_route(&test_fib_sr_table, (uint8_t *)&addr_nxt,
add_buf_size, &sr_iface_id, &sr_flags,
addr_list, &addr_list_elements, &element_size,
true, NULL)
);
2015-08-05 14:40:49 +02:00
/*
* @note uncomment the following lines to print the source route and the result.
* expected X0, .., X9
*/
2015-08-05 14:40:49 +02:00
/*
fib_print_sr( local_sourceroutes[0]);
2015-08-05 14:40:49 +02:00
for (size_t i = 0; i < addr_list_elements; ++i) {
2015-08-05 14:40:49 +02:00
printf("[");
for (size_t j = 0; j < element_size; j++) {
printf("%c", addr_list[(i*element_size)+j]);
}printf("] ");
}puts("");
*/
2015-08-05 14:40:49 +02:00
/* remove the source route */
TEST_ASSERT_EQUAL_INT(0, fib_sr_delete(&test_fib_sr_table, local_sourceroutes[0]));
fib_deinit(&test_fib_sr_table);
}
/*
* @brief create a new source route with a number of hops on its path,
* and get a partial route (also in reverse order)
*/
2015-08-05 14:40:49 +02:00
static void test_fib_sr_11_create_sr_with_hops_and_get_a_partial_route(void)
{
fib_sr_t *local_sourceroutes[1];
size_t add_buf_size = 16;
char addr_nxt[add_buf_size];
TEST_ASSERT_EQUAL_INT(0, fib_sr_create(&test_fib_sr_table, &local_sourceroutes[0],
42, 0x0, 10000));
2015-12-19 21:56:50 +01:00
TEST_ASSERT_EQUAL_INT(0, _create_sr("Some address X", 0, 10, local_sourceroutes[0], 16));
2015-08-05 14:40:49 +02:00
size_t addr_list_elements = 10;
size_t element_size = 16;
uint8_t addr_list[ addr_list_elements * element_size ];
kernel_pid_t sr_iface_id;
uint32_t sr_flags = 0x0;
snprintf(addr_nxt, add_buf_size, "Some address X7");
TEST_ASSERT_EQUAL_INT(0, fib_sr_get_route(&test_fib_sr_table, (uint8_t *)&addr_nxt,
add_buf_size, &sr_iface_id, &sr_flags,
addr_list, &addr_list_elements, &element_size,
false, NULL)
);
2015-08-05 14:40:49 +02:00
/*
* @note uncomment the following lines to print the resulting source route.
* expected X0..X9 where X0..X7 has usecount of 2
*/
2015-08-05 14:40:49 +02:00
/*
fib_print_sr( local_sourceroutes[0]);
2015-08-05 14:40:49 +02:00
for (size_t i = 0; i < addr_list_elements; ++i) {
2015-08-05 14:40:49 +02:00
printf("[");
for (size_t j = 0; j < element_size; j++) {
printf("%c", addr_list[(i*element_size)+j]);
}printf("] ");
}puts("");
*/
2015-08-05 14:40:49 +02:00
/* now we get the addresses in reverse order */
TEST_ASSERT_EQUAL_INT(0, fib_sr_get_route(&test_fib_sr_table, (uint8_t *)&addr_nxt,
add_buf_size, &sr_iface_id, &sr_flags,
addr_list, &addr_list_elements, &element_size,
true, NULL)
);
2015-08-05 14:40:49 +02:00
/*
* @note uncomment the following lines to print the resulting source route.
*/
2015-08-05 14:40:49 +02:00
/*
for (size_t i = 0; i < addr_list_elements; ++i) {
2015-08-05 14:40:49 +02:00
printf("[");
for (size_t j = 0; j < element_size; j++) {
printf("%c", addr_list[(i*element_size)+j]);
}printf("] ");
}puts("");
*/
2015-08-05 14:40:49 +02:00
/* remove the source route */
TEST_ASSERT_EQUAL_INT(0, fib_sr_delete(&test_fib_sr_table, local_sourceroutes[0]));
fib_deinit(&test_fib_sr_table);
}
/*
* @brief create new source routes and get all routes succesively
*/
2015-08-05 14:40:49 +02:00
static void test_fib_sr_12_get_consecutive_sr(void)
{
fib_sr_t *local_sourceroutes[3];
size_t add_buf_size = 16;
char addr_nxt[add_buf_size];
/* Create SR1 X0,.., X9,XX */
TEST_ASSERT_EQUAL_INT(0, fib_sr_create(&test_fib_sr_table, &local_sourceroutes[0],
42, 0x0, 10000));
2015-12-19 21:56:50 +01:00
TEST_ASSERT_EQUAL_INT(0, _create_sr("Some address X", 0, 10, local_sourceroutes[0], 16));
2015-08-05 14:40:49 +02:00
snprintf(addr_nxt, add_buf_size, "Some address XX");
/* append a the last hop, i.e. the destination */
TEST_ASSERT_EQUAL_INT(0, fib_sr_entry_append(&test_fib_sr_table, local_sourceroutes[0],
(uint8_t *)&addr_nxt,
add_buf_size)
);
2015-08-05 14:40:49 +02:00
/* Create SR1 Y1,.., Y7,XX */
TEST_ASSERT_EQUAL_INT(0, fib_sr_create(&test_fib_sr_table, &local_sourceroutes[1],
42, 0x0, 10000));
2015-12-19 21:56:50 +01:00
TEST_ASSERT_EQUAL_INT(0, _create_sr("Some address Y", 1, 8, local_sourceroutes[1], 16));
2015-08-05 14:40:49 +02:00
snprintf(addr_nxt, add_buf_size, "Some address XX");
/* append a the last hop, i.e. the destination */
TEST_ASSERT_EQUAL_INT(0, fib_sr_entry_append(&test_fib_sr_table, local_sourceroutes[1],
(uint8_t *)&addr_nxt,
add_buf_size)
);
2015-08-05 14:40:49 +02:00
/* Create SR1 Z5,.., Z7,XX */
TEST_ASSERT_EQUAL_INT(0, fib_sr_create(&test_fib_sr_table, &local_sourceroutes[2],
42, 0x0, 10000));
2015-08-05 14:40:49 +02:00
2015-12-19 21:56:50 +01:00
TEST_ASSERT_EQUAL_INT(0, _create_sr("Some address Z", 5, 8, local_sourceroutes[2], 16));
2015-08-05 14:40:49 +02:00
snprintf(addr_nxt, add_buf_size, "Some address XX");
/* append a the last hop, i.e. the destination */
TEST_ASSERT_EQUAL_INT(0, fib_sr_entry_append(&test_fib_sr_table, local_sourceroutes[2],
(uint8_t *)&addr_nxt,
add_buf_size)
2015-08-05 14:40:49 +02:00
);
fib_sr_t *iter[1];
iter[0] = NULL;
size_t addr_list_elements = 11;
size_t element_size = 16;
uint8_t addr_list[ addr_list_elements * element_size ];
kernel_pid_t sr_iface_id;
uint32_t sr_flags = 0x0;
snprintf(addr_nxt, add_buf_size, "Some address XX");
TEST_ASSERT_EQUAL_INT(0, fib_sr_get_route(&test_fib_sr_table, (uint8_t *)&addr_nxt,
add_buf_size, &sr_iface_id, &sr_flags,
addr_list, &addr_list_elements, &element_size,
false, iter)
);
2015-08-05 14:40:49 +02:00
TEST_ASSERT_EQUAL_INT(11, addr_list_elements);
TEST_ASSERT_EQUAL_INT(0, fib_sr_get_route(&test_fib_sr_table, (uint8_t *)&addr_nxt,
add_buf_size, &sr_iface_id, &sr_flags,
addr_list, &addr_list_elements, &element_size,
false, iter)
);
2015-08-05 14:40:49 +02:00
TEST_ASSERT_EQUAL_INT(8, addr_list_elements);
TEST_ASSERT_EQUAL_INT(0, fib_sr_get_route(&test_fib_sr_table, (uint8_t *)&addr_nxt,
add_buf_size, &sr_iface_id, &sr_flags,
addr_list, &addr_list_elements, &element_size,
false, iter)
);
2015-08-05 14:40:49 +02:00
TEST_ASSERT_EQUAL_INT(4, addr_list_elements);
fib_deinit(&test_fib_sr_table);
}
Test *tests_fib_sr_tests(void)
{
test_fib_sr_table.data.source_routes = &_entries_sr;
test_fib_sr_table.table_type = FIB_TABLE_TYPE_SR;
test_fib_sr_table.size = TEST_MAX_FIB_SR;
mutex_init(&(test_fib_sr_table.mtx_access));
test_fib_sr_table.notify_rp_pos = 0;
fib_init(&test_fib_sr_table);
EMB_UNIT_TESTFIXTURES(fixtures) {
new_TestFixture(test_fib_sr_01_create_empty_sr),
new_TestFixture(test_fib_sr_02_change_sr_parameters),
new_TestFixture(test_fib_sr_03_read_sr_parameters),
new_TestFixture(test_fib_sr_04_create_and_delete_sr),
new_TestFixture(test_fib_sr_05_create_sr_and_append_hop),
new_TestFixture(test_fib_sr_06_create_sr_with_hops),
new_TestFixture(test_fib_sr_07_create_sr_with_hops_and_delete_one),
new_TestFixture(test_fib_sr_08_create_sr_with_hops_and_overwrite_one),
new_TestFixture(test_fib_sr_09_create_sr_with_hops_and_get_one),
new_TestFixture(test_fib_sr_10_create_sr_with_hops_and_get_a_route),
new_TestFixture(test_fib_sr_11_create_sr_with_hops_and_get_a_partial_route),
new_TestFixture(test_fib_sr_12_get_consecutive_sr),
2015-08-05 14:40:49 +02:00
};
EMB_UNIT_TESTCALLER(fib_sr_tests, NULL, NULL, fixtures);
return (Test *)&fib_sr_tests;
}
void tests_fib_sr(void)
{
TESTS_RUN(tests_fib_sr_tests());
}