|
@@ -14,7 +14,7 @@
|
|
|
|
|
|
#include <config.h>
|
|
|
#include <exceptions/exceptions.h>
|
|
|
-#include <dhcpsrv/data_source.h>
|
|
|
+#include <dhcpsrv/database_connection.h>
|
|
|
#include <gtest/gtest.h>
|
|
|
|
|
|
using namespace isc::dhcp;
|
|
@@ -24,12 +24,12 @@ using namespace isc::dhcp;
|
|
|
///
|
|
|
/// This test checks if the LeaseMgr can be instantiated and that it
|
|
|
/// parses parameters string properly.
|
|
|
-TEST(DataSourceTest, getParameter) {
|
|
|
+TEST(DatabaseConnectionTest, getParameter) {
|
|
|
|
|
|
- DataSource::ParameterMap pmap;
|
|
|
+ DatabaseConnection::ParameterMap pmap;
|
|
|
pmap[std::string("param1")] = std::string("value1");
|
|
|
pmap[std::string("param2")] = std::string("value2");
|
|
|
- DataSource datasrc(pmap);
|
|
|
+ DatabaseConnection datasrc(pmap);
|
|
|
|
|
|
EXPECT_EQ("value1", datasrc.getParameter("param1"));
|
|
|
EXPECT_EQ("value2", datasrc.getParameter("param2"));
|
|
@@ -37,9 +37,9 @@ TEST(DataSourceTest, getParameter) {
|
|
|
}
|
|
|
|
|
|
// This test checks that a database access string can be parsed correctly.
|
|
|
-TEST(DataSourceTest, parse) {
|
|
|
+TEST(DatabaseConnectionTest, parse) {
|
|
|
|
|
|
- DataSource::ParameterMap parameters = DataSource::parse(
|
|
|
+ DatabaseConnection::ParameterMap parameters = DatabaseConnection::parse(
|
|
|
"user=me password=forbidden name=kea somethingelse= type=mysql");
|
|
|
|
|
|
EXPECT_EQ(5, parameters.size());
|
|
@@ -51,25 +51,25 @@ TEST(DataSourceTest, parse) {
|
|
|
}
|
|
|
|
|
|
// This test checks that an invalid database access string behaves as expected.
|
|
|
-TEST(DataSourceTest, parseInvalid) {
|
|
|
+TEST(DatabaseConnectionTest, parseInvalid) {
|
|
|
|
|
|
// No tokens in the string, so we expect no parameters
|
|
|
std::string invalid = "";
|
|
|
- DataSource::ParameterMap parameters = DataSource::parse(invalid);
|
|
|
+ DatabaseConnection::ParameterMap parameters = DatabaseConnection::parse(invalid);
|
|
|
EXPECT_EQ(0, parameters.size());
|
|
|
|
|
|
// With spaces, there are some tokens so we expect invalid parameter
|
|
|
// as there are no equals signs.
|
|
|
invalid = " \t ";
|
|
|
- EXPECT_THROW(DataSource::parse(invalid), isc::InvalidParameter);
|
|
|
+ EXPECT_THROW(DatabaseConnection::parse(invalid), isc::InvalidParameter);
|
|
|
|
|
|
invalid = " noequalshere ";
|
|
|
- EXPECT_THROW(DataSource::parse(invalid), isc::InvalidParameter);
|
|
|
+ EXPECT_THROW(DatabaseConnection::parse(invalid), isc::InvalidParameter);
|
|
|
|
|
|
// A single "=" is valid string, but is placed here as the result is
|
|
|
// expected to be nothing.
|
|
|
invalid = "=";
|
|
|
- parameters = DataSource::parse(invalid);
|
|
|
+ parameters = DatabaseConnection::parse(invalid);
|
|
|
EXPECT_EQ(1, parameters.size());
|
|
|
EXPECT_EQ("", parameters[""]);
|
|
|
}
|
|
@@ -78,10 +78,10 @@ TEST(DataSourceTest, parseInvalid) {
|
|
|
///
|
|
|
/// Checks that the redacted configuration string includes the password only
|
|
|
/// as a set of asterisks.
|
|
|
-TEST(DataSourceTest, redactAccessString) {
|
|
|
+TEST(DatabaseConnectionTest, redactAccessString) {
|
|
|
|
|
|
- DataSource::ParameterMap parameters =
|
|
|
- DataSource::parse("user=me password=forbidden name=kea type=mysql");
|
|
|
+ DatabaseConnection::ParameterMap parameters =
|
|
|
+ DatabaseConnection::parse("user=me password=forbidden name=kea type=mysql");
|
|
|
EXPECT_EQ(4, parameters.size());
|
|
|
EXPECT_EQ("me", parameters["user"]);
|
|
|
EXPECT_EQ("forbidden", parameters["password"]);
|
|
@@ -90,8 +90,8 @@ TEST(DataSourceTest, redactAccessString) {
|
|
|
|
|
|
// Redact the result. To check, break the redacted string down into its
|
|
|
// components.
|
|
|
- std::string redacted = DataSource::redactedAccessString(parameters);
|
|
|
- parameters = DataSource::parse(redacted);
|
|
|
+ std::string redacted = DatabaseConnection::redactedAccessString(parameters);
|
|
|
+ parameters = DatabaseConnection::parse(redacted);
|
|
|
|
|
|
EXPECT_EQ(4, parameters.size());
|
|
|
EXPECT_EQ("me", parameters["user"]);
|
|
@@ -104,10 +104,10 @@ TEST(DataSourceTest, redactAccessString) {
|
|
|
///
|
|
|
/// Checks that the redacted configuration string includes the password only
|
|
|
/// as a set of asterisks, even if the password is null.
|
|
|
-TEST(DataSourceTest, redactAccessStringEmptyPassword) {
|
|
|
+TEST(DatabaseConnectionTest, redactAccessStringEmptyPassword) {
|
|
|
|
|
|
- DataSource::ParameterMap parameters =
|
|
|
- DataSource::parse("user=me name=kea type=mysql password=");
|
|
|
+ DatabaseConnection::ParameterMap parameters =
|
|
|
+ DatabaseConnection::parse("user=me name=kea type=mysql password=");
|
|
|
EXPECT_EQ(4, parameters.size());
|
|
|
EXPECT_EQ("me", parameters["user"]);
|
|
|
EXPECT_EQ("", parameters["password"]);
|
|
@@ -116,8 +116,8 @@ TEST(DataSourceTest, redactAccessStringEmptyPassword) {
|
|
|
|
|
|
// Redact the result. To check, break the redacted string down into its
|
|
|
// components.
|
|
|
- std::string redacted = DataSource::redactedAccessString(parameters);
|
|
|
- parameters = DataSource::parse(redacted);
|
|
|
+ std::string redacted = DatabaseConnection::redactedAccessString(parameters);
|
|
|
+ parameters = DatabaseConnection::parse(redacted);
|
|
|
|
|
|
EXPECT_EQ(4, parameters.size());
|
|
|
EXPECT_EQ("me", parameters["user"]);
|
|
@@ -127,15 +127,15 @@ TEST(DataSourceTest, redactAccessStringEmptyPassword) {
|
|
|
|
|
|
// ... and again to check that the position of the empty password in the
|
|
|
// string does not matter.
|
|
|
- parameters = DataSource::parse("user=me password= name=kea type=mysql");
|
|
|
+ parameters = DatabaseConnection::parse("user=me password= name=kea type=mysql");
|
|
|
EXPECT_EQ(4, parameters.size());
|
|
|
EXPECT_EQ("me", parameters["user"]);
|
|
|
EXPECT_EQ("", parameters["password"]);
|
|
|
EXPECT_EQ("kea", parameters["name"]);
|
|
|
EXPECT_EQ("mysql", parameters["type"]);
|
|
|
|
|
|
- redacted = DataSource::redactedAccessString(parameters);
|
|
|
- parameters = DataSource::parse(redacted);
|
|
|
+ redacted = DatabaseConnection::redactedAccessString(parameters);
|
|
|
+ parameters = DatabaseConnection::parse(redacted);
|
|
|
|
|
|
EXPECT_EQ(4, parameters.size());
|
|
|
EXPECT_EQ("me", parameters["user"]);
|
|
@@ -148,10 +148,10 @@ TEST(DataSourceTest, redactAccessStringEmptyPassword) {
|
|
|
///
|
|
|
/// Checks that the redacted configuration string excludes the password if there
|
|
|
/// was no password to begin with.
|
|
|
-TEST(DataSourceTest, redactAccessStringNoPassword) {
|
|
|
+TEST(DatabaseConnectionTest, redactAccessStringNoPassword) {
|
|
|
|
|
|
- DataSource::ParameterMap parameters =
|
|
|
- DataSource::parse("user=me name=kea type=mysql");
|
|
|
+ DatabaseConnection::ParameterMap parameters =
|
|
|
+ DatabaseConnection::parse("user=me name=kea type=mysql");
|
|
|
EXPECT_EQ(3, parameters.size());
|
|
|
EXPECT_EQ("me", parameters["user"]);
|
|
|
EXPECT_EQ("kea", parameters["name"]);
|
|
@@ -159,8 +159,8 @@ TEST(DataSourceTest, redactAccessStringNoPassword) {
|
|
|
|
|
|
// Redact the result. To check, break the redacted string down into its
|
|
|
// components.
|
|
|
- std::string redacted = DataSource::redactedAccessString(parameters);
|
|
|
- parameters = DataSource::parse(redacted);
|
|
|
+ std::string redacted = DatabaseConnection::redactedAccessString(parameters);
|
|
|
+ parameters = DatabaseConnection::parse(redacted);
|
|
|
|
|
|
EXPECT_EQ(3, parameters.size());
|
|
|
EXPECT_EQ("me", parameters["user"]);
|