From 99e6bc6ea1dfee48969d59ba212bc3e47a5fd261 Mon Sep 17 00:00:00 2001 From: hanen mizouni Date: Thu, 2 Jan 2020 18:02:27 +0000 Subject: [PATCH 1/2] test:improve coverage of antispoof Signed-off-by: hanen mizouni --- src/brick-int.h | 4 +- src/utils/errors.h | 5 ++ tests/antispoof/test-ndp.c | 14 ++++++ tests/antispoof/tests.c | 96 ++++++++++++++++++++++++++++++++++++-- 4 files changed, 112 insertions(+), 7 deletions(-) diff --git a/src/brick-int.h b/src/brick-int.h index e8c6a8524..3afad9afd 100644 --- a/src/brick-int.h +++ b/src/brick-int.h @@ -208,8 +208,8 @@ int pg_brick_reset(struct pg_brick *brick, struct pg_error **errp); /* testing */ uint32_t pg_brick_links_count_get(const struct pg_brick *brick, - const struct pg_brick *target, - struct pg_error **errp); + const struct pg_brick *target, + struct pg_error **errp); int64_t pg_brick_refcount(const struct pg_brick *brick); /* generic functions used to factorize code */ diff --git a/src/utils/errors.h b/src/utils/errors.h index 391852e58..7cd9ded0d 100644 --- a/src/utils/errors.h +++ b/src/utils/errors.h @@ -57,5 +57,10 @@ pg_error_make_ctx_internal(const char *file, uint64_t line, const char *func); pg_error_make_ctx_internal(__FILE__, (__LINE__ + line_decalage), \ __func__); +#define PG_ERROR_EXISTS(error) do { \ + g_assert(error); \ + pg_error_free(error); \ + error = NULL; \ + } while (0) #endif /* _PG_UTILS_ERRORS_H */ diff --git a/tests/antispoof/test-ndp.c b/tests/antispoof/test-ndp.c index 1a8fa41c9..4bff435c4 100644 --- a/tests/antispoof/test-ndp.c +++ b/tests/antispoof/test-ndp.c @@ -147,3 +147,17 @@ static const unsigned char pkt2[86] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0x02, 0x01, /* ........ */ 0x52, 0x54, 0x00, 0x12, 0x34, 0x06 /* RT..4. */ }; + +/* pkt3 with Next header : UDP (17) + * + * */ +unsigned char pkt3[86]; +memcpy(pkt3, pkt2, 86); +pkt3[20] = 0x11; + +/* Internet Control Message Protocol v6 + * Type: Neighbor Advertisement (137) + * */ +unsigned char pkt4[86]; +memcpy(pkt4, pkt2, 86); +pkt4[46] = 0x89; diff --git a/tests/antispoof/tests.c b/tests/antispoof/tests.c index e46478c44..acec3ddbf 100644 --- a/tests/antispoof/tests.c +++ b/tests/antispoof/tests.c @@ -32,6 +32,7 @@ #include "fail.h" #include "utils/mac.h" #include "utils/ip.h" +#include "utils/errors.h" static struct rte_mbuf *build_packet(const unsigned char *data, size_t len) { @@ -253,10 +254,57 @@ static void test_antispoof_generic(const unsigned char **pkts, pg_error_free(error); error = NULL; + /* re-add other IP and original IP, should pass */ + g_assert(!pg_antispoof_arp_del(antispoof, 42, &error)); + g_assert(!pg_antispoof_arp_del(antispoof, 51, &error)); + g_assert(!pg_antispoof_arp_add(antispoof, 42, &error)); + g_assert(!pg_antispoof_arp_add(antispoof, 51, &error)); + g_assert(!pg_antispoof_arp_add(antispoof, inside_ip, &error)); + g_assert(!error); + REPLAY(1); + + /* remove IP, should not pass */ + pg_antispoof_arp_del_all(antispoof); + REPLAY(0); + + /* add ARP_MAX */ + for (int i = 0; i <= 150; i++) { + if (i < PG_ARP_MAX) { + g_assert(!pg_antispoof_arp_add(antispoof, i, &error)); + g_assert(!error); + } else { + g_assert(pg_antispoof_arp_add(antispoof, i, &error)); + PG_ERROR_EXISTS(error); + } + } + + /* remove IP, should not pass */ + pg_antispoof_arp_del_all(antispoof); + REPLAY(0); + /* disable arp antispoof, should pass */ pg_antispoof_arp_disable(antispoof); REPLAY(1); + /* add ARP_MAX */ + for (int i = 0; i <= 150; i++) { + if (i < PG_ARP_MAX) { + g_assert(!pg_antispoof_arp_add(antispoof, i, &error)); + g_assert(!error); + } else { + g_assert(pg_antispoof_arp_add(antispoof, i, &error)); + PG_ERROR_EXISTS(error); + } + } + + /* remove IP, should pass */ + pg_antispoof_arp_del_all(antispoof); + REPLAY(1); + + /* disable arp antispoof, should pass */ + pg_antispoof_arp_disable(antispoof); + REPLAY(1); + /* enable arp antispoof again, should re-block */ pg_antispoof_arp_enable(antispoof); REPLAY(0); @@ -265,8 +313,7 @@ static void test_antispoof_generic(const unsigned char **pkts, pg_brick_unlink(antispoof, &error); g_assert(!error); pg_brick_destroy(antispoof); - antispoof = pg_antispoof_new("antispoof", PG_WEST_SIDE, - &inside_mac, &error); + antispoof = pg_antispoof_new("antispoof", PG_WEST_SIDE, &inside_mac, &error); pg_antispoof_arp_enable(antispoof); g_assert(!pg_antispoof_arp_add(antispoof, inside_ip, &error)); g_assert(!error); @@ -275,6 +322,7 @@ static void test_antispoof_generic(const unsigned char **pkts, pg_brick_link(antispoof, col_east, &error); g_assert(!error); REPLAY(1); + pg_brick_destroy(antispoof); #undef REPLAY pg_brick_destroy(gen_west); @@ -437,8 +485,8 @@ static void test_antispoof_empty_burst(void) g_free(pkts); } -static int test_antispoof_filter(struct pg_brick *antispoof, - struct rte_mbuf *packet) +static int test_antispoof_filter(struct pg_brick *antispoof, + struct rte_mbuf *packet) { struct pg_brick *gen_west; struct pg_brick *col_east; @@ -521,6 +569,30 @@ static void test_antispoof_ndp(void) pg_antispoof_ndp_enable(antispoof); pg_antispoof_ndp_del_all(antispoof); + /* add NDP_MAX adresses */ + for (int i = 0; i < 150; i++) { + pg_autofree char *c = g_strdup_printf("2001:db8:2000:aff0::%d",i); + pg_ip_from_str(ip, c); + if (i < PG_NPD_MAX) { + pg_antispoof_ndp_add(antispoof, ip, &error); + g_assert(!error); + } else { + pg_antispoof_ndp_add(antispoof, ip, &error); + PG_ERROR_EXISTS(error); + } + } + + /* remove all adresses */ + pg_antispoof_ndp_del_all(antispoof); + + /* add several bad addresses */ + pg_ip_from_str(ip, "2001:db8:2000:aff0::42"); + pg_antispoof_ndp_add(antispoof, ip, &error); + g_assert(!error); + + /* remove all addresses */ + pg_antispoof_ndp_del(antispoof,ip,&error); + /* legit packet */ packet = build_packet(pkt0, 86); g_assert(test_antispoof_filter(antispoof, packet) == 0); @@ -538,10 +610,24 @@ static void test_antispoof_ndp(void) pg_ip_from_str(ip, "2001:db8:2000:aff0::42"); pg_antispoof_ndp_add(antispoof, ip, &error); g_assert(!error); - pg_ip_from_str(ip, "2001:db8:2000:aff0::43"); + pg_ip_from_str(ip, "0"); pg_antispoof_ndp_add(antispoof, ip, &error); g_assert(!error); + /* remove adresse */ + g_assert(pg_antispoof_ndp_del(antispoof,ip,&error) == 0); + g_assert(!error); + + /* legit packet with next header :UDP */ + packet = build_packet(pkt3, 86); + g_assert(test_antispoof_filter(antispoof, packet) != 0); + pg_packets_free(&packet, pg_mask_firsts(1)); + + /* legit packet with type Redirect Message */ + packet = build_packet(pkt4, 86); + g_assert(test_antispoof_filter(antispoof, packet) == 0); + pg_packets_free(&packet, pg_mask_firsts(1)); + /* legit packet */ packet = build_packet(pkt0, 86); g_assert(test_antispoof_filter(antispoof, packet) == 0); From b6d0ef519d2e0d9a0c3be291f8cab9a6afe972ae Mon Sep 17 00:00:00 2001 From: hanen mizouni Date: Mon, 6 Jan 2020 09:40:30 +0000 Subject: [PATCH 2/2] test:improve coverage of brick Signed-off-by: hanen mizouni --- src/brick.c | 5 +- tests/core/test-core.c | 393 +++++++++++++++++++++++++++++++---------- 2 files changed, 306 insertions(+), 92 deletions(-) diff --git a/src/brick.c b/src/brick.c index df1c28f07..b0801b494 100644 --- a/src/brick.c +++ b/src/brick.c @@ -325,13 +325,13 @@ uint32_t pg_brick_links_count_get(const struct pg_brick *brick, const struct pg_brick *target, struct pg_error **errp) { - uint32_t count = 0; + int count = 0; enum pg_side i; const struct pg_brick_side *side; if (!brick) { *errp = pg_error_new("brick is NULL"); - return 0; + return -1; } if (brick->type == PG_MULTIPOLE) { @@ -349,6 +349,7 @@ uint32_t pg_brick_links_count_get(const struct pg_brick *brick, if (side->edge.link && side->edge.link == target) ++count; } else { + *errp = pg_error_new("brick config type is unknown"); return -1; } diff --git a/tests/core/test-core.c b/tests/core/test-core.c index e79359384..bb271baf3 100644 --- a/tests/core/test-core.c +++ b/tests/core/test-core.c @@ -25,38 +25,73 @@ #include "packetgraph/queue.h" #include "utils/network.h" #include "utils/mac-table.h" +#include "utils/errors.h" +#include "utils/common.h" static void test_brick_core_simple_lifecycle(void) { struct pg_error *error = NULL; struct pg_brick *brick; - struct pg_brick_config *config = pg_brick_config_new("mybrick", 2, 2, - PG_MULTIPOLE); + struct pg_brick_config *config = pg_brick_config_new("mybrick", 2, 2, PG_MULTIPOLE); + struct pg_brick_config *config1 = pg_brick_config_new("mybrick", 2, 2, PG_MONOPOLE); + struct pg_brick_config *config2 = pg_brick_config_new("mybrick", UINT16_MAX, UINT16_MAX, PG_MULTIPOLE); + + brick = pg_brick_new("nop", config1, &error); + g_assert(!brick); + g_assert(error->message); + g_assert_cmpstr(error->message, ==, "A 'PG_MONOPOLE' cannot have more than one neibour per side"); + PG_ERROR_EXISTS(error); + + brick = pg_brick_new("nop", config2, &error); + g_assert(!brick); + g_assert(error->message); + g_assert_cmpstr(error->message, ==, "A 'PG_MULTIPOLE' cannot have more than 65535 edge on PG_WEST_SIDE"); + PG_ERROR_EXISTS(error); + + brick = pg_brick_new(NULL, NULL, &error); + g_assert(!brick); + g_assert(error->message); + g_assert_cmpstr(error->message, ==, "Brick config not set"); + PG_ERROR_EXISTS(error); + + brick = pg_brick_new(NULL, config, &error); + g_assert(!brick); + g_assert(error->message); + g_assert_cmpstr(error->message, ==, "Brick name not set"); + PG_ERROR_EXISTS(error); + + pg_brick_decref(brick, &error); + g_assert(error->message); + g_assert_cmpstr(error->message, ==, "NULL brick"); + PG_ERROR_EXISTS(error); + + g_assert(pg_brick_reset(brick,&error) < 0); + PG_ERROR_EXISTS(error); brick = pg_brick_new("foo", config, &error); g_assert(!brick); - g_assert(error); g_assert(error->message); g_assert_cmpstr(error->message, ==, "Brick 'foo' not found"); - pg_error_free(error); - error = NULL; + PG_ERROR_EXISTS(error); brick = pg_brick_new("nop", config, &error); g_assert(brick); g_assert(!error); + g_assert(brick->refcount >= 0); pg_brick_decref(brick, &error); g_assert(!error); + g_assert(brick->refcount >= 0); brick = pg_brick_decref(NULL, &error); g_assert(!brick); - g_assert(error); g_assert(error->message); g_assert_cmpstr(error->message, ==, "NULL brick"); - pg_error_free(error); - error = NULL; + PG_ERROR_EXISTS(error); pg_brick_config_free(config); + pg_brick_config_free(config1); + pg_brick_config_free(config2); } static void test_brick_core_refcount(void) @@ -90,14 +125,25 @@ static void test_brick_core_refcount(void) pg_brick_config_free(config); } +#define pg_autobrick pg_cleanup(pg_brick_ptrptr_destroy) + static void test_brick_core_link(void) { struct pg_error *error = NULL; - struct pg_brick *west_brick, *middle_brick, *east_brick; - struct pg_brick_config *config = pg_brick_config_new("mybrick", 4, 4, - PG_MULTIPOLE); + struct rte_mbuf **result_pkts; + pg_autobrick struct pg_brick *west_brick, *middle_brick, *east_brick, + *west_brick1, *middle_brick1, *east_brick1, + *west_brick2, *west_brick3, *east_brick3; + struct pg_brick_config *config = pg_brick_config_new("mybrick", 4, 4, PG_MULTIPOLE); + struct pg_brick_config *config1 = pg_brick_config_new("mybrick", 1, 1,4); + struct pg_brick_config *config2 = pg_brick_config_new("mybrick", 1, 1,PG_MONOPOLE); + struct pg_brick_config *config3 = pg_brick_config_new("mybrick", 0, 0,PG_DIPOLE); + int64_t refcount; + uint64_t pkts_mask = 0; int ret; + uint16_t count = 0; + FILE *fd; west_brick = pg_brick_new("nop", config, &error); g_assert(west_brick); @@ -107,6 +153,9 @@ static void test_brick_core_link(void) g_assert(middle_brick); g_assert(!error); + g_assert(pg_brick_reset(middle_brick,&error)!=0); + PG_ERROR_EXISTS(error); + east_brick = pg_brick_new("nop", config, &error); g_assert(east_brick); g_assert(!error); @@ -144,21 +193,95 @@ static void test_brick_core_link(void) refcount = pg_brick_refcount(east_brick); g_assert(refcount == 1); - /* destroy */ - pg_brick_decref(west_brick, &error); + g_assert(pg_brick_poll(NULL, &count, &error) == -1); + PG_ERROR_EXISTS(error); + + result_pkts = pg_brick_west_burst_get(NULL, &pkts_mask, + &error); + g_assert(result_pkts == 0); + PG_ERROR_EXISTS(error); + result_pkts = pg_brick_east_burst_get(NULL, &pkts_mask, + &error); + g_assert(result_pkts == 0); + PG_ERROR_EXISTS(error); + + g_assert(pg_brick_pkts_count_get(NULL, PG_WEST_SIDE) == 0); + + g_assert(pg_brick_rx_bytes(NULL) == 0); + g_assert(pg_brick_tx_bytes(NULL) == 0); + + west_brick1 = pg_brick_new("nop", config1, &error); g_assert(!error); - pg_brick_decref(middle_brick, &error); + + middle_brick1 = pg_brick_new("nop", config1, &error); + g_assert(!error); + + east_brick1 = pg_brick_new("nop", config1, &error); g_assert(!error); - pg_brick_decref(east_brick, &error); + + g_assert(pg_brick_poll(middle_brick1, &count, &error) == -1); + PG_ERROR_EXISTS(error); + + g_assert(!pg_brick_pollable(middle_brick1)); g_assert(!error); + g_assert(pg_brick_rx_bytes(middle_brick1) == 0); + g_assert(pg_brick_tx_bytes(middle_brick1) == 0); + + result_pkts = pg_brick_west_burst_get(middle_brick1, &pkts_mask, + &error); + g_assert(result_pkts == 0); + PG_ERROR_EXISTS(error); + + result_pkts = pg_brick_east_burst_get(middle_brick1, &pkts_mask, + &error); + g_assert(result_pkts == 0); + PG_ERROR_EXISTS(error); + + ret = pg_brick_chained_links_int(&error, middle_brick1, east_brick1, west_brick1); + g_assert(ret == -1); + PG_ERROR_EXISTS(error); + ret = pg_brick_link(east_brick1, west_brick1, &error); + g_assert(ret == -1); + PG_ERROR_EXISTS(error); + + ret = pg_brick_link(west_brick1, middle_brick1, &error); + g_assert(ret == -1); + PG_ERROR_EXISTS(error); + + pg_brick_generic_unlink(east_brick1, &error); + g_assert(!error); + + west_brick2 = pg_brick_new("nop", config2, &error); + g_assert(!error); + + g_assert(pg_brick_unlink_edge(west_brick2, east_brick, &error) == -1); + PG_ERROR_EXISTS(error); + + fd = fopen ("graph","w"); + pg_brick_dot_fd(west_brick2, fd); + + west_brick3 = pg_brick_new("nop", config3, &error); + g_assert(!error); + + east_brick3 = pg_brick_new("nop", config3, &error); + g_assert(!error); + + g_assert(pg_brick_unlink_edge(west_brick3, east_brick3, &error) == -1); + PG_ERROR_EXISTS(error); + + pg_brick_dot_fd(west_brick3, fd); + pg_brick_config_free(config); + pg_brick_config_free(config1); + pg_brick_config_free(config2); + pg_brick_config_free(config3); } static void test_brick_core_unlink_edge(void) { struct pg_error *error = NULL; - struct pg_brick *west_brick, *middle_brick, *east_brick; + pg_autobrick struct pg_brick *west_brick, *middle_brick, *east_brick; struct pg_brick_config *config = pg_brick_config_new("mybrick", 4, 4, PG_MULTIPOLE); int64_t refcount; @@ -180,6 +303,18 @@ static void test_brick_core_unlink_edge(void) g_assert(ret == 0); g_assert(!error); + ret = pg_brick_link(west_brick, west_brick, &error); + g_assert(ret == -1); + g_assert(error->message); + g_assert_cmpstr(error->message, ==, "Can not link a brick to itself"); + PG_ERROR_EXISTS(error); + + ret = pg_brick_link(NULL, west_brick, &error); + g_assert(ret == -1); + g_assert(error->message); + g_assert_cmpstr(error->message, ==, "Node is not valid"); + PG_ERROR_EXISTS(error); + ret = pg_brick_link(middle_brick, east_brick, &error); g_assert(ret == 0); g_assert(!error); @@ -192,13 +327,16 @@ static void test_brick_core_unlink_edge(void) g_assert(refcount == 2); g_assert(pg_brick_unlink_edge(west_brick, east_brick, &error) == -1); - g_assert(error); - pg_error_free(error); - error = NULL; + PG_ERROR_EXISTS(error); + g_assert(pg_brick_unlink_edge(east_brick, west_brick, &error) == -1); - g_assert(error); - pg_error_free(error); - error = NULL; + PG_ERROR_EXISTS(error); + + g_assert(pg_brick_unlink_edge(east_brick, NULL, &error) == -1); + PG_ERROR_EXISTS(error); + + g_assert(pg_brick_unlink_edge(NULL, west_brick, &error) == -1); + PG_ERROR_EXISTS(error); g_assert(!pg_brick_unlink_edge(west_brick, middle_brick, &error)); refcount = pg_brick_refcount(west_brick); @@ -250,20 +388,12 @@ static void test_brick_core_unlink_edge(void) refcount = pg_brick_refcount(east_brick); g_assert(refcount == 1); - /* destroy */ - pg_brick_decref(west_brick, &error); - g_assert(!error); - pg_brick_decref(middle_brick, &error); - g_assert(!error); - pg_brick_decref(east_brick, &error); - g_assert(!error); - pg_brick_config_free(config); } static void test_brick_core_multiple_link(void) { - struct pg_brick *west_brick, *middle_brick, *east_brick; + pg_autobrick struct pg_brick *west_brick, *middle_brick, *east_brick; struct pg_brick_config *config = pg_brick_config_new("mybrick", 4, 4, PG_MULTIPOLE); struct pg_error *error = NULL; @@ -324,14 +454,6 @@ static void test_brick_core_multiple_link(void) refcount = pg_brick_refcount(east_brick); g_assert(refcount == 1); - /* destroy */ - pg_brick_decref(west_brick, &error); - g_assert(!error); - pg_brick_decref(middle_brick, &error); - g_assert(!error); - pg_brick_decref(east_brick, &error); - g_assert(!error); - pg_brick_config_free(config); } @@ -355,13 +477,10 @@ static void test_brick_core_multiple_unlink_edge_(struct pg_brick *west[4], } g_assert(pg_brick_unlink_edge(west[0], east[0], &error) == -1); - g_assert(error); - pg_error_free(error); - error = NULL; + PG_ERROR_EXISTS(error); + g_assert(pg_brick_unlink_edge(east[0], west[0], &error) == -1); - g_assert(error); - pg_error_free(error); - error = NULL; + PG_ERROR_EXISTS(error); g_assert(!pg_brick_unlink_edge(west[0], middle, &error)); g_assert(!error); @@ -484,7 +603,8 @@ static void test_brick_core_multiple_unlink_edge(void) static void test_brick_core_multiple_unlink_edge_same(void) { - struct pg_brick *west_brick, *middle_brick, *east_brick; + pg_autobrick struct pg_brick *west_brick, + *middle_brick, *east_brick; struct pg_brick_config *config = pg_brick_config_new("mybrick", 4, 4, PG_MULTIPOLE); struct pg_error *error = NULL; @@ -528,13 +648,10 @@ static void test_brick_core_multiple_unlink_edge_same(void) g_assert(refcount == 4); g_assert(pg_brick_unlink_edge(west_brick, east_brick, &error) == -1); - g_assert(error); - pg_error_free(error); - error = NULL; + PG_ERROR_EXISTS(error); + g_assert(pg_brick_unlink_edge(east_brick, west_brick, &error) == -1); - g_assert(error); - pg_error_free(error); - error = NULL; + PG_ERROR_EXISTS(error); g_assert(!pg_brick_unlink_edge(west_brick, middle_brick, &error)); g_assert(!error); @@ -581,14 +698,6 @@ static void test_brick_core_multiple_unlink_edge_same(void) refcount = pg_brick_refcount(east_brick); g_assert(refcount == 1); - /* destroy */ - pg_brick_decref(west_brick, &error); - g_assert(!error); - pg_brick_decref(middle_brick, &error); - g_assert(!error); - pg_brick_decref(east_brick, &error); - g_assert(!error); - pg_brick_config_free(config); } @@ -628,9 +737,18 @@ static void test_brick_sanity_check_expected(struct pg_brick *brick, static void test_brick_core_verify_multiple_link(void) { - struct pg_brick *west_brick, *middle_brick, *east_brick; + struct pg_brick *west_brick, *middle_brick, *east_brick, + *west_brick1, *middle_brick1, *east_brick1, + *west_brick2, *middle_brick2, *east_brick2, + *west_brick3, *middle_brick3, *east_brick3; struct pg_brick_config *config = pg_brick_config_new("mybrick", 4, 4, PG_MULTIPOLE); + struct pg_brick_config *config1 = pg_brick_config_new("mybrick", 1, 1, + PG_DIPOLE); + struct pg_brick_config *config2 = pg_brick_config_new("mybrick", 1, 1, + PG_MONOPOLE); + struct pg_brick_config *config3 = pg_brick_config_new("mybrick", 1, 1, + 4); uint32_t links_count; struct pg_error *error = NULL; @@ -641,6 +759,27 @@ static void test_brick_core_verify_multiple_link(void) east_brick = pg_brick_new("nop", config, &error); g_assert(!error); + west_brick1 = pg_brick_new("nop", config1, &error); + g_assert(!error); + middle_brick1 = pg_brick_new("nop", config1, &error); + g_assert(!error); + east_brick1 = pg_brick_new("nop", config1, &error); + g_assert(!error); + + west_brick2 = pg_brick_new("nop", config2, &error); + g_assert(!error); + middle_brick2 = pg_brick_new("nop", config2, &error); + g_assert(!error); + east_brick2 = pg_brick_new("nop", config2, &error); + g_assert(!error); + + west_brick3 = pg_brick_new("nop", config3, &error); + g_assert(!error); + middle_brick3 = pg_brick_new("nop", config3, &error); + g_assert(!error); + east_brick3 = pg_brick_new("nop", config3, &error); + g_assert(!error); + /* create a few links */ pg_brick_link(west_brick, middle_brick, &error); g_assert(!error); @@ -652,48 +791,99 @@ static void test_brick_core_verify_multiple_link(void) g_assert(!error); pg_brick_link(middle_brick, east_brick, &error); g_assert(!error); + pg_brick_link(middle_brick1, east_brick1, &error); + g_assert(!error); + pg_brick_link(middle_brick2, east_brick2, &error); + g_assert(!error); + + pg_brick_link(middle_brick1, west_brick1, &error); + PG_ERROR_EXISTS(error); + + pg_brick_link(middle_brick2, west_brick2, &error); + PG_ERROR_EXISTS(error); + pg_brick_link(middle_brick3, west_brick3, &error); + PG_ERROR_EXISTS(error); + + pg_brick_link(west_brick3, middle_brick3, &error); + PG_ERROR_EXISTS(error); + /* sanity checks */ test_brick_sanity_check(west_brick); test_brick_sanity_check(middle_brick); test_brick_sanity_check(east_brick); - /* check the link count */ + /* check the link count */ + links_count = pg_brick_links_count_get(NULL, west_brick, &error); + g_assert(links_count == (uint32_t) -1); + g_assert(error->message); + g_assert_cmpstr(error->message, ==, "brick is NULL"); + PG_ERROR_EXISTS(error); + + links_count = pg_brick_links_count_get(middle_brick3, west_brick3, &error); + g_assert(links_count == (uint32_t)-1); + g_assert(error->message); + g_assert_cmpstr(error->message, ==, "brick config type is unknown"); + PG_ERROR_EXISTS(error); + + links_count = pg_brick_links_count_get(east_brick3, west_brick3, &error); + g_assert(links_count == (uint32_t)-1); + g_assert(error->message); + g_assert_cmpstr(error->message, ==, "brick config type is unknown"); + PG_ERROR_EXISTS(error); + links_count = pg_brick_links_count_get(west_brick, west_brick, &error); g_assert(!error); g_assert(links_count == 0); - links_count = pg_brick_links_count_get(west_brick, middle_brick, - &error); + + links_count = pg_brick_links_count_get(west_brick, middle_brick, &error); g_assert(!error); g_assert(links_count == 2); + links_count = pg_brick_links_count_get(west_brick, east_brick, &error); g_assert(!error); g_assert(links_count == 0); - links_count = pg_brick_links_count_get(middle_brick, middle_brick, - &error); + links_count = pg_brick_links_count_get(middle_brick, middle_brick, &error); g_assert(!error); g_assert(links_count == 0); - links_count = pg_brick_links_count_get(middle_brick, west_brick, - &error); + + links_count = pg_brick_links_count_get(middle_brick, west_brick, &error); g_assert(!error); g_assert(links_count == 2); - links_count = pg_brick_links_count_get(middle_brick, east_brick, - &error); + + links_count = pg_brick_links_count_get(middle_brick, east_brick, &error); g_assert(!error); g_assert(links_count == 3); links_count = pg_brick_links_count_get(east_brick, east_brick, &error); g_assert(!error); g_assert(links_count == 0); + links_count = pg_brick_links_count_get(east_brick, west_brick, &error); g_assert(!error); g_assert(links_count == 0); - links_count = pg_brick_links_count_get(east_brick, middle_brick, - &error); + + links_count = pg_brick_links_count_get(east_brick, middle_brick, &error); g_assert(!error); g_assert(links_count == 3); + links_count = pg_brick_links_count_get(middle_brick1,east_brick1, &error); + g_assert(!error); + g_assert(links_count == 1); + + links_count = pg_brick_links_count_get(middle_brick2, east_brick2, &error); + g_assert(!error); + g_assert(links_count == 1); + + links_count = pg_brick_links_count_get(west_brick2, middle_brick2, &error); + g_assert(!error); + g_assert(links_count == 0); + + links_count = pg_brick_links_count_get(east_brick1, east_brick1, &error); + g_assert(!error); + g_assert(links_count == 0); + /* unlink the west brick */ pg_brick_unlink(west_brick, &error); @@ -706,35 +896,36 @@ static void test_brick_core_verify_multiple_link(void) links_count = pg_brick_links_count_get(west_brick, west_brick, &error); g_assert(!error); g_assert(links_count == 0); - links_count = pg_brick_links_count_get(west_brick, middle_brick, - &error); + + links_count = pg_brick_links_count_get(west_brick, middle_brick, &error); g_assert(!error); g_assert(links_count == 0); + links_count = pg_brick_links_count_get(west_brick, east_brick, &error); g_assert(!error); g_assert(links_count == 0); - links_count = pg_brick_links_count_get(middle_brick, - middle_brick, &error); + links_count = pg_brick_links_count_get(middle_brick, middle_brick, &error); g_assert(!error); g_assert(links_count == 0); - links_count = pg_brick_links_count_get(middle_brick, - west_brick, &error); + + links_count = pg_brick_links_count_get(middle_brick, west_brick, &error); g_assert(!error); g_assert(links_count == 0); - links_count = pg_brick_links_count_get(middle_brick, - east_brick, &error); + + links_count = pg_brick_links_count_get(middle_brick, east_brick, &error); g_assert(!error); g_assert(links_count == 3); links_count = pg_brick_links_count_get(east_brick, east_brick, &error); g_assert(!error); g_assert(links_count == 0); + links_count = pg_brick_links_count_get(east_brick, west_brick, &error); g_assert(!error); g_assert(links_count == 0); - links_count = pg_brick_links_count_get(east_brick, - middle_brick, &error); + + links_count = pg_brick_links_count_get(east_brick, middle_brick, &error); g_assert(!error); g_assert(links_count == 3); @@ -784,15 +975,34 @@ static void test_brick_core_verify_multiple_link(void) g_assert(!error); g_assert(links_count == 0); - /* destroy */ - pg_brick_decref(west_brick, &error); + //destroy bricks + pg_brick_destroy(east_brick); + pg_brick_destroy(middle_brick); + pg_brick_destroy(west_brick); + + pg_brick_decref(east_brick1, &error); + g_assert(!error); + pg_brick_decref(middle_brick1, &error); + g_assert(!error); + pg_brick_decref(west_brick1, &error); + g_assert(!error); + pg_brick_decref(east_brick2, &error); g_assert(!error); - pg_brick_decref(middle_brick, &error); + pg_brick_decref(middle_brick2, &error); g_assert(!error); - pg_brick_decref(east_brick, &error); + pg_brick_decref(west_brick2, &error); + g_assert(!error); + pg_brick_decref(east_brick3, &error); + g_assert(!error); + pg_brick_decref(middle_brick3, &error); + g_assert(!error); + pg_brick_decref(west_brick3, &error); g_assert(!error); pg_brick_config_free(config); + pg_brick_config_free(config1); + pg_brick_config_free(config2); + pg_brick_config_free(config3); } static void test_brick_core_verify_re_link(void) @@ -821,6 +1031,9 @@ static void test_brick_core_verify_re_link(void) test_brick_sanity_check_expected(f, 1, 1); test_brick_sanity_check_expected(a, 1, 0); + pg_brick_chained_links(&e,v,NULL); + PG_ERROR_EXISTS(e); + /* Unlink f */ pg_brick_unlink(f, &e); g_assert(!e); @@ -828,6 +1041,9 @@ static void test_brick_core_verify_re_link(void) test_brick_sanity_check_expected(f, 0, 0); test_brick_sanity_check_expected(a, 0, 0); + pg_brick_unlink(NULL, &e); + PG_ERROR_EXISTS(e); + /* Link v and s */ pg_brick_link(v, s, &e); g_assert(!e); @@ -859,7 +1075,7 @@ static void test_brick_core_verify_re_link(void) static void test_brick_verify_re_link_monopole(void) { - struct pg_brick *west_brick, *east_brick; + pg_autobrick struct pg_brick *west_brick, *east_brick; struct pg_error *error = NULL; west_brick = pg_queue_new("q1", 1, &error); @@ -878,9 +1094,6 @@ static void test_brick_verify_re_link_monopole(void) /* We relink them to make sure unlink works */ pg_brick_link(west_brick, east_brick, &error); g_assert(!error); - - pg_brick_destroy(west_brick); - pg_brick_destroy(east_brick); } static void test_big_endian(void)