From: Florian Westphal Date: Thu, 14 Dec 2023 16:47:21 +0000 (+0100) Subject: Revert "evaluate: error out when existing set has incompatible key" X-Git-Tag: v1.1.0~155 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=21657008dd4b4094eac017a175f2a3056af36b17;p=thirdparty%2Fnftables.git Revert "evaluate: error out when existing set has incompatible key" This breaks existing behaviour, add a test case so this is caught in the future. The reverted test case will be brought back once a better fix is available. Signed-off-by: Florian Westphal --- diff --git a/src/evaluate.c b/src/evaluate.c index 0e0e0c00b..70d80eb48 100644 --- a/src/evaluate.c +++ b/src/evaluate.c @@ -4768,9 +4768,6 @@ static int set_evaluate(struct eval_ctx *ctx, struct set *set) existing_set = set_cache_find(table, set->handle.set.name); if (!existing_set) set_cache_add(set_get(set), table); - else if (!datatype_equal(existing_set->key->dtype, set->key->dtype)) - return set_error(ctx, set, "%s definition has conflicting key (%s vs %s)\n", - type, set->key->dtype->name, existing_set->key->dtype->name); if (existing_set && existing_set->flags & NFT_SET_EVAL) { uint32_t existing_flags = existing_set->flags & ~NFT_SET_EVAL; diff --git a/tests/shell/testcases/bogons/nft-f/range_expr_value_high_assert b/tests/shell/testcases/bogons/nft-f/range_expr_value_high_assert deleted file mode 100644 index a25ac028b..000000000 --- a/tests/shell/testcases/bogons/nft-f/range_expr_value_high_assert +++ /dev/null @@ -1,12 +0,0 @@ -table inet t { - set s3 { - type inet_proto - flags interval - elements = { 100-11.0.0.0, } - } - set s3 { - type ipv4_addr - flags interval - elements = { 100-11.0.0.0, } - } -} diff --git a/tests/shell/testcases/transactions/doubled-set b/tests/shell/testcases/transactions/doubled-set new file mode 100755 index 000000000..50b568ebd --- /dev/null +++ b/tests/shell/testcases/transactions/doubled-set @@ -0,0 +1,22 @@ +#!/bin/bash + +# NFT_TEST_REQUIRES(NFT_TEST_HAVE_pipapo) + +$NFT -f /dev/stdin <