mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
1036 lines
41 KiB
C
1036 lines
41 KiB
C
|
/*
|
||
|
* Copyright (C) 2017 Freie Universität Berlin
|
||
|
*
|
||
|
* 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.
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @ingroup tests
|
||
|
* @{
|
||
|
*
|
||
|
* @file
|
||
|
* @brief Tests default configuration of GNRC's Network Information Base
|
||
|
*
|
||
|
* @author Martine Lenders <m.lenders@fu-berlin.de>
|
||
|
*
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
#include <errno.h>
|
||
|
#include <stdio.h>
|
||
|
|
||
|
#include "common.h"
|
||
|
#include "embUnit.h"
|
||
|
#include "embUnit/embUnit.h"
|
||
|
#include "net/ethernet.h"
|
||
|
#include "net/ipv6.h"
|
||
|
#include "net/gnrc.h"
|
||
|
#include "net/gnrc/ipv6/hdr.h"
|
||
|
#include "net/gnrc/netif/hdr.h"
|
||
|
#include "net/gnrc/netif2.h"
|
||
|
#include "net/gnrc/netif2/ethernet.h"
|
||
|
#include "net/gnrc/netif2/internal.h"
|
||
|
#include "net/netdev_test.h"
|
||
|
#include "utlist.h"
|
||
|
#include "xtimer.h"
|
||
|
|
||
|
#define ETHERNET_STACKSIZE (THREAD_STACKSIZE_MAIN)
|
||
|
|
||
|
static gnrc_netif2_t *ethernet_netif = NULL;
|
||
|
static gnrc_netif2_t *netifs[DEFAULT_DEVS_NUMOF];
|
||
|
static char ethernet_netif_stack[ETHERNET_STACKSIZE];
|
||
|
static char netifs_stack[DEFAULT_DEVS_NUMOF][THREAD_STACKSIZE_DEFAULT];
|
||
|
static bool init_called = false;
|
||
|
|
||
|
static inline void _test_init(gnrc_netif2_t *netif);
|
||
|
static inline int _mock_netif_send(gnrc_netif2_t *netif, gnrc_pktsnip_t *pkt);
|
||
|
static inline gnrc_pktsnip_t *_mock_netif_recv(gnrc_netif2_t * netif);
|
||
|
static int _get_netdev_address(netdev_t *dev, void *value, size_t max_len);
|
||
|
static int _set_netdev_address(netdev_t *dev, const void *value, size_t value_len);
|
||
|
|
||
|
static const gnrc_netif2_ops_t default_ops = {
|
||
|
.init = _test_init,
|
||
|
.send = _mock_netif_send,
|
||
|
.recv = _mock_netif_recv,
|
||
|
.get = gnrc_netif2_get_from_netdev,
|
||
|
.set = gnrc_netif2_set_from_netdev,
|
||
|
.msg_handler = NULL,
|
||
|
};
|
||
|
|
||
|
static void _set_up(void)
|
||
|
{
|
||
|
msg_t msg;
|
||
|
|
||
|
if (ethernet_netif != NULL) {
|
||
|
memset(ethernet_netif->ipv6.addrs_flags, 0,
|
||
|
sizeof(ethernet_netif->ipv6.addrs_flags));
|
||
|
memset(ethernet_netif->ipv6.addrs, 0,
|
||
|
sizeof(ethernet_netif->ipv6.addrs));
|
||
|
memset(ethernet_netif->ipv6.groups, 0,
|
||
|
sizeof(ethernet_netif->ipv6.groups));
|
||
|
}
|
||
|
for (unsigned i = 0; i < DEFAULT_DEVS_NUMOF; i++) {
|
||
|
if (netifs[i] != NULL) {
|
||
|
memset(netifs[i]->ipv6.addrs_flags, 0,
|
||
|
sizeof(netifs[i]->ipv6.addrs_flags));
|
||
|
memset(netifs[i]->ipv6.addrs, 0, sizeof(netifs[i]->ipv6.addrs));
|
||
|
memset(netifs[i]->ipv6.groups, 0, sizeof(netifs[i]->ipv6.groups));
|
||
|
}
|
||
|
}
|
||
|
/* empty message queue */
|
||
|
while (msg_try_receive(&msg) > 0) {}
|
||
|
}
|
||
|
|
||
|
static inline void _test_init(gnrc_netif2_t *netif)
|
||
|
{
|
||
|
(void)netif;
|
||
|
init_called = true;
|
||
|
}
|
||
|
|
||
|
static void test_creation(void)
|
||
|
{
|
||
|
gnrc_netif2_t *ptr = NULL;
|
||
|
|
||
|
TEST_ASSERT_EQUAL_INT(0, gnrc_netif2_numof());
|
||
|
TEST_ASSERT_NULL(gnrc_netif2_iter(ptr));
|
||
|
TEST_ASSERT_NOT_NULL((ethernet_netif = gnrc_netif2_ethernet_create(
|
||
|
ethernet_netif_stack, ETHERNET_STACKSIZE, GNRC_NETIF2_PRIO,
|
||
|
"eth", ethernet_dev
|
||
|
)));
|
||
|
TEST_ASSERT_EQUAL_INT(1, gnrc_netif2_numof());
|
||
|
TEST_ASSERT_NOT_NULL((ptr = gnrc_netif2_iter(ptr)));
|
||
|
TEST_ASSERT_NULL((ptr = gnrc_netif2_iter(ptr)));
|
||
|
TEST_ASSERT_NOT_NULL(ethernet_netif->ops);
|
||
|
TEST_ASSERT_NOT_NULL(ethernet_netif->dev);
|
||
|
TEST_ASSERT_EQUAL_INT(ETHERNET_DATA_LEN, ethernet_netif->ipv6.mtu);
|
||
|
TEST_ASSERT_EQUAL_INT(GNRC_NETIF2_DEFAULT_HL, ethernet_netif->cur_hl);
|
||
|
TEST_ASSERT_EQUAL_INT(NETDEV_TYPE_ETHERNET, ethernet_netif->device_type);
|
||
|
TEST_ASSERT(ethernet_netif->pid > KERNEL_PID_UNDEF);
|
||
|
#ifdef DEVELHELP
|
||
|
TEST_ASSERT_EQUAL_STRING("eth", sched_threads[ethernet_netif->pid]->name);
|
||
|
#endif
|
||
|
TEST_ASSERT_NOT_NULL(sched_threads[ethernet_netif->pid]->msg_array);
|
||
|
for (unsigned i = 0; i < DEFAULT_DEVS_NUMOF; i++) {
|
||
|
TEST_ASSERT_NOT_NULL((netifs[i] = gnrc_netif2_create(
|
||
|
netifs_stack[i], THREAD_STACKSIZE_DEFAULT,
|
||
|
GNRC_NETIF2_PRIO, "netif", devs[i], &default_ops
|
||
|
)));
|
||
|
TEST_ASSERT_NOT_NULL(netifs[i]->ops);
|
||
|
TEST_ASSERT_NOT_NULL(netifs[i]->dev);
|
||
|
TEST_ASSERT_EQUAL_INT(GNRC_NETIF2_DEFAULT_HL, netifs[i]->cur_hl);
|
||
|
TEST_ASSERT_EQUAL_INT(NETDEV_TYPE_UNKNOWN, netifs[i]->device_type);
|
||
|
TEST_ASSERT(netifs[i]->pid > KERNEL_PID_UNDEF);
|
||
|
TEST_ASSERT_NOT_NULL(sched_threads[netifs[i]->pid]->msg_array);
|
||
|
TEST_ASSERT_EQUAL_INT(i + SPECIAL_DEVS + 1, gnrc_netif2_numof());
|
||
|
for (unsigned j = 0; j < (i + SPECIAL_DEVS + 1); j++) {
|
||
|
TEST_ASSERT_NOT_NULL((ptr = gnrc_netif2_iter(ptr)));
|
||
|
}
|
||
|
TEST_ASSERT_NULL((ptr = gnrc_netif2_iter(ptr)));
|
||
|
}
|
||
|
TEST_ASSERT(init_called);
|
||
|
}
|
||
|
|
||
|
static void test_get_by_pid(void)
|
||
|
{
|
||
|
TEST_ASSERT(ethernet_netif == gnrc_netif2_get_by_pid(ethernet_netif->pid));
|
||
|
for (kernel_pid_t i = 0; i < DEFAULT_DEVS_NUMOF; i++) {
|
||
|
TEST_ASSERT(netifs[i] == gnrc_netif2_get_by_pid(netifs[i]->pid));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
static void test_addr_to_str(void)
|
||
|
{
|
||
|
static const uint8_t ethernet_l2addr[] = ETHERNET_SRC;
|
||
|
static const uint8_t netif0_l2addr[] = NETIF0_SRC;
|
||
|
char out[sizeof(netif0_l2addr) * 3];
|
||
|
|
||
|
TEST_ASSERT(out == gnrc_netif2_addr_to_str(NULL, 0, out));
|
||
|
TEST_ASSERT_EQUAL_STRING("", &out[0]);
|
||
|
TEST_ASSERT(out == gnrc_netif2_addr_to_str(ethernet_l2addr,
|
||
|
sizeof(ethernet_l2addr), out));
|
||
|
TEST_ASSERT_EQUAL_STRING("3e:e6:b5:22:fd:0a", &out[0]);
|
||
|
TEST_ASSERT(out == gnrc_netif2_addr_to_str(netif0_l2addr,
|
||
|
sizeof(netif0_l2addr),
|
||
|
out));
|
||
|
TEST_ASSERT_EQUAL_STRING("3e:e7:b5:0f:19:22:fd:0a", &out[0]);
|
||
|
}
|
||
|
|
||
|
static void test_addr_from_str(void)
|
||
|
{
|
||
|
static const uint8_t ethernet_l2addr[] = ETHERNET_SRC;
|
||
|
uint8_t out[GNRC_NETIF2_L2ADDR_MAXLEN];
|
||
|
|
||
|
TEST_ASSERT_EQUAL_INT(0, gnrc_netif2_addr_from_str("", out));
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(ethernet_l2addr),
|
||
|
gnrc_netif2_addr_from_str("3e:e6:b5:22:fd:0a", out));
|
||
|
TEST_ASSERT_EQUAL_INT(0, memcmp(ethernet_l2addr, out,
|
||
|
sizeof(ethernet_l2addr)));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_addr_add__ENOMEM(void)
|
||
|
{
|
||
|
ipv6_addr_t addr = { .u8 = NETIF0_IPV6_G };
|
||
|
|
||
|
for (unsigned i = 0; i < GNRC_NETIF2_IPV6_ADDRS_NUMOF;
|
||
|
i++, addr.u16[3].u16++) {
|
||
|
TEST_ASSERT(0 <= gnrc_netif2_ipv6_addr_add(netifs[0], &addr, 64U,
|
||
|
GNRC_NETIF2_IPV6_ADDRS_FLAGS_STATE_VALID));
|
||
|
}
|
||
|
TEST_ASSERT_EQUAL_INT(-ENOMEM,
|
||
|
gnrc_netif2_ipv6_addr_add(netifs[0], &addr, 64U,
|
||
|
GNRC_NETIF2_IPV6_ADDRS_FLAGS_STATE_VALID));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_addr_add__success(void)
|
||
|
{
|
||
|
static const ipv6_addr_t addr = { .u8 = NETIF0_IPV6_LL };
|
||
|
int idx;
|
||
|
|
||
|
TEST_ASSERT(0 <= (idx = gnrc_netif2_ipv6_addr_add(netifs[0], &addr, 64U,
|
||
|
GNRC_NETIF2_IPV6_ADDRS_FLAGS_STATE_VALID)));
|
||
|
/* check duplicate addition */
|
||
|
TEST_ASSERT_EQUAL_INT(idx,
|
||
|
gnrc_netif2_ipv6_addr_add(netifs[0], &addr, 64U,
|
||
|
GNRC_NETIF2_IPV6_ADDRS_FLAGS_STATE_VALID));
|
||
|
TEST_ASSERT_EQUAL_INT(GNRC_NETIF2_IPV6_ADDRS_FLAGS_STATE_VALID,
|
||
|
netifs[0]->ipv6.addrs_flags[idx]);
|
||
|
TEST_ASSERT(ipv6_addr_equal(&addr, &netifs[0]->ipv6.addrs[idx]));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_addr_add__readd_with_free_entry(void)
|
||
|
{
|
||
|
/* Tests for possible duplicates (see #2965) */
|
||
|
static const ipv6_addr_t addr1 = { .u8 = NETIF0_IPV6_LL };
|
||
|
static const ipv6_addr_t addr2 = { .u8 = NETIF0_IPV6_G };
|
||
|
int idx;
|
||
|
|
||
|
TEST_ASSERT(0 <= gnrc_netif2_ipv6_addr_add(netifs[0], &addr1, 64U,
|
||
|
GNRC_NETIF2_IPV6_ADDRS_FLAGS_STATE_VALID));
|
||
|
TEST_ASSERT(0 <= (idx = gnrc_netif2_ipv6_addr_add(netifs[0], &addr2, 64U,
|
||
|
GNRC_NETIF2_IPV6_ADDRS_FLAGS_STATE_VALID)));
|
||
|
gnrc_netif2_ipv6_addr_remove(netifs[0], &addr1);
|
||
|
TEST_ASSERT_EQUAL_INT(idx,
|
||
|
gnrc_netif2_ipv6_addr_add(netifs[0], &addr2, 64U,
|
||
|
GNRC_NETIF2_IPV6_ADDRS_FLAGS_STATE_VALID));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_addr_remove__not_allocated(void)
|
||
|
{
|
||
|
static const ipv6_addr_t addr1 = { .u8 = NETIF0_IPV6_LL };
|
||
|
static const ipv6_addr_t addr2 = { .u8 = NETIF0_IPV6_G };
|
||
|
|
||
|
test_ipv6_addr_add__success();
|
||
|
TEST_ASSERT(0 <= gnrc_netif2_ipv6_addr_idx(netifs[0], &addr1));
|
||
|
TEST_ASSERT(0 <= gnrc_netif2_ipv6_addr_add(netifs[0], &addr2, 64U,
|
||
|
GNRC_NETIF2_IPV6_ADDRS_FLAGS_STATE_VALID));
|
||
|
gnrc_netif2_ipv6_addr_remove(netifs[0], &addr2);
|
||
|
TEST_ASSERT(0 <= gnrc_netif2_ipv6_addr_idx(netifs[0], &addr1));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_addr_remove__success(void)
|
||
|
{
|
||
|
static const ipv6_addr_t addr = { .u8 = NETIF0_IPV6_LL };
|
||
|
|
||
|
test_ipv6_addr_add__success();
|
||
|
gnrc_netif2_ipv6_addr_remove(netifs[0], &addr);
|
||
|
TEST_ASSERT_EQUAL_INT(-1, gnrc_netif2_ipv6_addr_idx(netifs[0], &addr));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_addr_idx__empty(void)
|
||
|
{
|
||
|
static const ipv6_addr_t addr = { .u8 = NETIF0_IPV6_LL };
|
||
|
|
||
|
TEST_ASSERT_EQUAL_INT(-1, gnrc_netif2_ipv6_addr_idx(netifs[0], &addr));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_addr_idx__wrong_netif(void)
|
||
|
{
|
||
|
static const ipv6_addr_t addr = { .u8 = NETIF0_IPV6_LL };
|
||
|
|
||
|
test_ipv6_addr_add__success();
|
||
|
TEST_ASSERT_EQUAL_INT(-1, gnrc_netif2_ipv6_addr_idx(netifs[1], &addr));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_addr_idx__wrong_addr(void)
|
||
|
{
|
||
|
static const ipv6_addr_t addr2 = { .u8 = NETIF0_IPV6_G };
|
||
|
|
||
|
test_ipv6_addr_add__success();
|
||
|
TEST_ASSERT_EQUAL_INT(-1, gnrc_netif2_ipv6_addr_idx(netifs[0], &addr2));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_addr_idx__success(void)
|
||
|
{
|
||
|
static const ipv6_addr_t addr = { .u8 = NETIF0_IPV6_LL };
|
||
|
|
||
|
test_ipv6_addr_add__success();
|
||
|
TEST_ASSERT(0 <= gnrc_netif2_ipv6_addr_idx(netifs[0], &addr));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_addr_match__empty(void)
|
||
|
{
|
||
|
static const ipv6_addr_t addr = { .u8 = NETIF0_IPV6_G };
|
||
|
|
||
|
TEST_ASSERT_EQUAL_INT(-1, gnrc_netif2_ipv6_addr_match(netifs[0], &addr));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_addr_match__wrong_netif(void)
|
||
|
{
|
||
|
static const ipv6_addr_t addr = { .u8 = NETIF0_IPV6_G };
|
||
|
|
||
|
test_ipv6_addr_add__success();
|
||
|
TEST_ASSERT_EQUAL_INT(-1, gnrc_netif2_ipv6_addr_match(netifs[1], &addr));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_addr_match__wrong_addr(void)
|
||
|
{
|
||
|
static const ipv6_addr_t addr2 = { .u8 = NETIF0_IPV6_G };
|
||
|
|
||
|
test_ipv6_addr_add__success();
|
||
|
TEST_ASSERT_EQUAL_INT(-1, gnrc_netif2_ipv6_addr_match(netifs[0], &addr2));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_addr_match__success18(void)
|
||
|
{
|
||
|
static const ipv6_addr_t addr = { .u8 = NETIF0_IPV6_G };
|
||
|
|
||
|
static const ipv6_addr_t pfx = { .u8 = GLOBAL_PFX18 };
|
||
|
int idx;
|
||
|
|
||
|
TEST_ASSERT(0 <= (idx = gnrc_netif2_ipv6_addr_add(netifs[0], &addr, 64U,
|
||
|
GNRC_NETIF2_IPV6_ADDRS_FLAGS_STATE_VALID)));
|
||
|
TEST_ASSERT_EQUAL_INT(idx, gnrc_netif2_ipv6_addr_match(netifs[0], &pfx));
|
||
|
TEST_ASSERT_EQUAL_INT(18, ipv6_addr_match_prefix(&netifs[0]->ipv6.addrs[idx],
|
||
|
&pfx));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_addr_match__success23(void)
|
||
|
{
|
||
|
static const ipv6_addr_t addr = { .u8 = NETIF0_IPV6_G };
|
||
|
|
||
|
static const ipv6_addr_t pfx = { .u8 = GLOBAL_PFX23 };
|
||
|
int idx;
|
||
|
|
||
|
TEST_ASSERT(0 <= (idx = gnrc_netif2_ipv6_addr_add(netifs[0], &addr, 64U,
|
||
|
GNRC_NETIF2_IPV6_ADDRS_FLAGS_STATE_VALID)));
|
||
|
TEST_ASSERT_EQUAL_INT(idx, gnrc_netif2_ipv6_addr_match(netifs[0], &pfx));
|
||
|
TEST_ASSERT_EQUAL_INT(23, ipv6_addr_match_prefix(&netifs[0]->ipv6.addrs[idx],
|
||
|
&pfx));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_addr_match__success64(void)
|
||
|
{
|
||
|
static const ipv6_addr_t addr = { .u8 = NETIF0_IPV6_G };
|
||
|
|
||
|
static const ipv6_addr_t pfx = { .u8 = GLOBAL_PFX64 };
|
||
|
int idx;
|
||
|
|
||
|
TEST_ASSERT(0 <= (idx = gnrc_netif2_ipv6_addr_add(netifs[0], &addr, 64U,
|
||
|
GNRC_NETIF2_IPV6_ADDRS_FLAGS_STATE_VALID)));
|
||
|
TEST_ASSERT_EQUAL_INT(idx, gnrc_netif2_ipv6_addr_match(netifs[0], &pfx));
|
||
|
TEST_ASSERT_EQUAL_INT(64, ipv6_addr_match_prefix(&netifs[0]->ipv6.addrs[idx],
|
||
|
&pfx));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_addr_best_src__multicast_input(void)
|
||
|
{
|
||
|
static const ipv6_addr_t addr1 = { .u8 = NETIF0_IPV6_G };
|
||
|
|
||
|
static const ipv6_addr_t addr2 = { .u8 = GLOBAL_PFX18 };
|
||
|
ipv6_addr_t *out;
|
||
|
|
||
|
/* adds a link-local address */
|
||
|
test_ipv6_addr_add__success();
|
||
|
TEST_ASSERT(0 <= gnrc_netif2_ipv6_addr_add(netifs[0], &addr1, 64U,
|
||
|
GNRC_NETIF2_IPV6_ADDRS_FLAGS_STATE_VALID));
|
||
|
TEST_ASSERT_NOT_NULL((out = gnrc_netif2_ipv6_addr_best_src(netifs[0],
|
||
|
&addr2,
|
||
|
false)));
|
||
|
TEST_ASSERT(!ipv6_addr_equal(&addr2, out));
|
||
|
TEST_ASSERT(ipv6_addr_equal(&addr1, out));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_addr_best_src__other_subnet(void)
|
||
|
{
|
||
|
static const ipv6_addr_t mc_addr = IPV6_ADDR_ALL_ROUTERS_SITE_LOCAL;
|
||
|
ipv6_addr_t *out = NULL;
|
||
|
|
||
|
test_ipv6_addr_add__success();
|
||
|
TEST_ASSERT_NOT_NULL((out = gnrc_netif2_ipv6_addr_best_src(netifs[0],
|
||
|
&mc_addr,
|
||
|
false)));
|
||
|
TEST_ASSERT(!ipv6_addr_equal(&mc_addr, out));
|
||
|
TEST_ASSERT(!ipv6_addr_is_multicast(out));
|
||
|
TEST_ASSERT(!ipv6_addr_is_unspecified(out));
|
||
|
}
|
||
|
|
||
|
static void test_get_by_ipv6_addr__empty(void)
|
||
|
{
|
||
|
static const ipv6_addr_t addr = { .u8 = NETIF0_IPV6_LL };
|
||
|
|
||
|
TEST_ASSERT_NULL(gnrc_netif2_get_by_ipv6_addr(&addr));
|
||
|
}
|
||
|
|
||
|
static void test_get_by_ipv6_addr__success(void)
|
||
|
{
|
||
|
static const ipv6_addr_t addr = { .u8 = NETIF0_IPV6_LL };
|
||
|
|
||
|
test_ipv6_addr_add__success();
|
||
|
TEST_ASSERT_NOT_NULL(netifs[0]);
|
||
|
TEST_ASSERT(netifs[0] == gnrc_netif2_get_by_ipv6_addr(&addr));
|
||
|
}
|
||
|
|
||
|
static void test_get_by_prefix__empty(void)
|
||
|
{
|
||
|
static const ipv6_addr_t addr = { .u8 = NETIF0_IPV6_G };
|
||
|
|
||
|
TEST_ASSERT_NULL(gnrc_netif2_get_by_prefix(&addr));
|
||
|
}
|
||
|
|
||
|
static void test_get_by_prefix__success18(void)
|
||
|
{
|
||
|
static const ipv6_addr_t addr = { .u8 = NETIF0_IPV6_G };
|
||
|
static const ipv6_addr_t pfx = { .u8 = GLOBAL_PFX18 };
|
||
|
|
||
|
TEST_ASSERT(0 <= gnrc_netif2_ipv6_addr_add(netifs[0], &addr, 64U,
|
||
|
GNRC_NETIF2_IPV6_ADDRS_FLAGS_STATE_VALID));
|
||
|
TEST_ASSERT_NOT_NULL(netifs[0]);
|
||
|
TEST_ASSERT(netifs[0] == gnrc_netif2_get_by_prefix(&pfx));
|
||
|
test_ipv6_addr_match__success18();
|
||
|
}
|
||
|
|
||
|
static void test_get_by_prefix__success23(void)
|
||
|
{
|
||
|
static const ipv6_addr_t addr = { .u8 = NETIF0_IPV6_G };
|
||
|
static const ipv6_addr_t pfx = { .u8 = GLOBAL_PFX23 };
|
||
|
|
||
|
TEST_ASSERT(0 <= gnrc_netif2_ipv6_addr_add(netifs[0], &addr, 64U,
|
||
|
GNRC_NETIF2_IPV6_ADDRS_FLAGS_STATE_VALID));
|
||
|
TEST_ASSERT_NOT_NULL(netifs[0]);
|
||
|
TEST_ASSERT(netifs[0] == gnrc_netif2_get_by_prefix(&pfx));
|
||
|
test_ipv6_addr_match__success23();
|
||
|
}
|
||
|
|
||
|
static void test_get_by_prefix__success64(void)
|
||
|
{
|
||
|
static const ipv6_addr_t addr = { .u8 = NETIF0_IPV6_G };
|
||
|
static const ipv6_addr_t pfx = { .u8 = GLOBAL_PFX64 };
|
||
|
|
||
|
TEST_ASSERT(0 <= gnrc_netif2_ipv6_addr_add(netifs[0], &addr, 64U,
|
||
|
GNRC_NETIF2_IPV6_ADDRS_FLAGS_STATE_VALID));
|
||
|
TEST_ASSERT_NOT_NULL(netifs[0]);
|
||
|
TEST_ASSERT(netifs[0] == gnrc_netif2_get_by_prefix(&pfx));
|
||
|
test_ipv6_addr_match__success64();
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_group_join__ENOMEM(void)
|
||
|
{
|
||
|
ipv6_addr_t addr = IPV6_ADDR_ALL_NODES_LINK_LOCAL;
|
||
|
|
||
|
for (unsigned i = 0; i < GNRC_NETIF2_IPV6_ADDRS_NUMOF;
|
||
|
i++, addr.u16[7].u16++) {
|
||
|
TEST_ASSERT(0 <= gnrc_netif2_ipv6_group_join(netifs[0], &addr));
|
||
|
}
|
||
|
TEST_ASSERT_EQUAL_INT(-ENOMEM,
|
||
|
gnrc_netif2_ipv6_group_join(netifs[0], &addr));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_group_join__success(void)
|
||
|
{
|
||
|
int idx;
|
||
|
|
||
|
TEST_ASSERT(0 <= (idx = gnrc_netif2_ipv6_group_join(netifs[0],
|
||
|
&ipv6_addr_all_nodes_link_local)));
|
||
|
/* check duplicate addition */
|
||
|
TEST_ASSERT_EQUAL_INT(idx,
|
||
|
gnrc_netif2_ipv6_group_join(netifs[0],
|
||
|
&ipv6_addr_all_nodes_link_local));
|
||
|
TEST_ASSERT(ipv6_addr_equal(&ipv6_addr_all_nodes_link_local,
|
||
|
&netifs[0]->ipv6.groups[idx]));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_group_join__readd_with_free_entry(void)
|
||
|
{
|
||
|
/* Tests for possible duplicates (see #2965) */
|
||
|
int idx;
|
||
|
|
||
|
TEST_ASSERT(0 <= gnrc_netif2_ipv6_group_join(netifs[0],
|
||
|
&ipv6_addr_all_nodes_link_local));
|
||
|
TEST_ASSERT(0 <= (idx = gnrc_netif2_ipv6_group_join(netifs[0],
|
||
|
&ipv6_addr_all_routers_link_local)));
|
||
|
gnrc_netif2_ipv6_group_leave(netifs[0], &ipv6_addr_all_nodes_link_local);
|
||
|
TEST_ASSERT_EQUAL_INT(idx,
|
||
|
gnrc_netif2_ipv6_group_join(netifs[0],
|
||
|
&ipv6_addr_all_routers_link_local));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_group_leave__not_allocated(void)
|
||
|
{
|
||
|
test_ipv6_group_join__success();
|
||
|
TEST_ASSERT(0 <= gnrc_netif2_ipv6_group_idx(netifs[0],
|
||
|
&ipv6_addr_all_nodes_link_local));
|
||
|
TEST_ASSERT(0 <= gnrc_netif2_ipv6_group_join(netifs[0],
|
||
|
&ipv6_addr_all_routers_link_local));
|
||
|
gnrc_netif2_ipv6_group_leave(netifs[0], &ipv6_addr_all_routers_link_local);
|
||
|
TEST_ASSERT(0 <= gnrc_netif2_ipv6_group_idx(netifs[0],
|
||
|
&ipv6_addr_all_nodes_link_local));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_group_leave__success(void)
|
||
|
{
|
||
|
test_ipv6_group_join__success();
|
||
|
gnrc_netif2_ipv6_group_leave(netifs[0], &ipv6_addr_all_nodes_link_local);
|
||
|
TEST_ASSERT_EQUAL_INT(-1, gnrc_netif2_ipv6_group_idx(netifs[0],
|
||
|
&ipv6_addr_all_nodes_link_local));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_group_idx__empty(void)
|
||
|
{
|
||
|
TEST_ASSERT_EQUAL_INT(-1, gnrc_netif2_ipv6_group_idx(netifs[0],
|
||
|
&ipv6_addr_all_nodes_link_local));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_group_idx__wrong_netif(void)
|
||
|
{
|
||
|
test_ipv6_group_join__success();
|
||
|
TEST_ASSERT_EQUAL_INT(-1, gnrc_netif2_ipv6_group_idx(netifs[1],
|
||
|
&ipv6_addr_all_nodes_link_local));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_group_idx__wrong_addr(void)
|
||
|
{
|
||
|
test_ipv6_group_join__success();
|
||
|
TEST_ASSERT_EQUAL_INT(-1, gnrc_netif2_ipv6_group_idx(netifs[0],
|
||
|
&ipv6_addr_all_routers_link_local));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_group_idx__success(void)
|
||
|
{
|
||
|
test_ipv6_group_join__success();
|
||
|
TEST_ASSERT(0 <= gnrc_netif2_ipv6_group_idx(netifs[0], &ipv6_addr_all_nodes_link_local));
|
||
|
}
|
||
|
|
||
|
static void test_ipv6_get_iid(void)
|
||
|
{
|
||
|
static const ipv6_addr_t ethernet_ipv6_ll = { .u8 = ETHERNET_IPV6_LL };
|
||
|
eui64_t res;
|
||
|
|
||
|
TEST_ASSERT_EQUAL_INT(0, gnrc_netif2_ipv6_get_iid(ethernet_netif, &res));
|
||
|
TEST_ASSERT_EQUAL_INT(0, memcmp(&res, ðernet_ipv6_ll.u64[1],
|
||
|
sizeof(res)));
|
||
|
for (unsigned i = 0; i < DEFAULT_DEVS_NUMOF; i++) {
|
||
|
TEST_ASSERT_EQUAL_INT(-ENOTSUP, gnrc_netif2_ipv6_get_iid(netifs[i], &res));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
static void test_netapi_get__HOP_LIMIT(void)
|
||
|
{
|
||
|
uint8_t value;
|
||
|
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(value),
|
||
|
gnrc_netapi_get(netifs[0]->pid, NETOPT_HOP_LIMIT,
|
||
|
0, &value, sizeof(value)));
|
||
|
TEST_ASSERT_EQUAL_INT(netifs[0]->cur_hl, value);
|
||
|
}
|
||
|
|
||
|
static void test_netapi_get__IPV6_ADDR(void)
|
||
|
{
|
||
|
static const ipv6_addr_t exp = { NETIF0_IPV6_LL };
|
||
|
ipv6_addr_t value[GNRC_NETIF2_IPV6_ADDRS_NUMOF];
|
||
|
|
||
|
test_ipv6_addr_add__success();
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(ipv6_addr_t), gnrc_netapi_get(netifs[0]->pid,
|
||
|
NETOPT_IPV6_ADDR,
|
||
|
0, &value,
|
||
|
sizeof(value)));
|
||
|
TEST_ASSERT(ipv6_addr_equal(&exp, &value[0]));
|
||
|
}
|
||
|
|
||
|
static void test_netapi_get__IPV6_ADDR_FLAGS(void)
|
||
|
{
|
||
|
uint8_t value[GNRC_NETIF2_IPV6_ADDRS_NUMOF];
|
||
|
|
||
|
test_ipv6_addr_add__success();
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(uint8_t), gnrc_netapi_get(netifs[0]->pid,
|
||
|
NETOPT_IPV6_ADDR_FLAGS,
|
||
|
0, &value,
|
||
|
sizeof(value)));
|
||
|
TEST_ASSERT_EQUAL_INT(GNRC_NETIF2_IPV6_ADDRS_FLAGS_STATE_VALID,
|
||
|
value[0]);
|
||
|
}
|
||
|
|
||
|
static void test_netapi_get__IPV6_GROUP(void)
|
||
|
{
|
||
|
ipv6_addr_t value[GNRC_NETIF2_IPV6_GROUPS_NUMOF];
|
||
|
|
||
|
test_ipv6_group_join__success();
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(ipv6_addr_t), gnrc_netapi_get(netifs[0]->pid,
|
||
|
NETOPT_IPV6_GROUP,
|
||
|
0, &value,
|
||
|
sizeof(value)));
|
||
|
TEST_ASSERT(ipv6_addr_equal(&ipv6_addr_all_nodes_link_local, &value[0]));
|
||
|
}
|
||
|
|
||
|
static void test_netapi_get__IPV6_IID(void)
|
||
|
{
|
||
|
static const ipv6_addr_t ethernet_ipv6_ll = { .u8 = ETHERNET_IPV6_LL };
|
||
|
eui64_t value;
|
||
|
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(eui64_t), gnrc_netapi_get(ethernet_netif->pid,
|
||
|
NETOPT_IPV6_IID,
|
||
|
0, &value, sizeof(value)));
|
||
|
TEST_ASSERT_EQUAL_INT(0, memcmp(&value, ðernet_ipv6_ll.u64[1],
|
||
|
sizeof(value)));
|
||
|
TEST_ASSERT_EQUAL_INT(-ENOTSUP, gnrc_netapi_get(netifs[0]->pid,
|
||
|
NETOPT_IPV6_IID,
|
||
|
0, &value, sizeof(value)));
|
||
|
}
|
||
|
|
||
|
static void test_netapi_get__MAX_PACKET_SIZE(void)
|
||
|
{
|
||
|
uint16_t value;
|
||
|
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(uint16_t), gnrc_netapi_get(ethernet_netif->pid,
|
||
|
NETOPT_MAX_PACKET_SIZE,
|
||
|
GNRC_NETTYPE_IPV6,
|
||
|
&value, sizeof(value)));
|
||
|
TEST_ASSERT_EQUAL_INT(ETHERNET_DATA_LEN, value);
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(uint16_t), gnrc_netapi_get(ethernet_netif->pid,
|
||
|
NETOPT_MAX_PACKET_SIZE,
|
||
|
GNRC_NETTYPE_NETIF,
|
||
|
&value, sizeof(value)));
|
||
|
TEST_ASSERT_EQUAL_INT(ETHERNET_DATA_LEN, value);
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(uint16_t), gnrc_netapi_get(netifs[0]->pid,
|
||
|
NETOPT_MAX_PACKET_SIZE,
|
||
|
GNRC_NETTYPE_IPV6,
|
||
|
&value, sizeof(value)));
|
||
|
TEST_ASSERT_EQUAL_INT(IPV6_MIN_MTU, value);
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(uint16_t), gnrc_netapi_get(netifs[0]->pid,
|
||
|
NETOPT_MAX_PACKET_SIZE,
|
||
|
GNRC_NETTYPE_NETIF,
|
||
|
&value, sizeof(value)));
|
||
|
TEST_ASSERT_EQUAL_INT(IPV6_MIN_MTU, value);
|
||
|
}
|
||
|
|
||
|
static void test_netapi_get__6LO_IPHC(void)
|
||
|
{
|
||
|
netopt_enable_t value;
|
||
|
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(netopt_enable_t),
|
||
|
gnrc_netapi_get(ethernet_netif->pid,
|
||
|
NETOPT_6LO_IPHC, 0,
|
||
|
&value, sizeof(value)));
|
||
|
TEST_ASSERT_EQUAL_INT(NETOPT_DISABLE, value);
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(netopt_enable_t),
|
||
|
gnrc_netapi_get(netifs[0]->pid,
|
||
|
NETOPT_6LO_IPHC, 0,
|
||
|
&value, sizeof(value)));
|
||
|
TEST_ASSERT_EQUAL_INT(NETOPT_DISABLE, value);
|
||
|
}
|
||
|
|
||
|
static void test_netapi_get__ADDRESS(void)
|
||
|
{
|
||
|
static const uint8_t exp_ethernet[] = ETHERNET_SRC;
|
||
|
uint8_t value[GNRC_NETIF2_L2ADDR_MAXLEN];
|
||
|
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(exp_ethernet),
|
||
|
gnrc_netapi_get(ethernet_netif->pid,
|
||
|
NETOPT_ADDRESS, 0,
|
||
|
&value, sizeof(value)));
|
||
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp_ethernet, value, sizeof(exp_ethernet)));
|
||
|
}
|
||
|
|
||
|
static void test_netapi_get__ADDRESS_LONG(void)
|
||
|
{
|
||
|
uint8_t value[GNRC_NETIF2_L2ADDR_MAXLEN];
|
||
|
|
||
|
TEST_ASSERT_EQUAL_INT(-ENOTSUP,
|
||
|
gnrc_netapi_get(ethernet_netif->pid,
|
||
|
NETOPT_ADDRESS_LONG, 0,
|
||
|
&value, sizeof(value)));
|
||
|
TEST_ASSERT_EQUAL_INT(-ENOTSUP,
|
||
|
gnrc_netapi_get(netifs[0]->pid,
|
||
|
NETOPT_ADDRESS_LONG, 0,
|
||
|
&value, sizeof(value)));
|
||
|
}
|
||
|
|
||
|
static void test_netapi_set__HOP_LIMIT(void)
|
||
|
{
|
||
|
uint8_t value = 89;
|
||
|
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(value),
|
||
|
gnrc_netapi_set(netifs[0]->pid,
|
||
|
NETOPT_HOP_LIMIT, 0,
|
||
|
&value, sizeof(value)));
|
||
|
TEST_ASSERT_EQUAL_INT(value, netifs[0]->cur_hl);
|
||
|
}
|
||
|
|
||
|
static void test_netapi_set__IPV6_ADDR(void)
|
||
|
{
|
||
|
ipv6_addr_t value = { .u8 = NETIF0_IPV6_LL };
|
||
|
static const uint16_t context = (64U << 8) |
|
||
|
(GNRC_NETIF2_IPV6_ADDRS_FLAGS_STATE_VALID);
|
||
|
|
||
|
TEST_ASSERT(0 > gnrc_netif2_ipv6_addr_idx(netifs[0], &value));
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(value),
|
||
|
gnrc_netapi_set(netifs[0]->pid,
|
||
|
NETOPT_IPV6_ADDR, context,
|
||
|
&value, sizeof(value)));
|
||
|
TEST_ASSERT(0 <= gnrc_netif2_ipv6_addr_idx(netifs[0], &value));
|
||
|
}
|
||
|
|
||
|
static void test_netapi_set__IPV6_ADDR_REMOVE(void)
|
||
|
{
|
||
|
ipv6_addr_t value = { .u8 = NETIF0_IPV6_LL };
|
||
|
|
||
|
test_ipv6_addr_add__success();
|
||
|
TEST_ASSERT(0 <= gnrc_netif2_ipv6_addr_idx(netifs[0], &value));
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(value),
|
||
|
gnrc_netapi_set(netifs[0]->pid,
|
||
|
NETOPT_IPV6_ADDR_REMOVE, 0,
|
||
|
&value, sizeof(value)));
|
||
|
TEST_ASSERT(0 > gnrc_netif2_ipv6_addr_idx(netifs[0], &value));
|
||
|
}
|
||
|
|
||
|
static void test_netapi_set__IPV6_GROUP(void)
|
||
|
{
|
||
|
ipv6_addr_t value = IPV6_ADDR_ALL_NODES_LINK_LOCAL;
|
||
|
|
||
|
TEST_ASSERT(0 > gnrc_netif2_ipv6_group_idx(netifs[0], &value));
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(value),
|
||
|
gnrc_netapi_set(netifs[0]->pid,
|
||
|
NETOPT_IPV6_GROUP, 0,
|
||
|
&value, sizeof(value)));
|
||
|
TEST_ASSERT(0 <= gnrc_netif2_ipv6_group_idx(netifs[0], &value));
|
||
|
}
|
||
|
|
||
|
static void test_netapi_set__IPV6_GROUP_LEAVE(void)
|
||
|
{
|
||
|
ipv6_addr_t value = IPV6_ADDR_ALL_NODES_LINK_LOCAL;
|
||
|
|
||
|
test_ipv6_group_join__success();
|
||
|
TEST_ASSERT(0 <= gnrc_netif2_ipv6_group_idx(netifs[0], &value));
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(value),
|
||
|
gnrc_netapi_set(netifs[0]->pid,
|
||
|
NETOPT_IPV6_GROUP_LEAVE, 0,
|
||
|
&value, sizeof(value)));
|
||
|
TEST_ASSERT(0 > gnrc_netif2_ipv6_group_idx(netifs[0], &value));
|
||
|
}
|
||
|
|
||
|
static void test_netapi_set__MAX_PACKET_SIZE(void)
|
||
|
{
|
||
|
uint16_t value = 57194;
|
||
|
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(value),
|
||
|
gnrc_netapi_set(netifs[0]->pid,
|
||
|
NETOPT_MAX_PACKET_SIZE,
|
||
|
GNRC_NETTYPE_IPV6,
|
||
|
&value, sizeof(value)));
|
||
|
TEST_ASSERT_EQUAL_INT(value, netifs[0]->ipv6.mtu);
|
||
|
TEST_ASSERT_EQUAL_INT(-ENOTSUP,
|
||
|
gnrc_netapi_set(netifs[0]->pid,
|
||
|
NETOPT_MAX_PACKET_SIZE, 0,
|
||
|
&value, sizeof(value)));
|
||
|
}
|
||
|
|
||
|
static void test_netapi_set__6LO_IPHC(void)
|
||
|
{
|
||
|
netopt_enable_t value = NETOPT_ENABLE;
|
||
|
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(value),
|
||
|
gnrc_netapi_set(netifs[0]->pid,
|
||
|
NETOPT_6LO_IPHC, 0,
|
||
|
&value, sizeof(value)));
|
||
|
TEST_ASSERT(netifs[0]->flags & GNRC_NETIF2_FLAGS_6LO_HC);
|
||
|
}
|
||
|
|
||
|
static void test_netapi_set__ADDRESS(void)
|
||
|
{
|
||
|
static const uint8_t exp_ethernet[] = ETHERNET_SRC;
|
||
|
uint8_t value[] = { LA1 + 1, LA2 + 2, LA3 + 3, LA4 + 4, LA5 + 5, LA6 + 6 };
|
||
|
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(exp_ethernet),
|
||
|
gnrc_netapi_set(ethernet_netif->pid,
|
||
|
NETOPT_ADDRESS, 0,
|
||
|
&value, sizeof(value)));
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(value), ethernet_netif->l2addr_len);
|
||
|
TEST_ASSERT_EQUAL_INT(0, memcmp(value, ethernet_netif->l2addr,
|
||
|
sizeof(value)));
|
||
|
TEST_ASSERT_EQUAL_INT(-ENOTSUP,
|
||
|
gnrc_netapi_set(netifs[0]->pid,
|
||
|
NETOPT_ADDRESS_LONG, 0,
|
||
|
&value, sizeof(value)));
|
||
|
/* return addresses to previous state for further testing */
|
||
|
memcpy(value, exp_ethernet, sizeof(exp_ethernet));
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(exp_ethernet),
|
||
|
gnrc_netapi_set(ethernet_netif->pid,
|
||
|
NETOPT_ADDRESS, 0,
|
||
|
&value, sizeof(value)));
|
||
|
TEST_ASSERT_EQUAL_INT(sizeof(value), ethernet_netif->l2addr_len);
|
||
|
TEST_ASSERT_EQUAL_INT(0, memcmp(value, ethernet_netif->l2addr,
|
||
|
sizeof(value)));
|
||
|
}
|
||
|
|
||
|
static void test_netapi_set__ADDRESS_LONG(void)
|
||
|
{
|
||
|
uint8_t value[GNRC_NETIF2_L2ADDR_MAXLEN];
|
||
|
|
||
|
TEST_ASSERT_EQUAL_INT(-ENOTSUP,
|
||
|
gnrc_netapi_set(ethernet_netif->pid,
|
||
|
NETOPT_ADDRESS_LONG, 0,
|
||
|
&value, sizeof(value)));
|
||
|
TEST_ASSERT_EQUAL_INT(-ENOTSUP,
|
||
|
gnrc_netapi_set(netifs[0]->pid,
|
||
|
NETOPT_ADDRESS_LONG, 0,
|
||
|
&value, sizeof(value)));
|
||
|
}
|
||
|
|
||
|
static void test_netapi_send__raw_unicast_ethernet_packet(void)
|
||
|
{
|
||
|
uint8_t dst[] = { LA1, LA2, LA3, LA4, LA5, LA6 + 1 };
|
||
|
gnrc_pktsnip_t *pkt = gnrc_pktbuf_add(NULL, "ABCDEFG",
|
||
|
sizeof("ABCDEFG"),
|
||
|
GNRC_NETTYPE_UNDEF);
|
||
|
TEST_ASSERT_NOT_NULL(pkt);
|
||
|
gnrc_pktsnip_t *netif = gnrc_netif_hdr_build(NULL, 0, dst, sizeof(dst));
|
||
|
TEST_ASSERT_NOT_NULL(netif);
|
||
|
LL_PREPEND(pkt, netif);
|
||
|
gnrc_netapi_send(ethernet_netif->pid, pkt);
|
||
|
}
|
||
|
|
||
|
static void test_netapi_send__raw_broadcast_ethernet_packet(void)
|
||
|
{
|
||
|
gnrc_netif_hdr_t *hdr;
|
||
|
gnrc_pktsnip_t *pkt = gnrc_pktbuf_add(NULL, "ABCDEFG",
|
||
|
sizeof("ABCDEFG"),
|
||
|
GNRC_NETTYPE_UNDEF);
|
||
|
TEST_ASSERT_NOT_NULL(pkt);
|
||
|
gnrc_pktsnip_t *netif = gnrc_netif_hdr_build(NULL, 0, NULL, 0);
|
||
|
TEST_ASSERT_NOT_NULL(netif);
|
||
|
hdr = netif->data;
|
||
|
hdr->flags |= GNRC_NETIF_HDR_FLAGS_BROADCAST;
|
||
|
LL_PREPEND(pkt, netif);
|
||
|
gnrc_netapi_send(ethernet_netif->pid, pkt);
|
||
|
}
|
||
|
|
||
|
static void test_netapi_send__ipv6_unicast_ethernet_packet(void)
|
||
|
{
|
||
|
ipv6_hdr_t *ipv6_hdr;
|
||
|
uint8_t dst_netif[] = { LA1, LA2, LA3, LA4, LA5, LA6 + 1 };
|
||
|
static const ipv6_addr_t dst_ipv6 = { .u8 = { LP1, LP2, LP3, LP4,
|
||
|
LP5, LP6, LP7, LP8,
|
||
|
LA1 ^ 0x2, LA2, LA3, 0xff,
|
||
|
0xfe, LA4, LA5, LA6 + 1} };
|
||
|
static const ipv6_addr_t src_ipv6 = { .u8 = ETHERNET_IPV6_LL };
|
||
|
gnrc_pktsnip_t *payload = gnrc_pktbuf_add(NULL, "ABCDEFG",
|
||
|
sizeof("ABCDEFG"),
|
||
|
GNRC_NETTYPE_UNDEF);
|
||
|
TEST_ASSERT_NOT_NULL(payload);
|
||
|
/* we don't send through gnrc_ipv6 (because we are lazy and don't want
|
||
|
* to update the neighbor cache ;-)) so we need to set the IPv6 source
|
||
|
* address */
|
||
|
gnrc_pktsnip_t *pkt = gnrc_ipv6_hdr_build(payload, &src_ipv6, &dst_ipv6);
|
||
|
TEST_ASSERT_NOT_NULL(pkt);
|
||
|
ipv6_hdr = pkt->data;
|
||
|
ipv6_hdr->len = byteorder_htons(sizeof("ABCDEFG"));
|
||
|
ipv6_hdr->nh = PROTNUM_IPV6_NONXT;
|
||
|
ipv6_hdr->hl = ethernet_netif->cur_hl;
|
||
|
gnrc_pktsnip_t *netif = gnrc_netif_hdr_build(NULL, 0, dst_netif,
|
||
|
sizeof(dst_netif));
|
||
|
TEST_ASSERT_NOT_NULL(netif);
|
||
|
LL_PREPEND(pkt, netif);
|
||
|
gnrc_netapi_send(ethernet_netif->pid, pkt);
|
||
|
}
|
||
|
|
||
|
static void test_netapi_send__ipv6_multicast_ethernet_packet(void)
|
||
|
{
|
||
|
ipv6_hdr_t *ipv6_hdr;
|
||
|
gnrc_netif_hdr_t *netif_hdr;
|
||
|
static const ipv6_addr_t src_ipv6 = { .u8 = ETHERNET_IPV6_LL };
|
||
|
gnrc_pktsnip_t *payload = gnrc_pktbuf_add(NULL, "ABCDEFG",
|
||
|
sizeof("ABCDEFG"),
|
||
|
GNRC_NETTYPE_UNDEF);
|
||
|
TEST_ASSERT_NOT_NULL(payload);
|
||
|
/* we don't send through gnrc_ipv6 (because we are lazy and don't want
|
||
|
* to update the neighbor cache ;-)) so we need to set the IPv6 source
|
||
|
* address */
|
||
|
gnrc_pktsnip_t *pkt = gnrc_ipv6_hdr_build(payload, &src_ipv6,
|
||
|
&ipv6_addr_all_nodes_link_local);
|
||
|
TEST_ASSERT_NOT_NULL(pkt);
|
||
|
ipv6_hdr = pkt->data;
|
||
|
ipv6_hdr->len = byteorder_htons(sizeof("ABCDEFG"));
|
||
|
ipv6_hdr->nh = PROTNUM_IPV6_NONXT;
|
||
|
ipv6_hdr->hl = ethernet_netif->cur_hl;
|
||
|
gnrc_pktsnip_t *netif = gnrc_netif_hdr_build(NULL, 0, NULL, 0);
|
||
|
TEST_ASSERT_NOT_NULL(netif);
|
||
|
netif_hdr = netif->data;
|
||
|
netif_hdr->flags |= GNRC_NETIF_HDR_FLAGS_MULTICAST;
|
||
|
LL_PREPEND(pkt, netif);
|
||
|
gnrc_netapi_send(ethernet_netif->pid, pkt);
|
||
|
}
|
||
|
|
||
|
static void test_netapi_recv__empty_ethernet_payload(void)
|
||
|
{
|
||
|
static const uint8_t data[] = { LA1, LA2, LA3, LA6, LA7, LA8,
|
||
|
LA1, LA2, LA3, LA6, LA7, LA8 + 1,
|
||
|
0xff, 0xff };
|
||
|
|
||
|
puts("pktdump dumping Ethernet packet with empty payload");
|
||
|
_test_trigger_recv(ethernet_netif, data, sizeof(data));
|
||
|
}
|
||
|
|
||
|
static void test_netapi_recv__raw_ethernet_payload(void)
|
||
|
{
|
||
|
static const uint8_t data[] = { LA1, LA2, LA3, LA6, LA7, LA8,
|
||
|
LA1, LA2, LA3, LA6, LA7, LA8 + 1,
|
||
|
0xff, 0xff, 0x12, 0x34, 0x45, 0x56 };
|
||
|
|
||
|
puts("pktdump dumping Ethernet packet with payload 12 34 45 56");
|
||
|
_test_trigger_recv(ethernet_netif, data, sizeof(data));
|
||
|
}
|
||
|
|
||
|
static void test_netapi_recv__ipv6_ethernet_payload(void)
|
||
|
{
|
||
|
static const uint8_t data[] = { LA1, LA2, LA3, LA6, LA7, LA8,
|
||
|
LA1, LA2, LA3, LA6, LA7, LA8 + 1,
|
||
|
0x86, 0xdd, /* Ethertype: IPv6 */
|
||
|
0x60, 0, 0, 0, /* Version + TC + FL */
|
||
|
0, 1, /* payload length 1 */
|
||
|
59, /* next header: no next header */
|
||
|
64, /* hop limit */
|
||
|
/* IPv6 source */
|
||
|
LP1, LP2, LP3, LP4, LP5, LP6, LP7, LP8,
|
||
|
LA1 ^ 1, LA2, LA3, 0xff, 0xfe, LA6, LA7, LA8,
|
||
|
/* IPv6 destination */
|
||
|
LP1, LP2, LP3, LP4, LP5, LP6, LP7, LP8,
|
||
|
LA1 ^ 1, LA2, LA3, 0xff, 0xfe, LA6, LA7, LA8 + 1,
|
||
|
0x01 /* payload */
|
||
|
};
|
||
|
|
||
|
puts("pktdump dumping IPv6 over Ethernet packet with payload 01");
|
||
|
_test_trigger_recv(ethernet_netif, data, sizeof(data));
|
||
|
}
|
||
|
|
||
|
static Test *embunit_tests_gnrc_netif2(void)
|
||
|
{
|
||
|
EMB_UNIT_TESTFIXTURES(fixtures) {
|
||
|
new_TestFixture(test_creation),
|
||
|
new_TestFixture(test_get_by_pid),
|
||
|
new_TestFixture(test_addr_to_str),
|
||
|
new_TestFixture(test_addr_from_str),
|
||
|
new_TestFixture(test_ipv6_addr_add__ENOMEM),
|
||
|
new_TestFixture(test_ipv6_addr_add__success),
|
||
|
new_TestFixture(test_ipv6_addr_add__readd_with_free_entry),
|
||
|
new_TestFixture(test_ipv6_addr_remove__not_allocated),
|
||
|
new_TestFixture(test_ipv6_addr_remove__success),
|
||
|
new_TestFixture(test_ipv6_addr_idx__empty),
|
||
|
new_TestFixture(test_ipv6_addr_idx__wrong_netif),
|
||
|
new_TestFixture(test_ipv6_addr_idx__wrong_addr),
|
||
|
new_TestFixture(test_ipv6_addr_idx__success),
|
||
|
new_TestFixture(test_ipv6_addr_match__empty),
|
||
|
new_TestFixture(test_ipv6_addr_match__wrong_netif),
|
||
|
new_TestFixture(test_ipv6_addr_match__wrong_addr),
|
||
|
new_TestFixture(test_ipv6_addr_match__success18),
|
||
|
new_TestFixture(test_ipv6_addr_match__success23),
|
||
|
new_TestFixture(test_ipv6_addr_match__success64),
|
||
|
new_TestFixture(test_ipv6_addr_best_src__multicast_input),
|
||
|
new_TestFixture(test_ipv6_addr_best_src__other_subnet),
|
||
|
new_TestFixture(test_get_by_ipv6_addr__empty),
|
||
|
new_TestFixture(test_get_by_ipv6_addr__success),
|
||
|
new_TestFixture(test_get_by_prefix__empty),
|
||
|
new_TestFixture(test_get_by_prefix__success18),
|
||
|
new_TestFixture(test_get_by_prefix__success23),
|
||
|
new_TestFixture(test_get_by_prefix__success64),
|
||
|
new_TestFixture(test_ipv6_group_join__ENOMEM),
|
||
|
new_TestFixture(test_ipv6_group_join__success),
|
||
|
new_TestFixture(test_ipv6_group_join__readd_with_free_entry),
|
||
|
new_TestFixture(test_ipv6_group_leave__not_allocated),
|
||
|
new_TestFixture(test_ipv6_group_leave__success),
|
||
|
new_TestFixture(test_ipv6_group_idx__empty),
|
||
|
new_TestFixture(test_ipv6_group_idx__wrong_netif),
|
||
|
new_TestFixture(test_ipv6_group_idx__wrong_addr),
|
||
|
new_TestFixture(test_ipv6_group_idx__success),
|
||
|
new_TestFixture(test_ipv6_get_iid),
|
||
|
new_TestFixture(test_netapi_get__HOP_LIMIT),
|
||
|
new_TestFixture(test_netapi_get__IPV6_ADDR),
|
||
|
new_TestFixture(test_netapi_get__IPV6_ADDR_FLAGS),
|
||
|
new_TestFixture(test_netapi_get__IPV6_GROUP),
|
||
|
new_TestFixture(test_netapi_get__IPV6_IID),
|
||
|
new_TestFixture(test_netapi_get__MAX_PACKET_SIZE),
|
||
|
new_TestFixture(test_netapi_get__6LO_IPHC),
|
||
|
new_TestFixture(test_netapi_get__ADDRESS),
|
||
|
new_TestFixture(test_netapi_get__ADDRESS_LONG),
|
||
|
new_TestFixture(test_netapi_set__HOP_LIMIT),
|
||
|
new_TestFixture(test_netapi_set__IPV6_ADDR),
|
||
|
new_TestFixture(test_netapi_set__IPV6_ADDR_REMOVE),
|
||
|
new_TestFixture(test_netapi_set__IPV6_GROUP),
|
||
|
new_TestFixture(test_netapi_set__IPV6_GROUP_LEAVE),
|
||
|
new_TestFixture(test_netapi_set__MAX_PACKET_SIZE),
|
||
|
new_TestFixture(test_netapi_set__6LO_IPHC),
|
||
|
new_TestFixture(test_netapi_set__ADDRESS),
|
||
|
new_TestFixture(test_netapi_set__ADDRESS_LONG),
|
||
|
/* only add tests not involving output here */
|
||
|
};
|
||
|
EMB_UNIT_TESTCALLER(tests, _set_up, NULL, fixtures);
|
||
|
|
||
|
return (Test *)&tests;
|
||
|
}
|
||
|
|
||
|
int main(void)
|
||
|
{
|
||
|
_tests_init();
|
||
|
netdev_test_set_get_cb((netdev_test_t *)ethernet_dev, NETOPT_ADDRESS,
|
||
|
_get_netdev_address);
|
||
|
netdev_test_set_set_cb((netdev_test_t *)ethernet_dev, NETOPT_ADDRESS,
|
||
|
_set_netdev_address);
|
||
|
TESTS_START();
|
||
|
TESTS_RUN(embunit_tests_gnrc_netif2());
|
||
|
TESTS_END();
|
||
|
/* add netapi send and receive tests here */
|
||
|
test_netapi_send__raw_unicast_ethernet_packet();
|
||
|
test_netapi_send__raw_broadcast_ethernet_packet();
|
||
|
test_netapi_send__ipv6_unicast_ethernet_packet();
|
||
|
test_netapi_send__ipv6_multicast_ethernet_packet();
|
||
|
test_netapi_recv__empty_ethernet_payload();
|
||
|
test_netapi_recv__raw_ethernet_payload();
|
||
|
test_netapi_recv__ipv6_ethernet_payload();
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
static inline int _mock_netif_send(gnrc_netif2_t *netif, gnrc_pktsnip_t *pkt)
|
||
|
{
|
||
|
(void)netif;
|
||
|
(void)pkt;
|
||
|
return -1;
|
||
|
}
|
||
|
|
||
|
static inline gnrc_pktsnip_t *_mock_netif_recv(gnrc_netif2_t * netif)
|
||
|
{
|
||
|
(void)netif;
|
||
|
return NULL;
|
||
|
}
|
||
|
|
||
|
static uint8_t ethernet_l2addr[] = ETHERNET_SRC;
|
||
|
|
||
|
static int _get_netdev_address(netdev_t *dev, void *value, size_t max_len)
|
||
|
{
|
||
|
if (dev == ethernet_dev) {
|
||
|
assert(max_len >= sizeof(ethernet_l2addr));
|
||
|
memcpy(value, ethernet_l2addr, sizeof(ethernet_l2addr));
|
||
|
return sizeof(ethernet_l2addr);
|
||
|
}
|
||
|
return -ENOTSUP;
|
||
|
}
|
||
|
|
||
|
static int _set_netdev_address(netdev_t *dev, const void *value, size_t value_len)
|
||
|
{
|
||
|
if (dev == ethernet_dev) {
|
||
|
assert(value_len <= sizeof(ethernet_l2addr));
|
||
|
memcpy(ethernet_l2addr, value, value_len);
|
||
|
return value_len;
|
||
|
}
|
||
|
return -ENOTSUP;
|
||
|
}
|