blob: aefb822acbc6e8aa6e169ea8c1ec3bbac794bfbe [file] [log] [blame]
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
/**
* Copyright (c) 2014-2017, Regents of the University of California
*
* This file is part of NDN DeLorean, An Authentication System for Data Archives in
* Named Data Networking. See AUTHORS.md for complete list of NDN DeLorean authors
* and contributors.
*
* NDN DeLorean is free software: you can redistribute it and/or modify it under
* the terms of the GNU General Public License as published by the Free Software
* Foundation, either version 3 of the License, or (at your option) any later
* version.
*
* NDN DeLorean is distributed in the hope that it will be useful, but WITHOUT ANY
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
* PARTICULAR PURPOSE. See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along with NDN
* DeLorean, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
*/
#include "auditor.hpp"
#include "../tree-generator.hpp"
#include "cryptopp.hpp"
#include <boost/mpl/list.hpp>
#include "boost-test.hpp"
namespace ndn {
namespace delorean {
namespace tests {
BOOST_AUTO_TEST_SUITE(TestAuditor)
void
printHex(const uint8_t* buf, size_t size)
{
using namespace CryptoPP;
StringSource ss(buf, size, true, new HexEncoder(new FileSink(std::cerr), false));
std::cerr << std::endl;
}
BOOST_AUTO_TEST_CASE(LoadProofTests)
{
std::vector<shared_ptr<Data>> proofs;
proofs.push_back(TreeGenerator::getSubTreeBinary(Node::Index(0, 5), 32)->encode());
proofs.push_back(TreeGenerator::getSubTreeBinary(Node::Index(32, 5), 64)->encode());
std::map<Node::Index, ConstSubTreeBinaryPtr> tree1;
BOOST_CHECK(Auditor::loadProof(tree1, proofs, TreeGenerator::LOGGER_NAME));
proofs.push_back(TreeGenerator::getSubTreeBinary(Node::Index(32, 5), 64)->encode());
std::map<Node::Index, ConstSubTreeBinaryPtr> tree2;
BOOST_CHECK_EQUAL(Auditor::loadProof(tree2, proofs, TreeGenerator::LOGGER_NAME), false);
}
size_t
getRootLevel(const NonNegativeInteger& leafSeqNo) {
size_t rootLevel = 0;
NonNegativeInteger seqNo = leafSeqNo;
while (seqNo != 0) {
seqNo = seqNo >> 1;
rootLevel++;
}
return rootLevel;
}
template<NonNegativeInteger L, NonNegativeInteger O, NonNegativeInteger N>
class AuditorProofParam1
{
public:
void
createProof()
{
proofs.push_back(TreeGenerator::getSubTreeBinary(Node::Index(0, 5), 32, true)->encode());
leafHash = TreeGenerator::getHash(Node::Index(L, 0), L + 1, false);
oldHash = TreeGenerator::getHash(Node::Index(0, getRootLevel(O - 1)), O, false);
newHash = TreeGenerator::getHash(Node::Index(0, getRootLevel(N - 1)), N, false);
}
std::vector<shared_ptr<Data>> proofs;
const NonNegativeInteger leafSeqNo = L;
ndn::ConstBufferPtr leafHash;
const NonNegativeInteger oldNextSeqNo = O;
ndn::ConstBufferPtr oldHash;
const NonNegativeInteger newNextSeqNo = N;
ndn::ConstBufferPtr newHash;
};
template<NonNegativeInteger L, NonNegativeInteger O, NonNegativeInteger N>
class AuditorProofParam2
{
public:
void
createProof()
{
// proofs.push_back(TreeGenerator::getSubTreeBinary(Node::Index(0, 5), 32, true)->encode());
proofs.push_back(TreeGenerator::getSubTreeBinary(Node::Index(32, 5), 64, true)->encode());
proofs.push_back(TreeGenerator::getSubTreeBinary(Node::Index(0, 10), 64, true)->encode());
leafHash = TreeGenerator::getHash(Node::Index(L, 0), L + 1, false);
oldHash = TreeGenerator::getHash(Node::Index(0, getRootLevel(O - 1)), O, false);
newHash = TreeGenerator::getHash(Node::Index(0, getRootLevel(N - 1)), N, false);
}
std::vector<shared_ptr<Data>> proofs;
const NonNegativeInteger leafSeqNo = L;
ndn::ConstBufferPtr leafHash;
const NonNegativeInteger oldNextSeqNo = O;
ndn::ConstBufferPtr oldHash;
const NonNegativeInteger newNextSeqNo = N;
ndn::ConstBufferPtr newHash;
};
template<NonNegativeInteger L, NonNegativeInteger O, NonNegativeInteger N>
class AuditorProofParam3
{
public:
void
createProof()
{
proofs.push_back(TreeGenerator::getSubTreeBinary(Node::Index(0, 5), 32, true)->encode());
proofs.push_back(TreeGenerator::getSubTreeBinary(Node::Index(32, 5), 33, true)->encode());
proofs.push_back(TreeGenerator::getSubTreeBinary(Node::Index(0, 10), 33, true)->encode());
leafHash = TreeGenerator::getHash(Node::Index(L, 0), L + 1, false);
oldHash = TreeGenerator::getHash(Node::Index(0, getRootLevel(O - 1)), O, false);
newHash = TreeGenerator::getHash(Node::Index(0, getRootLevel(N - 1)), N, false);
}
std::vector<shared_ptr<Data>> proofs;
const NonNegativeInteger leafSeqNo = L;
ndn::ConstBufferPtr leafHash;
const NonNegativeInteger oldNextSeqNo = O;
ndn::ConstBufferPtr oldHash;
const NonNegativeInteger newNextSeqNo = N;
ndn::ConstBufferPtr newHash;
};
typedef boost::mpl::list<AuditorProofParam1<0, 1, 1>,
AuditorProofParam1<0, 2, 2>,
AuditorProofParam1<0, 4, 4>,
AuditorProofParam1<1, 2, 2>,
AuditorProofParam1<1, 4, 4>,
AuditorProofParam1<2, 4, 4>,
AuditorProofParam1<3, 4, 4>,
AuditorProofParam1<4, 6, 6>,
AuditorProofParam1<31, 32, 32>,
AuditorProofParam3<0, 33, 33>,
AuditorProofParam2<32, 33, 33>,
AuditorProofParam2<48, 64, 64>> ExistenceProofTestParams;
BOOST_AUTO_TEST_CASE_TEMPLATE(ExistenceProof, P, ExistenceProofTestParams)
{
P params;
params.createProof();
BOOST_CHECK(Auditor::doesExist(params.leafSeqNo, params.leafHash,
params.newNextSeqNo, params.newHash,
params.proofs, TreeGenerator::LOGGER_NAME));
}
template<NonNegativeInteger L, NonNegativeInteger O, NonNegativeInteger N>
class AuditorProofParam4
{
public:
void
createProof()
{
proofs.push_back(TreeGenerator::getSubTreeBinary(Node::Index(0, 5), 32, true)->encode());
proofs.push_back(TreeGenerator::getSubTreeBinary(Node::Index(32, 5), 64, true)->encode());
proofs.push_back(TreeGenerator::getSubTreeBinary(Node::Index(0, 10), 64, true)->encode());
leafHash = TreeGenerator::getHash(Node::Index(L, 0), L + 1, false);
oldHash = TreeGenerator::getHash(Node::Index(0, getRootLevel(O - 1)), O, false);
newHash = TreeGenerator::getHash(Node::Index(0, getRootLevel(N - 1)), N, false);
}
std::vector<shared_ptr<Data>> proofs;
const NonNegativeInteger leafSeqNo = L;
ndn::ConstBufferPtr leafHash;
const NonNegativeInteger oldNextSeqNo = O;
ndn::ConstBufferPtr oldHash;
const NonNegativeInteger newNextSeqNo = N;
ndn::ConstBufferPtr newHash;
};
typedef boost::mpl::list<AuditorProofParam1<0, 1, 1>,
AuditorProofParam1<0, 1, 2>,
AuditorProofParam1<0, 1, 32>,
AuditorProofParam1<0, 2, 32>,
AuditorProofParam1<0, 31, 32>,
AuditorProofParam4<0, 32, 64>,
AuditorProofParam3<0, 1, 33>,
AuditorProofParam3<0, 31, 33>,
AuditorProofParam4<0, 1, 64>> ConsistencyProofTestParams;
BOOST_AUTO_TEST_CASE_TEMPLATE(ConsistencyProof, P, ConsistencyProofTestParams)
{
P params;
params.createProof();
BOOST_CHECK(Auditor::isConsistent(params.oldNextSeqNo, params.oldHash,
params.newNextSeqNo, params.newHash,
params.proofs, TreeGenerator::LOGGER_NAME));
}
BOOST_AUTO_TEST_SUITE_END()
} // namespace tests
} // namespace delorean
} // namespace ndn