blob: 78077db5068e2dd74fd947727deb69710cfa1bc1 [file] [log] [blame]
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
/*
* Copyright (c) 2017-2020, Regents of the University of California.
*
* This file is part of ndncert, a certificate management system based on NDN.
*
* ndncert 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.
*
* ndncert 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 copies of the GNU General Public License along with
* ndncert, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
*
* See AUTHORS.md for complete list of ndncert authors and contributors.
*/
#include "detail/ca-sqlite.hpp"
#include "test-common.hpp"
namespace ndn {
namespace ndncert {
namespace tests {
using namespace ca;
BOOST_FIXTURE_TEST_SUITE(TestCaSqlite, DatabaseFixture)
BOOST_AUTO_TEST_CASE(RequestOperations)
{
CaSqlite storage(Name(), dbDir.string() + "/TestCaSqlite_RequestOperations.db");
auto identity1 = addIdentity(Name("/ndn/site1"));
auto key1 = identity1.getDefaultKey();
auto cert1 = key1.getDefaultCertificate();
// add operation
RequestId requestId = {{101}};
RequestState request1;
request1.caPrefix = Name("/ndn/site1");
request1.requestId = requestId;
request1.requestType = RequestType::NEW;
request1.cert = cert1;
request1.encryptionKey = {{102}};
request1.decryptionIv.assign({1,2,3,4,5,6,7,8,9,10,11,12});
request1.decryptionIv.assign({2,3,4,5,6,7,8,9,10,11,12,13});
storage.addRequest(request1);
// get operation
auto result = storage.getRequest(requestId);
BOOST_CHECK_EQUAL(request1.cert, result.cert);
BOOST_CHECK(request1.status == result.status);
BOOST_CHECK_EQUAL(request1.caPrefix, result.caPrefix);
BOOST_CHECK_EQUAL_COLLECTIONS(request1.encryptionKey.begin(), request1.encryptionKey.end(),
result.encryptionKey.begin(), result.encryptionKey.end());
BOOST_CHECK_EQUAL_COLLECTIONS(request1.encryptionIv.begin(), request1.encryptionIv.end(),
result.encryptionIv.begin(), result.encryptionIv.end());
BOOST_CHECK_EQUAL_COLLECTIONS(request1.decryptionIv.begin(), request1.decryptionIv.end(),
result.decryptionIv.begin(), result.decryptionIv.end());
// update operation
RequestState request2;
request2.caPrefix = Name("/ndn/site1");
request2.requestId = requestId;
request2.requestType = RequestType::NEW;
request2.cert = cert1;
request2.challengeType = "email";
JsonSection secret;
secret.add("code", "1234");
request2.challengeState = ChallengeState("test", time::system_clock::now(), 3,
time::seconds(3600), std::move(secret));
request2.decryptionIv.assign({1,2,3,4,5,6,7,8,9,10,11,14});
request2.decryptionIv.assign({2,3,4,5,6,7,8,9,10,11,12,15});
storage.updateRequest(request2);
result = storage.getRequest(requestId);
BOOST_CHECK_EQUAL(request2.cert, result.cert);
BOOST_CHECK(request2.status == result.status);
BOOST_CHECK_EQUAL(request2.caPrefix, result.caPrefix);
BOOST_CHECK_EQUAL_COLLECTIONS(request2.encryptionIv.begin(), request2.encryptionIv.end(),
result.encryptionIv.begin(), result.encryptionIv.end());
BOOST_CHECK_EQUAL_COLLECTIONS(request2.decryptionIv.begin(), request2.decryptionIv.end(),
result.decryptionIv.begin(), result.decryptionIv.end());
// another add operation
auto identity2 = addIdentity(Name("/ndn/site2"));
auto key2 = identity2.getDefaultKey();
auto cert2 = key2.getDefaultCertificate();
RequestId requestId2 = {{102}};
RequestState request3;
request3.caPrefix = Name("/ndn/site2");
request3.requestId = requestId2;
request3.requestType = RequestType::NEW;
request3.cert = cert2;
storage.addRequest(request3);
// list operation
auto allRequests = storage.listAllRequests();
BOOST_CHECK_EQUAL(allRequests.size(), 2);
storage.deleteRequest(requestId2);
allRequests = storage.listAllRequests();
BOOST_CHECK_EQUAL(allRequests.size(), 1);
storage.deleteRequest(requestId);
allRequests = storage.listAllRequests();
BOOST_CHECK_EQUAL(allRequests.size(), 0);
}
BOOST_AUTO_TEST_CASE(DuplicateAdd)
{
CaSqlite storage(Name(), dbDir.string() + "/TestCaSqlite_DuplicateAdd.db");
auto identity1 = addIdentity(Name("/ndn/site1"));
auto key1 = identity1.getDefaultKey();
auto cert1 = key1.getDefaultCertificate();
// add operation
RequestId requestId = {{101}};
RequestState request1;
request1.caPrefix = Name("/ndn/site1");
request1.requestId = requestId;
request1.requestType = RequestType::NEW;
request1.cert = cert1;
BOOST_CHECK_NO_THROW(storage.addRequest(request1));
// add again
BOOST_CHECK_THROW(storage.addRequest(request1), std::runtime_error);
}
BOOST_AUTO_TEST_SUITE_END() // TestCaModule
} // namespace tests
} // namespace ndncert
} // namespace ndn