X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=tests%2Fovsdb-data.at;h=51d32e7317351517f127db3b9accf3bd1c150b08;hb=HEAD;hp=5ca23cf15ee049f76357748f1e220f28a3cdac15;hpb=02dd3123a0e312f1d33403e744af52dd6096f12d;p=sliver-openvswitch.git diff --git a/tests/ovsdb-data.at b/tests/ovsdb-data.at index 5ca23cf15..51d32e731 100644 --- a/tests/ovsdb-data.at +++ b/tests/ovsdb-data.at @@ -1,6 +1,79 @@ +AT_BANNER([OVSDB -- default values]) + +OVSDB_CHECK_POSITIVE_CPY([default atoms], + [default-atoms], + [[integer: OK +real: OK +boolean: OK +string: OK +uuid: OK]]) + +OVSDB_CHECK_POSITIVE_CPY([default data], + [default-data], + [[key integer, value void, n_min 0: OK +key integer, value integer, n_min 0: OK +key integer, value real, n_min 0: OK +key integer, value boolean, n_min 0: OK +key integer, value string, n_min 0: OK +key integer, value uuid, n_min 0: OK +key real, value void, n_min 0: OK +key real, value integer, n_min 0: OK +key real, value real, n_min 0: OK +key real, value boolean, n_min 0: OK +key real, value string, n_min 0: OK +key real, value uuid, n_min 0: OK +key boolean, value void, n_min 0: OK +key boolean, value integer, n_min 0: OK +key boolean, value real, n_min 0: OK +key boolean, value boolean, n_min 0: OK +key boolean, value string, n_min 0: OK +key boolean, value uuid, n_min 0: OK +key string, value void, n_min 0: OK +key string, value integer, n_min 0: OK +key string, value real, n_min 0: OK +key string, value boolean, n_min 0: OK +key string, value string, n_min 0: OK +key string, value uuid, n_min 0: OK +key uuid, value void, n_min 0: OK +key uuid, value integer, n_min 0: OK +key uuid, value real, n_min 0: OK +key uuid, value boolean, n_min 0: OK +key uuid, value string, n_min 0: OK +key uuid, value uuid, n_min 0: OK +key integer, value void, n_min 1: OK +key integer, value integer, n_min 1: OK +key integer, value real, n_min 1: OK +key integer, value boolean, n_min 1: OK +key integer, value string, n_min 1: OK +key integer, value uuid, n_min 1: OK +key real, value void, n_min 1: OK +key real, value integer, n_min 1: OK +key real, value real, n_min 1: OK +key real, value boolean, n_min 1: OK +key real, value string, n_min 1: OK +key real, value uuid, n_min 1: OK +key boolean, value void, n_min 1: OK +key boolean, value integer, n_min 1: OK +key boolean, value real, n_min 1: OK +key boolean, value boolean, n_min 1: OK +key boolean, value string, n_min 1: OK +key boolean, value uuid, n_min 1: OK +key string, value void, n_min 1: OK +key string, value integer, n_min 1: OK +key string, value real, n_min 1: OK +key string, value boolean, n_min 1: OK +key string, value string, n_min 1: OK +key string, value uuid, n_min 1: OK +key uuid, value void, n_min 1: OK +key uuid, value integer, n_min 1: OK +key uuid, value real, n_min 1: OK +key uuid, value boolean, n_min 1: OK +key uuid, value string, n_min 1: OK +key uuid, value uuid, n_min 1: OK]]) + AT_BANNER([OVSDB -- atoms without constraints]) -OVSDB_CHECK_POSITIVE([integer atom from JSON], +OVSDB_CHECK_POSITIVE_CPY([integer atom from JSON], [[parse-atoms '["integer"]' \ '[0]' \ '[-1]' \ @@ -26,7 +99,7 @@ OVSDB_CHECK_POSITIVE([integer atom from string], 9223372036854775807 -9223372036854775808]) -OVSDB_CHECK_POSITIVE([real atom from JSON], +OVSDB_CHECK_POSITIVE_CPY([real atom from JSON], [[parse-atoms '["real"]' \ '[0]' \ '[0.0]' \ @@ -60,7 +133,7 @@ OVSDB_CHECK_POSITIVE([real atom from string], 1e+37 0.00390625]) -OVSDB_CHECK_POSITIVE([boolean atom from JSON], +OVSDB_CHECK_POSITIVE_CPY([boolean atom from JSON], [[parse-atoms '["boolean"]' '[true]' '[false]' ]], [true false]) @@ -70,7 +143,7 @@ OVSDB_CHECK_POSITIVE([boolean atom from string], [true false]) -OVSDB_CHECK_POSITIVE([string atom from JSON], +OVSDB_CHECK_POSITIVE_CPY([string atom from JSON], [[parse-atoms '["string"]' '[""]' '["true"]' '["\"\\\/\b\f\n\r\t"]']], ["" "true" @@ -91,7 +164,7 @@ quoted-string "true" "\"\\/\b\f\n\r\t"]) -OVSDB_CHECK_POSITIVE([uuid atom from JSON], +OVSDB_CHECK_POSITIVE_CPY([uuid atom from JSON], [[parse-atoms '["uuid"]' '["uuid", "550e8400-e29b-41d4-a716-446655440000"]']], [[["uuid","550e8400-e29b-41d4-a716-446655440000"]]]) @@ -99,23 +172,23 @@ OVSDB_CHECK_POSITIVE([uuid atom from string], [[parse-atom-strings '["uuid"]' '550e8400-e29b-41d4-a716-446655440000']], [550e8400-e29b-41d4-a716-446655440000]) -OVSDB_CHECK_POSITIVE([integer atom sorting], +OVSDB_CHECK_POSITIVE_CPY([integer atom sorting], [[sort-atoms '["integer"]' '[55,0,-1,2,1]']], [[[-1,0,1,2,55]]]) -OVSDB_CHECK_POSITIVE([real atom sorting], +OVSDB_CHECK_POSITIVE_CPY([real atom sorting], [[sort-atoms '["real"]' '[1.25,1.23,0.0,-0.0,-1e99]']], [[[-1e+99,0,0,1.23,1.25]]]) -OVSDB_CHECK_POSITIVE([boolean atom sorting], +OVSDB_CHECK_POSITIVE_CPY([boolean atom sorting], [[sort-atoms '["boolean"]' '[true,false,true,false,false]']], [[[false,false,false,true,true]]]) -OVSDB_CHECK_POSITIVE([string atom sorting], +OVSDB_CHECK_POSITIVE_CPY([string atom sorting], [[sort-atoms '["string"]' '["abd","abc","\b","xxx"]']], [[["\b","abc","abd","xxx"]]]) -OVSDB_CHECK_POSITIVE([uuid atom sorting], +OVSDB_CHECK_POSITIVE_CPY([uuid atom sorting], [[sort-atoms '["uuid"]' '[ ["uuid", "00000000-0000-0000-0000-000000000001"], ["uuid", "00000000-1000-0000-0000-000000000000"], @@ -152,7 +225,7 @@ OVSDB_CHECK_POSITIVE([uuid atom sorting], ["uuid", "00001000-0000-0000-0000-000000000000"]]']], [[[["uuid","00000000-0000-0000-0000-000000000000"],["uuid","00000000-0000-0000-0000-000000000001"],["uuid","00000000-0000-0000-0000-000000000010"],["uuid","00000000-0000-0000-0000-000000000100"],["uuid","00000000-0000-0000-0000-000000001000"],["uuid","00000000-0000-0000-0000-000000010000"],["uuid","00000000-0000-0000-0000-000000100000"],["uuid","00000000-0000-0000-0000-000001000000"],["uuid","00000000-0000-0000-0000-000010000000"],["uuid","00000000-0000-0000-0000-000100000000"],["uuid","00000000-0000-0000-0000-001000000000"],["uuid","00000000-0000-0000-0000-010000000000"],["uuid","00000000-0000-0000-0000-100000000000"],["uuid","00000000-0000-0000-0001-000000000000"],["uuid","00000000-0000-0000-0010-000000000000"],["uuid","00000000-0000-0000-0100-000000000000"],["uuid","00000000-0000-0000-1000-000000000000"],["uuid","00000000-0000-0001-0000-000000000000"],["uuid","00000000-0000-0010-0000-000000000000"],["uuid","00000000-0000-0100-0000-000000000000"],["uuid","00000000-0000-1000-0000-000000000000"],["uuid","00000000-0001-0000-0000-000000000000"],["uuid","00000000-0010-0000-0000-000000000000"],["uuid","00000000-0100-0000-0000-000000000000"],["uuid","00000000-1000-0000-0000-000000000000"],["uuid","00000001-0000-0000-0000-000000000000"],["uuid","00000010-0000-0000-0000-000000000000"],["uuid","00000100-0000-0000-0000-000000000000"],["uuid","00001000-0000-0000-0000-000000000000"],["uuid","00010000-0000-0000-0000-000000000000"],["uuid","00100000-0000-0000-0000-000000000000"],["uuid","01000000-0000-0000-0000-000000000000"],["uuid","10000000-0000-0000-0000-000000000000"]]]]) -OVSDB_CHECK_POSITIVE([real not acceptable integer JSON atom], +OVSDB_CHECK_POSITIVE_CPY([real not acceptable integer JSON atom], [[parse-atoms '["integer"]' '[0.5]' ]], [syntax "0.5": syntax error: expected integer]) @@ -160,17 +233,32 @@ dnl is not allowed anywhere in a UTF-8 string. dnl is a surrogate and not allowed in UTF-8. OVSDB_CHECK_POSITIVE([no invalid UTF-8 sequences in strings], [parse-atoms '[["string"]]' \ - '@<:@"m4_esyscmd([printf "\xc0"])"@:>@' \ - '@<:@"m4_esyscmd([printf "\xed\xa0\x80"])"@:>@' \ + '@<:@"m4_esyscmd([printf "\300"])"@:>@' \ + '@<:@"m4_esyscmd([printf "\355\240\200"])"@:>@' \ +], + [constraint violation: not a valid UTF-8 string: invalid UTF-8 sequence 0xc0 +constraint violation: not a valid UTF-8 string: invalid UTF-8 sequence 0xed 0xa0]) + +dnl Python won't let invalid UTF-8 (its idea of invalid UTF-8, anyway) into it +dnl at all, so this test never gets as far as a constraint violation. It's +dnl just a JSON parse error. +dnl +dnl is not allowed anywhere in a UTF-8 string. +dnl ( is not allowed in UTF-8 but Python doesn't care.) +dnl is not allowed in UTF-8. +OVSDB_CHECK_POSITIVE_PY([no invalid UTF-8 sequences in strings - Python], + [parse-atoms '[["string"]]' \ + '@<:@"m4_esyscmd([printf "\300"])"@:>@' \ + '@<:@"m4_esyscmd([printf "\355\200\177"])"@:>@' \ ], - [constraint violation: "m4_esyscmd([printf "\xc0"])" is not a valid UTF-8 string: invalid UTF-8 sequence 0xc0 -constraint violation: "m4_esyscmd([printf "\xed\xa0\x80"])" is not a valid UTF-8 string: invalid UTF-8 sequence 0xed 0xa0]) + ["not a valid UTF-8 string: invalid UTF-8 sequence 0xc0" +"not a valid UTF-8 string: invalid UTF-8 sequence 0xed 0x80"]) OVSDB_CHECK_NEGATIVE([real not acceptable integer string atom], [[parse-atom-strings '["integer"]' '0.5' ]], ["0.5" is not a valid integer]) -OVSDB_CHECK_POSITIVE([string "true" not acceptable boolean JSON atom], +OVSDB_CHECK_POSITIVE_CPY([string "true" not acceptable boolean JSON atom], [[parse-atoms '["boolean"]' '["true"]' ]], [syntax ""true"": syntax error: expected boolean]) @@ -178,14 +266,18 @@ OVSDB_CHECK_NEGATIVE([string "true" not acceptable boolean string atom], [[parse-atom-strings '["boolean"]' '"true"' ]], [""true"" is not a valid boolean (use "true" or "false")]) -OVSDB_CHECK_POSITIVE([integer not acceptable string JSON atom], +OVSDB_CHECK_POSITIVE_CPY([integer not acceptable string JSON atom], [[parse-atoms '["string"]' '[1]']], [syntax "1": syntax error: expected string]) -OVSDB_CHECK_POSITIVE([uuid atom must be expressed as JSON array], +OVSDB_CHECK_POSITIVE_CPY([uuid atom must be expressed as JSON array], [[parse-atoms '["uuid"]' '["550e8400-e29b-41d4-a716-446655440000"]']], [[syntax ""550e8400-e29b-41d4-a716-446655440000"": syntax error: expected ["uuid", ]]]) +OVSDB_CHECK_POSITIVE_CPY([named-uuid requires symbol table], + [parse-atoms '[["uuid"]]' '[["named-uuid", "x"]]'], + [[syntax "["named-uuid","x"]": syntax error: expected ["uuid", ]]]) + OVSDB_CHECK_NEGATIVE([empty string atom must be quoted], [[parse-atom-strings '["string"]' '']], [An empty string is not valid as input; use "" to represent the empty string]) @@ -198,9 +290,82 @@ OVSDB_CHECK_NEGATIVE([uuids must be valid], [parse-atom-strings '[["uuid"]]' '1234-5678'], ["1234-5678" is not a valid UUID]) -AT_BANNER([OVSDB -- atoms with constraints]) +AT_BANNER([OVSDB -- atoms with enum constraints]) + +OVSDB_CHECK_POSITIVE_CPY([integer atom enum], + [[parse-atoms '[{"type": "integer", "enum": ["set", [1, 6, 8, 10]]}]' \ + '[0]' \ + '[1]' \ + '[2]' \ + '[3]' \ + '[6]' \ + '[7]' \ + '[8]' \ + '[9]' \ + '[10]' \ + '[11]']], + [[constraint violation: 0 is not one of the allowed values ([1, 6, 8, 10]) +1 +constraint violation: 2 is not one of the allowed values ([1, 6, 8, 10]) +constraint violation: 3 is not one of the allowed values ([1, 6, 8, 10]) +6 +constraint violation: 7 is not one of the allowed values ([1, 6, 8, 10]) +8 +constraint violation: 9 is not one of the allowed values ([1, 6, 8, 10]) +10 +constraint violation: 11 is not one of the allowed values ([1, 6, 8, 10])]]) -OVSDB_CHECK_POSITIVE([integers >= 5], +OVSDB_CHECK_POSITIVE_CPY([real atom enum], + [[parse-atoms '[{"type": "real", "enum": ["set", [-1.5, 1.5]]}]' \ + '[-2]' \ + '[-1]' \ + '[-1.5]' \ + '[0]' \ + '[1]' \ + '[1.5]' \ + '[2]']], + [[constraint violation: -2 is not one of the allowed values ([-1.5, 1.5]) +constraint violation: -1 is not one of the allowed values ([-1.5, 1.5]) +-1.5 +constraint violation: 0 is not one of the allowed values ([-1.5, 1.5]) +constraint violation: 1 is not one of the allowed values ([-1.5, 1.5]) +1.5 +constraint violation: 2 is not one of the allowed values ([-1.5, 1.5])]]) + +OVSDB_CHECK_POSITIVE_CPY([boolean atom enum], + [[parse-atoms '[{"type": "boolean", "enum": false}]' \ + '[false]' \ + '[true]']], + [[false +constraint violation: true is not one of the allowed values ([false])]]) + +OVSDB_CHECK_POSITIVE_CPY([string atom enum], + [[parse-atoms '[{"type": "string", "enum": ["set", ["abc", "def"]]}]' \ + '[""]' \ + '["ab"]' \ + '["abc"]' \ + '["def"]' \ + '["defg"]' \ + '["DEF"]']], + [[constraint violation: "" is not one of the allowed values ([abc, def]) +constraint violation: ab is not one of the allowed values ([abc, def]) +"abc" +"def" +constraint violation: defg is not one of the allowed values ([abc, def]) +constraint violation: DEF is not one of the allowed values ([abc, def])]]) + +OVSDB_CHECK_POSITIVE_CPY([uuid atom enum], + [[parse-atoms '[{"type": "uuid", "enum": ["set", [["uuid", "6d53a6dd-2da7-4924-9927-97f613812382"], ["uuid", "52cbc842-137a-4db5-804f-9f34106a0ba3"]]]}]' \ + '["uuid", "6d53a6dd-2da7-4924-9927-97f613812382"]' \ + '["uuid", "52cbc842-137a-4db5-804f-9f34106a0ba3"]' \ + '["uuid", "dab2a6b2-6094-4f43-a7ef-4c0f0608f176"]']], + [[["uuid","6d53a6dd-2da7-4924-9927-97f613812382"] +["uuid","52cbc842-137a-4db5-804f-9f34106a0ba3"] +constraint violation: dab2a6b2-6094-4f43-a7ef-4c0f0608f176 is not one of the allowed values ([52cbc842-137a-4db5-804f-9f34106a0ba3, 6d53a6dd-2da7-4924-9927-97f613812382])]]) + +AT_BANNER([OVSDB -- atoms with other constraints]) + +OVSDB_CHECK_POSITIVE_CPY([integers >= 5], [[parse-atoms '[{"type": "integer", "minInteger": 5}]' \ '[0]' \ '[4]' \ @@ -213,7 +378,7 @@ constraint violation: 4 is less than minimum allowed value 5 6 12345]) -OVSDB_CHECK_POSITIVE([integers <= -1], +OVSDB_CHECK_POSITIVE_CPY([integers <= -1], [[parse-atoms '[{"type": "integer", "maxInteger": -1}]' \ '[0]' \ '[-1]' \ @@ -224,7 +389,7 @@ OVSDB_CHECK_POSITIVE([integers <= -1], -2 -123]) -OVSDB_CHECK_POSITIVE([integers in range -10 to 10], +OVSDB_CHECK_POSITIVE_CPY([integers in range -10 to 10], [[parse-atoms '[{"type": "integer", "minInteger": -10, "maxInteger": 10}]' \ '[-20]' \ '[-11]' \ @@ -245,7 +410,7 @@ constraint violation: -11 is not in the valid range -10 to 10 (inclusive) constraint violation: 11 is not in the valid range -10 to 10 (inclusive) constraint violation: 123576 is not in the valid range -10 to 10 (inclusive)]) -OVSDB_CHECK_POSITIVE([reals >= 5], +OVSDB_CHECK_POSITIVE_CPY([reals >= 5], [[parse-atoms '[{"type": "real", "minReal": 5}]' \ '[0]' \ '[4]' \ @@ -258,7 +423,7 @@ constraint violation: 4 is less than minimum allowed value 5 6 12345]) -OVSDB_CHECK_POSITIVE([reals <= -1], +OVSDB_CHECK_POSITIVE_CPY([reals <= -1], [[parse-atoms '[{"type": "real", "maxReal": -1}]' \ '[0]' \ '[-1]' \ @@ -269,7 +434,7 @@ OVSDB_CHECK_POSITIVE([reals <= -1], -2 -123]) -OVSDB_CHECK_POSITIVE([reals in range -10 to 10], +OVSDB_CHECK_POSITIVE_CPY([reals in range -10 to 10], [[parse-atoms '[{"type": "real", "minReal": -10, "maxReal": 10}]' \ '[-20]' \ '[-11]' \ @@ -290,38 +455,7 @@ constraint violation: -11 is not in the valid range -10 to 10 (inclusive) constraint violation: 11 is not in the valid range -10 to 10 (inclusive) constraint violation: 123576 is not in the valid range -10 to 10 (inclusive)]) -AT_SETUP([strings matching /(a(b)?)c?/]) -AT_KEYWORDS([ovsdb positive]) -if test "$HAVE_PCRE" = yes; then - b_out='constraint violation: "b" does not match regular expression /(a(b)?)?c?/' - bc_out='constraint violation: "bc" does not match regular expression /(a(b)?)?c?/' -else - b_out='"b"' - bc_out='"bc"' -fi -AT_CHECK_UNQUOTED( - [[test-ovsdb parse-atoms '{"type": "string", "reMatch": "(a(b)?)?c?"}' \ - '[""]' \ - '["a"]' \ - '["ab"]' \ - '["abc"]' \ - '["ac"]' \ - '["b"]' \ - '["bc"]' \ - '["c"]']], - [0], - [["" -"a" -"ab" -"abc" -"ac" -$b_out -$bc_out -"c" -]]) -AT_CLEANUP - -OVSDB_CHECK_POSITIVE([strings at least 2 characters long], +OVSDB_CHECK_POSITIVE_CPY([strings at least 2 characters long], [[parse-atoms '{"type": "string", "minLength": 2}' \ '[""]' \ '["a"]' \ @@ -332,24 +466,29 @@ OVSDB_CHECK_POSITIVE([strings at least 2 characters long], constraint violation: "a" length 1 is less than minimum allowed length 2 "ab" "abc" -constraint violation: "𝄞" length 1 is less than minimum allowed length 2]]) - -OVSDB_CHECK_POSITIVE([strings no more than 2 characters long], +constraint violation: "𝄞" length 1 is less than minimum allowed length 2]], + [], + [], + [dnl This test requires a wide build of Python. + AT_CHECK([$PYTHON -c 'unichr(0x10000)' || exit 77], + [0], [ignore], [ignore])]) + +OVSDB_CHECK_POSITIVE_CPY([strings no more than 2 characters long], [[parse-atoms '{"type": "string", "maxLength": 2}' \ '[""]' \ '["a"]' \ '["ab"]' \ '["abc"]' \ - '["\ud834\udd1e"]']], + '["de"]']], [["" "a" "ab" constraint violation: "abc" length 3 is greater than maximum allowed length 2 -"𝄞"]]) +"de"]]) AT_BANNER([OSVDB -- simple data]) -OVSDB_CHECK_POSITIVE([integer JSON datum], +OVSDB_CHECK_POSITIVE_CPY([integer JSON datum], [[parse-data '["integer"]' '[0]' '["set",[1]]' '[-1]']], [0 1 @@ -362,7 +501,7 @@ OVSDB_CHECK_POSITIVE([integer string datum], -1 1]) -OVSDB_CHECK_POSITIVE([real JSON datum], +OVSDB_CHECK_POSITIVE_CPY([real JSON datum], [[parse-data '["real"]' '[0]' '["set",[1.0]]' '[-1.25]']], [0 1 @@ -374,7 +513,7 @@ OVSDB_CHECK_POSITIVE([real string datum], 1 -1.25]) -OVSDB_CHECK_POSITIVE([boolean JSON datum], +OVSDB_CHECK_POSITIVE_CPY([boolean JSON datum], [[parse-data '["boolean"]' '["set", [true]]' '[false]' ]], [true false]) @@ -384,7 +523,7 @@ OVSDB_CHECK_POSITIVE([boolean string datum], [true false]) -OVSDB_CHECK_POSITIVE([string JSON datum], +OVSDB_CHECK_POSITIVE_CPY([string JSON datum], [[parse-data '["string"]' '["set",[""]]' '["true"]' '["\"\\\/\b\f\n\r\t"]']], ["" "true" @@ -399,7 +538,7 @@ OVSDB_CHECK_POSITIVE([string string datum], AT_BANNER([OVSDB -- set data]) -OVSDB_CHECK_POSITIVE([JSON optional boolean], +OVSDB_CHECK_POSITIVE_CPY([JSON optional boolean], [[parse-data '{"key": "boolean", "min": 0}' \ '[true]' \ '["set", [false]]' \ @@ -419,7 +558,7 @@ false []]], [set]) -OVSDB_CHECK_POSITIVE([JSON set of 0 or more integers], +OVSDB_CHECK_POSITIVE_CPY([JSON set of 0 or more integers], [[parse-data '{"key": "integer", "min": 0, "max": "unlimited"}' \ '["set", [0]]' \ '[1]' \ @@ -451,7 +590,7 @@ OVSDB_CHECK_POSITIVE([string set of 0 or more integers], [0, 1, 2, 3, 4, 5, 6, 7, 8] [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]]]) -OVSDB_CHECK_POSITIVE([JSON set of 1 to 3 uuids], +OVSDB_CHECK_POSITIVE_CPY([JSON set of 1 to 3 uuids], [[parse-data '{"key": "uuid", "min": 1, "max": 3}' \ '["set", [["uuid", "550e8400-e29b-41d4-a716-446655440000"]]]' \ '["uuid", "b5078be0-7664-4299-b836-8bcc03ef941f"]' \ @@ -471,7 +610,7 @@ OVSDB_CHECK_POSITIVE([string set of 1 to 3 uuids], [[[550e8400-e29b-41d4-a716-446655440000] [550e8400-e29b-41d4-a716-446655440000, 90558331-09af-4d2f-a572-509cad2e9088, c5051240-30ff-43ed-b4b9-93cf3f050813]]]) -OVSDB_CHECK_POSITIVE([JSON set of 0 to 3 strings], +OVSDB_CHECK_POSITIVE_CPY([JSON set of 0 to 3 strings], [[parse-data '{"key": "string", "min": 0, "max": 3}' \ '["set", []]' \ '["a longer string"]' \ @@ -495,7 +634,7 @@ OVSDB_CHECK_POSITIVE([string set of 0 to 3 strings], ["a relatively long string", "short string"] ["a relatively long string", "short string", zzz]]]) -OVSDB_CHECK_NEGATIVE([duplicate boolean not allowed in JSON set], +OVSDB_CHECK_NEGATIVE_CPY([duplicate boolean not allowed in JSON set], [[parse-data '{"key": "boolean", "max": 5}' '["set", [true, true]]']], [ovsdb error: set contains duplicate]) @@ -503,7 +642,7 @@ OVSDB_CHECK_NEGATIVE([duplicate boolean not allowed in string set], [[parse-data-strings '{"key": "boolean", "max": 5}' 'true, true']], [set contains duplicate value]) -OVSDB_CHECK_NEGATIVE([duplicate integer not allowed in JSON set], +OVSDB_CHECK_NEGATIVE_CPY([duplicate integer not allowed in JSON set], [[parse-data '{"key": "integer", "max": 5}' '["set", [1, 2, 3, 1]]']], [ovsdb error: set contains duplicate]) @@ -511,7 +650,7 @@ OVSDB_CHECK_NEGATIVE([duplicate integer not allowed in string set], [[parse-data-strings '{"key": "integer", "max": 5}' '[1, 2, 3, 1]']], [set contains duplicate value]) -OVSDB_CHECK_NEGATIVE([duplicate real not allowed in JSON set], +OVSDB_CHECK_NEGATIVE_CPY([duplicate real not allowed in JSON set], [[parse-data '{"key": "real", "max": 5}' '["set", [0.0, -0.0]]']], [ovsdb error: set contains duplicate]) @@ -519,7 +658,7 @@ OVSDB_CHECK_NEGATIVE([duplicate real not allowed in string set], [[parse-data-strings '{"key": "real", "max": 5}' '0.0, -0.0']], [set contains duplicate value]) -OVSDB_CHECK_NEGATIVE([duplicate string not allowed in JSON set], +OVSDB_CHECK_NEGATIVE_CPY([duplicate string not allowed in JSON set], [[parse-data '{"key": "string", "max": 5}' '["set", ["asdf", "ASDF", "asdf"]]']], [ovsdb error: set contains duplicate]) @@ -527,7 +666,7 @@ OVSDB_CHECK_NEGATIVE([duplicate string not allowed in string set], [[parse-data-strings '{"key": "string", "max": 5}' 'asdf, ASDF, "asdf"']], [set contains duplicate value]) -OVSDB_CHECK_NEGATIVE([duplicate uuid not allowed in JSON set], +OVSDB_CHECK_NEGATIVE_CPY([duplicate uuid not allowed in JSON set], [[parse-data '{"key": "uuid", "max": 5}' \ '["set", [["uuid", "7ef21525-0088-4a28-a418-5518413e43ea"], ["uuid", "355ad037-f1da-40aa-b47c-ff9c7e8c6a38"], @@ -543,7 +682,7 @@ OVSDB_CHECK_NEGATIVE([duplicate uuid not allowed in string set], AT_BANNER([OVSDB -- map data]) -OVSDB_CHECK_POSITIVE([JSON map of 1 integer to boolean], +OVSDB_CHECK_POSITIVE_CPY([JSON map of 1 integer to boolean], [[parse-data '{"key": "integer", "value": "boolean"}' \ '["map", [[1, true]]]']], [[["map",[[1,true]]]]]) @@ -553,7 +692,7 @@ OVSDB_CHECK_POSITIVE([string map of 1 integer to boolean], '1=true']], [[1=true]]) -OVSDB_CHECK_POSITIVE([JSON map of at least 1 integer to boolean], +OVSDB_CHECK_POSITIVE_CPY([JSON map of at least 1 integer to boolean], [[parse-data '{"key": "integer", "value": "boolean", "max": "unlimited"}' \ '["map", [[1, true]]]' \ '["map", [[0, true], [1, false], [2, true], [3, true], [4, true]]]' \ @@ -571,7 +710,7 @@ OVSDB_CHECK_POSITIVE([string map of at least 1 integer to boolean], {0=true, 1=false, 2=true, 3=true, 4=true} {0=true, 3=false, 4=false}]]) -OVSDB_CHECK_POSITIVE([JSON map of 1 boolean to integer], +OVSDB_CHECK_POSITIVE_CPY([JSON map of 1 boolean to integer], [[parse-data '{"key": "boolean", "value": "integer"}' \ '["map", [[true, 1]]]']], [[["map",[[true,1]]]]]) @@ -581,7 +720,7 @@ OVSDB_CHECK_POSITIVE([string map of 1 boolean to integer], 'true=1']], [[true=1]]) -OVSDB_CHECK_POSITIVE([JSON map of 1 uuid to real], +OVSDB_CHECK_POSITIVE_CPY([JSON map of 1 uuid to real], [[parse-data '{"key": "uuid", "value": "real", "min": 1, "max": 5}' \ '["map", [[["uuid", "cad8542b-6ee1-486b-971b-7dcbf6e14979"], 1.0], [["uuid", "6b94b968-2702-4f64-9457-314a34d69b8c"], 2.0], @@ -599,7 +738,7 @@ OVSDB_CHECK_POSITIVE([string map of 1 uuid to real], 1c92b8ca-d5e4-4628-a85d-1dc2d099a99a=5.0']], [[{1c92b8ca-d5e4-4628-a85d-1dc2d099a99a=5, 25bfa475-d072-4f60-8be1-00f48643e9cb=4, 6b94b968-2702-4f64-9457-314a34d69b8c=2, cad8542b-6ee1-486b-971b-7dcbf6e14979=1, d2c4a168-24de-47eb-a8a3-c1abfc814979=3}]]) -OVSDB_CHECK_POSITIVE([JSON map of 10 string to string], +OVSDB_CHECK_POSITIVE_CPY([JSON map of 10 string to string], [[parse-data '{"key": "string", "value": "string", "min": 1, "max": 10}' \ '["map", [["2 gills", "1 chopin"], ["2 chopins", "1 pint"], @@ -627,7 +766,7 @@ OVSDB_CHECK_POSITIVE([string map of 10 string to string], "2 kilderkins"= "1 barrel"}']], [[{"2 chopins"="1 pint", "2 demibushel"="1 firkin", "2 firkins"="1 kilderkin", "2 gallons"="1 peck", "2 gills"="1 chopin", "2 kilderkins"="1 barrel", "2 pecks"="1 demibushel", "2 pints"="1 quart", "2 pottles"="1 gallon", "2 quarts"="1 pottle"}]]) -OVSDB_CHECK_NEGATIVE([duplicate integer key not allowed in JSON map], +OVSDB_CHECK_NEGATIVE_CPY([duplicate integer key not allowed in JSON map], [[parse-data '{"key": "integer", "value": "boolean", "max": 5}' \ '["map", [[1, true], [2, false], [1, false]]]']], [ovsdb error: map contains duplicate key])