Browse Source
2862b56
[tests] remove redundant univalue_tests.cpp (John Newbery)
Pull request description:
univalue unit tests were added in #4730 , and exist at `/src/test/univalue_tests.cpp` (outside the univalue tree). That test was brought into the univalue repository in https://github.com/bitcoin-core/univalue/pull/4 , which was pulled into the github repository in https://github.com/bitcoin/bitcoin/pull/11420.
That means that the univalue test exists in two places:
1. `/src/test/univalue_tests.cpp`
2. `/src/univalue/test/object.cpp`
(2) is a strict superset of (1). It adds some macros to work around boost not being a univalue dependency, and adds a few extra lines of test.
Therefore remove `/src/test/univalue_tests.cpp`
Tree-SHA512: 3747b10bbf62e9f12363905488b29945ad559ddca68c5c03d8a362de612a51f408f41a04d3712c6889bfc1632fb1a5fa0d7df0fbf02c322b3981a6d698f501b0
0.16
Wladimir J. van der Laan
7 years ago
2 changed files with 0 additions and 334 deletions
@ -1,333 +0,0 @@
@@ -1,333 +0,0 @@
|
||||
// Copyright (c) 2014 BitPay Inc.
|
||||
// Copyright (c) 2014-2016 The Bitcoin Core developers
|
||||
// Distributed under the MIT software license, see the accompanying
|
||||
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
||||
|
||||
#include <stdint.h> |
||||
#include <vector> |
||||
#include <string> |
||||
#include <map> |
||||
#include <univalue.h> |
||||
#include <test/test_bitcoin.h> |
||||
|
||||
#include <boost/test/unit_test.hpp> |
||||
|
||||
BOOST_FIXTURE_TEST_SUITE(univalue_tests, BasicTestingSetup) |
||||
|
||||
BOOST_AUTO_TEST_CASE(univalue_constructor) |
||||
{ |
||||
UniValue v1; |
||||
BOOST_CHECK(v1.isNull()); |
||||
|
||||
UniValue v2(UniValue::VSTR); |
||||
BOOST_CHECK(v2.isStr()); |
||||
|
||||
UniValue v3(UniValue::VSTR, "foo"); |
||||
BOOST_CHECK(v3.isStr()); |
||||
BOOST_CHECK_EQUAL(v3.getValStr(), "foo"); |
||||
|
||||
UniValue numTest; |
||||
BOOST_CHECK(numTest.setNumStr("82")); |
||||
BOOST_CHECK(numTest.isNum()); |
||||
BOOST_CHECK_EQUAL(numTest.getValStr(), "82"); |
||||
|
||||
uint64_t vu64 = 82; |
||||
UniValue v4(vu64); |
||||
BOOST_CHECK(v4.isNum()); |
||||
BOOST_CHECK_EQUAL(v4.getValStr(), "82"); |
||||
|
||||
int64_t vi64 = -82; |
||||
UniValue v5(vi64); |
||||
BOOST_CHECK(v5.isNum()); |
||||
BOOST_CHECK_EQUAL(v5.getValStr(), "-82"); |
||||
|
||||
int vi = -688; |
||||
UniValue v6(vi); |
||||
BOOST_CHECK(v6.isNum()); |
||||
BOOST_CHECK_EQUAL(v6.getValStr(), "-688"); |
||||
|
||||
double vd = -7.21; |
||||
UniValue v7(vd); |
||||
BOOST_CHECK(v7.isNum()); |
||||
BOOST_CHECK_EQUAL(v7.getValStr(), "-7.21"); |
||||
|
||||
std::string vs("yawn"); |
||||
UniValue v8(vs); |
||||
BOOST_CHECK(v8.isStr()); |
||||
BOOST_CHECK_EQUAL(v8.getValStr(), "yawn"); |
||||
|
||||
const char *vcs = "zappa"; |
||||
UniValue v9(vcs); |
||||
BOOST_CHECK(v9.isStr()); |
||||
BOOST_CHECK_EQUAL(v9.getValStr(), "zappa"); |
||||
} |
||||
|
||||
BOOST_AUTO_TEST_CASE(univalue_typecheck) |
||||
{ |
||||
UniValue v1; |
||||
BOOST_CHECK(v1.setNumStr("1")); |
||||
BOOST_CHECK(v1.isNum()); |
||||
BOOST_CHECK_THROW(v1.get_bool(), std::runtime_error); |
||||
|
||||
UniValue v2; |
||||
BOOST_CHECK(v2.setBool(true)); |
||||
BOOST_CHECK_EQUAL(v2.get_bool(), true); |
||||
BOOST_CHECK_THROW(v2.get_int(), std::runtime_error); |
||||
|
||||
UniValue v3; |
||||
BOOST_CHECK(v3.setNumStr("32482348723847471234")); |
||||
BOOST_CHECK_THROW(v3.get_int64(), std::runtime_error); |
||||
BOOST_CHECK(v3.setNumStr("1000")); |
||||
BOOST_CHECK_EQUAL(v3.get_int64(), 1000); |
||||
|
||||
UniValue v4; |
||||
BOOST_CHECK(v4.setNumStr("2147483648")); |
||||
BOOST_CHECK_EQUAL(v4.get_int64(), 2147483648); |
||||
BOOST_CHECK_THROW(v4.get_int(), std::runtime_error); |
||||
BOOST_CHECK(v4.setNumStr("1000")); |
||||
BOOST_CHECK_EQUAL(v4.get_int(), 1000); |
||||
BOOST_CHECK_THROW(v4.get_str(), std::runtime_error); |
||||
BOOST_CHECK_EQUAL(v4.get_real(), 1000); |
||||
BOOST_CHECK_THROW(v4.get_array(), std::runtime_error); |
||||
BOOST_CHECK_THROW(v4.getKeys(), std::runtime_error); |
||||
BOOST_CHECK_THROW(v4.getValues(), std::runtime_error); |
||||
BOOST_CHECK_THROW(v4.get_obj(), std::runtime_error); |
||||
|
||||
UniValue v5; |
||||
BOOST_CHECK(v5.read("[true, 10]")); |
||||
BOOST_CHECK_NO_THROW(v5.get_array()); |
||||
std::vector<UniValue> vals = v5.getValues(); |
||||
BOOST_CHECK_THROW(vals[0].get_int(), std::runtime_error); |
||||
BOOST_CHECK_EQUAL(vals[0].get_bool(), true); |
||||
|
||||
BOOST_CHECK_EQUAL(vals[1].get_int(), 10); |
||||
BOOST_CHECK_THROW(vals[1].get_bool(), std::runtime_error); |
||||
} |
||||
|
||||
BOOST_AUTO_TEST_CASE(univalue_set) |
||||
{ |
||||
UniValue v(UniValue::VSTR, "foo"); |
||||
v.clear(); |
||||
BOOST_CHECK(v.isNull()); |
||||
BOOST_CHECK_EQUAL(v.getValStr(), ""); |
||||
|
||||
BOOST_CHECK(v.setObject()); |
||||
BOOST_CHECK(v.isObject()); |
||||
BOOST_CHECK_EQUAL(v.size(), 0); |
||||
BOOST_CHECK_EQUAL(v.getType(), UniValue::VOBJ); |
||||
BOOST_CHECK(v.empty()); |
||||
|
||||
BOOST_CHECK(v.setArray()); |
||||
BOOST_CHECK(v.isArray()); |
||||
BOOST_CHECK_EQUAL(v.size(), 0); |
||||
|
||||
BOOST_CHECK(v.setStr("zum")); |
||||
BOOST_CHECK(v.isStr()); |
||||
BOOST_CHECK_EQUAL(v.getValStr(), "zum"); |
||||
|
||||
BOOST_CHECK(v.setFloat(-1.01)); |
||||
BOOST_CHECK(v.isNum()); |
||||
BOOST_CHECK_EQUAL(v.getValStr(), "-1.01"); |
||||
|
||||
BOOST_CHECK(v.setInt((int)1023)); |
||||
BOOST_CHECK(v.isNum()); |
||||
BOOST_CHECK_EQUAL(v.getValStr(), "1023"); |
||||
|
||||
BOOST_CHECK(v.setInt((int64_t)-1023LL)); |
||||
BOOST_CHECK(v.isNum()); |
||||
BOOST_CHECK_EQUAL(v.getValStr(), "-1023"); |
||||
|
||||
BOOST_CHECK(v.setInt((uint64_t)1023ULL)); |
||||
BOOST_CHECK(v.isNum()); |
||||
BOOST_CHECK_EQUAL(v.getValStr(), "1023"); |
||||
|
||||
BOOST_CHECK(v.setNumStr("-688")); |
||||
BOOST_CHECK(v.isNum()); |
||||
BOOST_CHECK_EQUAL(v.getValStr(), "-688"); |
||||
|
||||
BOOST_CHECK(v.setBool(false)); |
||||
BOOST_CHECK_EQUAL(v.isBool(), true); |
||||
BOOST_CHECK_EQUAL(v.isTrue(), false); |
||||
BOOST_CHECK_EQUAL(v.isFalse(), true); |
||||
BOOST_CHECK_EQUAL(v.getBool(), false); |
||||
|
||||
BOOST_CHECK(v.setBool(true)); |
||||
BOOST_CHECK_EQUAL(v.isBool(), true); |
||||
BOOST_CHECK_EQUAL(v.isTrue(), true); |
||||
BOOST_CHECK_EQUAL(v.isFalse(), false); |
||||
BOOST_CHECK_EQUAL(v.getBool(), true); |
||||
|
||||
BOOST_CHECK(!v.setNumStr("zombocom")); |
||||
|
||||
BOOST_CHECK(v.setNull()); |
||||
BOOST_CHECK(v.isNull()); |
||||
} |
||||
|
||||
BOOST_AUTO_TEST_CASE(univalue_array) |
||||
{ |
||||
UniValue arr(UniValue::VARR); |
||||
|
||||
UniValue v((int64_t)1023LL); |
||||
BOOST_CHECK(arr.push_back(v)); |
||||
|
||||
std::string vStr("zippy"); |
||||
BOOST_CHECK(arr.push_back(vStr)); |
||||
|
||||
const char *s = "pippy"; |
||||
BOOST_CHECK(arr.push_back(s)); |
||||
|
||||
std::vector<UniValue> vec; |
||||
v.setStr("boing"); |
||||
vec.push_back(v); |
||||
|
||||
v.setStr("going"); |
||||
vec.push_back(v); |
||||
|
||||
BOOST_CHECK(arr.push_backV(vec)); |
||||
|
||||
BOOST_CHECK_EQUAL(arr.empty(), false); |
||||
BOOST_CHECK_EQUAL(arr.size(), 5); |
||||
|
||||
BOOST_CHECK_EQUAL(arr[0].getValStr(), "1023"); |
||||
BOOST_CHECK_EQUAL(arr[1].getValStr(), "zippy"); |
||||
BOOST_CHECK_EQUAL(arr[2].getValStr(), "pippy"); |
||||
BOOST_CHECK_EQUAL(arr[3].getValStr(), "boing"); |
||||
BOOST_CHECK_EQUAL(arr[4].getValStr(), "going"); |
||||
|
||||
BOOST_CHECK_EQUAL(arr[999].getValStr(), ""); |
||||
|
||||
arr.clear(); |
||||
BOOST_CHECK(arr.empty()); |
||||
BOOST_CHECK_EQUAL(arr.size(), 0); |
||||
} |
||||
|
||||
BOOST_AUTO_TEST_CASE(univalue_object) |
||||
{ |
||||
UniValue obj(UniValue::VOBJ); |
||||
std::string strKey, strVal; |
||||
UniValue v; |
||||
|
||||
strKey = "age"; |
||||
v.setInt(100); |
||||
BOOST_CHECK(obj.pushKV(strKey, v)); |
||||
|
||||
strKey = "first"; |
||||
strVal = "John"; |
||||
BOOST_CHECK(obj.pushKV(strKey, strVal)); |
||||
|
||||
strKey = "last"; |
||||
const char *cVal = "Smith"; |
||||
BOOST_CHECK(obj.pushKV(strKey, cVal)); |
||||
|
||||
strKey = "distance"; |
||||
BOOST_CHECK(obj.pushKV(strKey, (int64_t) 25)); |
||||
|
||||
strKey = "time"; |
||||
BOOST_CHECK(obj.pushKV(strKey, (uint64_t) 3600)); |
||||
|
||||
strKey = "calories"; |
||||
BOOST_CHECK(obj.pushKV(strKey, (int) 12)); |
||||
|
||||
strKey = "temperature"; |
||||
BOOST_CHECK(obj.pushKV(strKey, (double) 90.012)); |
||||
|
||||
UniValue obj2(UniValue::VOBJ); |
||||
BOOST_CHECK(obj2.pushKV("cat1", 9000)); |
||||
BOOST_CHECK(obj2.pushKV("cat2", 12345)); |
||||
|
||||
BOOST_CHECK(obj.pushKVs(obj2)); |
||||
|
||||
BOOST_CHECK_EQUAL(obj.empty(), false); |
||||
BOOST_CHECK_EQUAL(obj.size(), 9); |
||||
|
||||
BOOST_CHECK_EQUAL(obj["age"].getValStr(), "100"); |
||||
BOOST_CHECK_EQUAL(obj["first"].getValStr(), "John"); |
||||
BOOST_CHECK_EQUAL(obj["last"].getValStr(), "Smith"); |
||||
BOOST_CHECK_EQUAL(obj["distance"].getValStr(), "25"); |
||||
BOOST_CHECK_EQUAL(obj["time"].getValStr(), "3600"); |
||||
BOOST_CHECK_EQUAL(obj["calories"].getValStr(), "12"); |
||||
BOOST_CHECK_EQUAL(obj["temperature"].getValStr(), "90.012"); |
||||
BOOST_CHECK_EQUAL(obj["cat1"].getValStr(), "9000"); |
||||
BOOST_CHECK_EQUAL(obj["cat2"].getValStr(), "12345"); |
||||
|
||||
BOOST_CHECK_EQUAL(obj["nyuknyuknyuk"].getValStr(), ""); |
||||
|
||||
BOOST_CHECK(obj.exists("age")); |
||||
BOOST_CHECK(obj.exists("first")); |
||||
BOOST_CHECK(obj.exists("last")); |
||||
BOOST_CHECK(obj.exists("distance")); |
||||
BOOST_CHECK(obj.exists("time")); |
||||
BOOST_CHECK(obj.exists("calories")); |
||||
BOOST_CHECK(obj.exists("temperature")); |
||||
BOOST_CHECK(obj.exists("cat1")); |
||||
BOOST_CHECK(obj.exists("cat2")); |
||||
|
||||
BOOST_CHECK(!obj.exists("nyuknyuknyuk")); |
||||
|
||||
std::map<std::string, UniValue::VType> objTypes; |
||||
objTypes["age"] = UniValue::VNUM; |
||||
objTypes["first"] = UniValue::VSTR; |
||||
objTypes["last"] = UniValue::VSTR; |
||||
objTypes["distance"] = UniValue::VNUM; |
||||
objTypes["time"] = UniValue::VNUM; |
||||
objTypes["calories"] = UniValue::VNUM; |
||||
objTypes["temperature"] = UniValue::VNUM; |
||||
objTypes["cat1"] = UniValue::VNUM; |
||||
objTypes["cat2"] = UniValue::VNUM; |
||||
BOOST_CHECK(obj.checkObject(objTypes)); |
||||
|
||||
objTypes["cat2"] = UniValue::VSTR; |
||||
BOOST_CHECK(!obj.checkObject(objTypes)); |
||||
|
||||
obj.clear(); |
||||
BOOST_CHECK(obj.empty()); |
||||
BOOST_CHECK_EQUAL(obj.size(), 0); |
||||
} |
||||
|
||||
static const char *json1 = |
||||
"[1.10000000,{\"key1\":\"str\\u0000\",\"key2\":800,\"key3\":{\"name\":\"martian http://test.com\"}}]"; |
||||
|
||||
BOOST_AUTO_TEST_CASE(univalue_readwrite) |
||||
{ |
||||
UniValue v; |
||||
BOOST_CHECK(v.read(json1)); |
||||
|
||||
std::string strJson1(json1); |
||||
BOOST_CHECK(v.read(strJson1)); |
||||
|
||||
BOOST_CHECK(v.isArray()); |
||||
BOOST_CHECK_EQUAL(v.size(), 2); |
||||
|
||||
BOOST_CHECK_EQUAL(v[0].getValStr(), "1.10000000"); |
||||
|
||||
UniValue obj = v[1]; |
||||
BOOST_CHECK(obj.isObject()); |
||||
BOOST_CHECK_EQUAL(obj.size(), 3); |
||||
|
||||
BOOST_CHECK(obj["key1"].isStr()); |
||||
std::string correctValue("str"); |
||||
correctValue.push_back('\0'); |
||||
BOOST_CHECK_EQUAL(obj["key1"].getValStr(), correctValue); |
||||
BOOST_CHECK(obj["key2"].isNum()); |
||||
BOOST_CHECK_EQUAL(obj["key2"].getValStr(), "800"); |
||||
BOOST_CHECK(obj["key3"].isObject()); |
||||
|
||||
BOOST_CHECK_EQUAL(strJson1, v.write()); |
||||
|
||||
/* Check for (correctly reporting) a parsing error if the initial
|
||||
JSON construct is followed by more stuff. Note that whitespace |
||||
is, of course, exempt. */ |
||||
|
||||
BOOST_CHECK(v.read(" {}\n ")); |
||||
BOOST_CHECK(v.isObject()); |
||||
BOOST_CHECK(v.read(" []\n ")); |
||||
BOOST_CHECK(v.isArray()); |
||||
|
||||
BOOST_CHECK(!v.read("@{}")); |
||||
BOOST_CHECK(!v.read("{} garbage")); |
||||
BOOST_CHECK(!v.read("[]{}")); |
||||
BOOST_CHECK(!v.read("{}[]")); |
||||
BOOST_CHECK(!v.read("{} 42")); |
||||
} |
||||
|
||||
BOOST_AUTO_TEST_SUITE_END() |
Loading…
Reference in new issue