2068f089c8
-BEGIN VERIFY SCRIPT- mkdir -p src/util git mv src/util.h src/util/system.h git mv src/util.cpp src/util/system.cpp git mv src/utilmemory.h src/util/memory.h git mv src/utilmoneystr.h src/util/moneystr.h git mv src/utilmoneystr.cpp src/util/moneystr.cpp git mv src/utilstrencodings.h src/util/strencodings.h git mv src/utilstrencodings.cpp src/util/strencodings.cpp git mv src/utiltime.h src/util/time.h git mv src/utiltime.cpp src/util/time.cpp sed -i 's/<util\.h>/<util\/system\.h>/g' $(git ls-files 'src/*.h' 'src/*.cpp') sed -i 's/<utilmemory\.h>/<util\/memory\.h>/g' $(git ls-files 'src/*.h' 'src/*.cpp') sed -i 's/<utilmoneystr\.h>/<util\/moneystr\.h>/g' $(git ls-files 'src/*.h' 'src/*.cpp') sed -i 's/<utilstrencodings\.h>/<util\/strencodings\.h>/g' $(git ls-files 'src/*.h' 'src/*.cpp') sed -i 's/<utiltime\.h>/<util\/time\.h>/g' $(git ls-files 'src/*.h' 'src/*.cpp') sed -i 's/BITCOIN_UTIL_H/BITCOIN_UTIL_SYSTEM_H/g' src/util/system.h sed -i 's/BITCOIN_UTILMEMORY_H/BITCOIN_UTIL_MEMORY_H/g' src/util/memory.h sed -i 's/BITCOIN_UTILMONEYSTR_H/BITCOIN_UTIL_MONEYSTR_H/g' src/util/moneystr.h sed -i 's/BITCOIN_UTILSTRENCODINGS_H/BITCOIN_UTIL_STRENCODINGS_H/g' src/util/strencodings.h sed -i 's/BITCOIN_UTILTIME_H/BITCOIN_UTIL_TIME_H/g' src/util/time.h sed -i 's/ util\.\(h\|cpp\)/ util\/system\.\1/g' src/Makefile.am sed -i 's/utilmemory\.\(h\|cpp\)/util\/memory\.\1/g' src/Makefile.am sed -i 's/utilmoneystr\.\(h\|cpp\)/util\/moneystr\.\1/g' src/Makefile.am sed -i 's/utilstrencodings\.\(h\|cpp\)/util\/strencodings\.\1/g' src/Makefile.am sed -i 's/utiltime\.\(h\|cpp\)/util\/time\.\1/g' src/Makefile.am sed -i 's/-> util ->/-> util\/system ->/' test/lint/lint-circular-dependencies.sh sed -i 's/src\/util\.cpp/src\/util\/system\.cpp/g' test/lint/lint-format-strings.py test/lint/lint-locale-dependence.sh sed -i 's/src\/utilmoneystr\.cpp/src\/util\/moneystr\.cpp/g' test/lint/lint-locale-dependence.sh sed -i 's/src\/utilstrencodings\.\(h\|cpp\)/src\/util\/strencodings\.\1/g' test/lint/lint-locale-dependence.sh sed -i 's/src\\utilstrencodings\.cpp/src\\util\\strencodings\.cpp/' build_msvc/libbitcoinconsensus/libbitcoinconsensus.vcxproj -END VERIFY SCRIPT-
53 lines
1.5 KiB
C++
53 lines
1.5 KiB
C++
// Copyright (c) 2018 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 <key.h>
|
|
|
|
#include <base58.h>
|
|
#include <script/script.h>
|
|
#include <uint256.h>
|
|
#include <util/system.h>
|
|
#include <util/strencodings.h>
|
|
#include <test/test_bitcoin.h>
|
|
#include <string>
|
|
#include <vector>
|
|
|
|
#include <boost/test/unit_test.hpp>
|
|
#include <rapidcheck/boost_test.h>
|
|
#include <rapidcheck/gen/Arbitrary.h>
|
|
#include <rapidcheck/Gen.h>
|
|
|
|
#include <test/gen/crypto_gen.h>
|
|
|
|
BOOST_FIXTURE_TEST_SUITE(key_properties, BasicTestingSetup)
|
|
|
|
/** Check CKey uniqueness */
|
|
RC_BOOST_PROP(key_uniqueness, (const CKey& key1, const CKey& key2))
|
|
{
|
|
RC_ASSERT(!(key1 == key2));
|
|
}
|
|
|
|
/** Verify that a private key generates the correct public key */
|
|
RC_BOOST_PROP(key_generates_correct_pubkey, (const CKey& key))
|
|
{
|
|
CPubKey pubKey = key.GetPubKey();
|
|
RC_ASSERT(key.VerifyPubKey(pubKey));
|
|
}
|
|
|
|
/** Create a CKey using the 'Set' function must give us the same key */
|
|
RC_BOOST_PROP(key_set_symmetry, (const CKey& key))
|
|
{
|
|
CKey key1;
|
|
key1.Set(key.begin(), key.end(), key.IsCompressed());
|
|
RC_ASSERT(key1 == key);
|
|
}
|
|
|
|
/** Create a CKey, sign a piece of data, then verify it with the public key */
|
|
RC_BOOST_PROP(key_sign_symmetry, (const CKey& key, const uint256& hash))
|
|
{
|
|
std::vector<unsigned char> vchSig;
|
|
key.Sign(hash, vchSig, 0);
|
|
const CPubKey& pubKey = key.GetPubKey();
|
|
RC_ASSERT(pubKey.Verify(hash, vchSig));
|
|
}
|
|
BOOST_AUTO_TEST_SUITE_END()
|