2020-03-02 21:18:25 +00:00
|
|
|
#include <gtest/gtest.h>
|
2020-03-08 15:14:55 +00:00
|
|
|
|
|
|
|
#include "webfused/config/factory.h"
|
2020-03-08 19:29:08 +00:00
|
|
|
#include "webfused/log/logger.h"
|
|
|
|
#include "webfused/log/log.h"
|
|
|
|
#include "mock_logger.hpp"
|
2020-03-15 20:48:45 +00:00
|
|
|
#include "mock_config_builder.hpp"
|
2020-03-08 19:29:08 +00:00
|
|
|
|
|
|
|
|
|
|
|
using ::testing::_;
|
2020-03-16 20:50:31 +00:00
|
|
|
using ::testing::Return;
|
2020-03-15 20:48:45 +00:00
|
|
|
using ::testing::StrictMock;
|
|
|
|
using ::testing::StrEq;
|
2020-03-08 19:29:08 +00:00
|
|
|
using ::webfused_test::MockLogger;
|
2020-03-15 20:48:45 +00:00
|
|
|
using ::webfused_test::MockConfigBuilder;
|
2020-03-02 21:18:25 +00:00
|
|
|
|
|
|
|
TEST(config, is_loadable)
|
|
|
|
{
|
2020-03-15 20:48:45 +00:00
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
2020-03-18 16:33:31 +00:00
|
|
|
EXPECT_CALL(builder, setLogger(_,_,_)).Times(1).WillOnce(Return(true));
|
2020-03-15 20:48:45 +00:00
|
|
|
EXPECT_CALL(builder, setServerVhostname(StrEq("localhost"))).Times(1);
|
|
|
|
EXPECT_CALL(builder, setServerPort(8080)).Times(1);
|
2020-03-18 09:17:17 +00:00
|
|
|
EXPECT_CALL(builder, addAuthProvider(_, _)).Times(1).WillOnce(Return(true));
|
2020-03-17 20:51:04 +00:00
|
|
|
EXPECT_CALL(builder, addFilesystem(_,_)).Times(1).WillOnce(Return(true));
|
2020-03-08 15:14:55 +00:00
|
|
|
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_file("webfused.conf");
|
|
|
|
ASSERT_NE(nullptr, config);
|
2020-03-08 15:14:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, minimal_config)
|
|
|
|
{
|
2020-03-08 19:29:08 +00:00
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(_, _, _)).Times(0);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
2020-03-15 20:48:45 +00:00
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
2020-03-08 15:14:55 +00:00
|
|
|
|
2020-03-15 20:48:45 +00:00
|
|
|
char const minimal[] = "version = { major = 1, minor = 0 }\n";
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(minimal);
|
|
|
|
ASSERT_NE(nullptr, config);
|
2020-03-08 15:14:55 +00:00
|
|
|
}
|
|
|
|
|
2020-03-09 22:25:47 +00:00
|
|
|
TEST(config, invalid_config)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(WFD_LOGLEVEL_ERROR, _, _)).Times(1);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
2020-03-19 16:25:26 +00:00
|
|
|
StrictMock<MockConfigBuilder> builder;
|
|
|
|
EXPECT_CALL(builder, create).Times(0);
|
|
|
|
EXPECT_CALL(builder, dispose(_)).Times(0);
|
2020-03-15 20:48:45 +00:00
|
|
|
|
2020-03-09 22:25:47 +00:00
|
|
|
char const syntax_error[] = "version.major = 1\n";
|
|
|
|
|
2020-03-19 16:25:26 +00:00
|
|
|
wfd_config * config = wfd_config_load_string(syntax_error);
|
|
|
|
ASSERT_EQ(nullptr, config);
|
2020-03-09 22:25:47 +00:00
|
|
|
}
|
|
|
|
|
2020-03-16 20:50:31 +00:00
|
|
|
TEST(config, invalid_config_file)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(WFD_LOGLEVEL_ERROR, _, _)).Times(1);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
2020-03-19 16:25:26 +00:00
|
|
|
StrictMock<MockConfigBuilder> builder;
|
|
|
|
EXPECT_CALL(builder, create).Times(0);
|
|
|
|
EXPECT_CALL(builder, dispose(_)).Times(0);
|
2020-03-16 20:50:31 +00:00
|
|
|
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_file("invalid.conf");
|
|
|
|
ASSERT_EQ(nullptr, config);
|
2020-03-16 20:50:31 +00:00
|
|
|
}
|
|
|
|
|
2020-03-08 15:14:55 +00:00
|
|
|
TEST(config, invalid_major_version_too_low)
|
|
|
|
{
|
2020-03-08 19:29:08 +00:00
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(WFD_LOGLEVEL_ERROR, _, _)).Times(1);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
2020-03-19 16:25:26 +00:00
|
|
|
StrictMock<MockConfigBuilder> builder;
|
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
|
|
|
EXPECT_CALL(builder, dispose(_)).Times(1);
|
2020-03-15 20:48:45 +00:00
|
|
|
|
2020-03-08 15:14:55 +00:00
|
|
|
char const too_low[] = "version = { major = 0, minor = 0 }\n";
|
|
|
|
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config= wfd_config_load_string(too_low);
|
|
|
|
ASSERT_EQ(nullptr, config);
|
2020-03-08 15:14:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, invalid_major_version_too_high)
|
|
|
|
{
|
2020-03-08 19:29:08 +00:00
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(WFD_LOGLEVEL_ERROR, _, _)).Times(1);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
2020-03-19 16:25:26 +00:00
|
|
|
StrictMock<MockConfigBuilder> builder;
|
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
|
|
|
EXPECT_CALL(builder, dispose(_)).Times(1);
|
2020-03-15 20:48:45 +00:00
|
|
|
|
2020-03-08 15:14:55 +00:00
|
|
|
char const too_high[] = "version = { major = 2, minor = 0 }\n";
|
|
|
|
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(too_high);
|
|
|
|
ASSERT_EQ(nullptr, config);
|
2020-03-08 15:14:55 +00:00
|
|
|
}
|
|
|
|
|
2020-03-08 19:29:08 +00:00
|
|
|
TEST(config, invalid_missing_major_version)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(WFD_LOGLEVEL_ERROR, _, _)).Times(1);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
2020-03-19 16:25:26 +00:00
|
|
|
StrictMock<MockConfigBuilder> builder;
|
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
|
|
|
EXPECT_CALL(builder, dispose(_)).Times(1);
|
2020-03-15 20:48:45 +00:00
|
|
|
|
2020-03-08 19:29:08 +00:00
|
|
|
char const too_high[] = "version = { minor = 0 }\n";
|
|
|
|
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(too_high);
|
|
|
|
ASSERT_EQ(nullptr, config);
|
2020-03-08 19:29:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, invalid_missing_minor_version)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(WFD_LOGLEVEL_ERROR, _, _)).Times(1);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
2020-03-19 16:25:26 +00:00
|
|
|
StrictMock<MockConfigBuilder> builder;
|
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
|
|
|
EXPECT_CALL(builder, dispose(_)).Times(1);
|
2020-03-15 20:48:45 +00:00
|
|
|
|
2020-03-08 19:29:08 +00:00
|
|
|
char const too_high[] = "version = { major = 1 }\n";
|
|
|
|
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(too_high);
|
|
|
|
ASSERT_EQ(nullptr, config);
|
2020-03-08 19:29:08 +00:00
|
|
|
}
|
|
|
|
|
2020-03-08 15:14:55 +00:00
|
|
|
TEST(config, valid_older_minor)
|
|
|
|
{
|
2020-03-08 19:29:08 +00:00
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(WFD_LOGLEVEL_INFO, _, _)).Times(1);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
2020-03-19 16:25:26 +00:00
|
|
|
StrictMock<MockConfigBuilder> builder;
|
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
2020-03-08 15:14:55 +00:00
|
|
|
|
2020-03-15 20:48:45 +00:00
|
|
|
char const valid[] = "version = { major = 1, minor = -1 }\n";
|
2020-03-08 15:14:55 +00:00
|
|
|
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(valid);
|
|
|
|
ASSERT_NE(nullptr, config);
|
2020-03-08 15:14:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, valid_newer_minor)
|
|
|
|
{
|
2020-03-08 19:29:08 +00:00
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(WFD_LOGLEVEL_WARN, _, _)).Times(1);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
2020-03-19 16:25:26 +00:00
|
|
|
StrictMock<MockConfigBuilder> builder;
|
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
2020-03-09 22:59:36 +00:00
|
|
|
|
2020-03-15 20:48:45 +00:00
|
|
|
char const valid[] = "version = { major = 1, minor = 1 }\n";
|
2020-03-09 22:59:36 +00:00
|
|
|
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(valid);
|
|
|
|
ASSERT_NE(nullptr, config);
|
2020-03-09 22:59:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, vhost_name)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(_, _, _)).Times(0);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
2020-03-15 20:48:45 +00:00
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
2020-03-15 20:48:45 +00:00
|
|
|
EXPECT_CALL(builder, setServerVhostname(StrEq("some.host"))).Times(1);
|
|
|
|
|
2020-03-09 22:59:36 +00:00
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"server:\n"
|
|
|
|
"{\n"
|
|
|
|
" vhost_name = \"some.host\"\n"
|
|
|
|
"}\n"
|
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_NE(nullptr, config);
|
2020-03-09 22:59:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, port)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(_, _, _)).Times(0);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
2020-03-15 20:48:45 +00:00
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
2020-03-15 20:48:45 +00:00
|
|
|
EXPECT_CALL(builder, setServerPort(54321)).Times(1);
|
2020-03-09 22:59:36 +00:00
|
|
|
|
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"server:\n"
|
|
|
|
"{\n"
|
2020-03-15 20:48:45 +00:00
|
|
|
" port = 54321\n"
|
2020-03-09 22:59:36 +00:00
|
|
|
"}\n"
|
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_NE(nullptr, config);
|
2020-03-09 22:59:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, tls_certificate)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(_, _, _)).Times(0);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
2020-03-15 20:48:45 +00:00
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
2020-03-15 20:48:45 +00:00
|
|
|
EXPECT_CALL(builder, setServerCert(StrEq("/path/to/cert.pem"))).Times(1);
|
|
|
|
|
2020-03-09 22:59:36 +00:00
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"server:\n"
|
|
|
|
"{\n"
|
|
|
|
" tls:\n"
|
|
|
|
" {\n"
|
|
|
|
" certificate = \"/path/to/cert.pem\"\n"
|
|
|
|
" }\n"
|
|
|
|
"}\n"
|
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_NE(nullptr, config);
|
2020-03-09 22:59:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, tls_key)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(_, _, _)).Times(0);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
2020-03-15 20:48:45 +00:00
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
2020-03-15 20:48:45 +00:00
|
|
|
EXPECT_CALL(builder, setServerKey(StrEq("/path/to/key.pem"))).Times(1);
|
|
|
|
|
2020-03-09 22:59:36 +00:00
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"server:\n"
|
|
|
|
"{\n"
|
|
|
|
" tls:\n"
|
|
|
|
" {\n"
|
|
|
|
" key = \"/path/to/key.pem\"\n"
|
|
|
|
" }\n"
|
|
|
|
"}\n"
|
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_NE(nullptr, config);
|
2020-03-09 22:59:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, document_root)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(_, _, _)).Times(0);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
2020-03-15 20:48:45 +00:00
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
2020-03-15 20:48:45 +00:00
|
|
|
EXPECT_CALL(builder, setServerDocumentRoot(StrEq("/var/www"))).Times(1);
|
|
|
|
|
2020-03-09 22:59:36 +00:00
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"server:\n"
|
|
|
|
"{\n"
|
|
|
|
" document_root = \"/var/www\"\n"
|
|
|
|
"}\n"
|
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_NE(nullptr, config);
|
2020-03-09 22:59:36 +00:00
|
|
|
}
|
2020-03-16 20:50:31 +00:00
|
|
|
|
|
|
|
TEST(config, authentication)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(_, _, _)).Times(0);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
2020-03-18 09:17:17 +00:00
|
|
|
EXPECT_CALL(builder, addAuthProvider(_, _)).Times(1).WillOnce(Return(true));
|
2020-03-16 20:50:31 +00:00
|
|
|
|
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"authentication:\n"
|
2020-03-18 18:14:02 +00:00
|
|
|
"(\n"
|
|
|
|
" {\n"
|
|
|
|
" provider = \"test\"\n"
|
|
|
|
" settings: { }\n"
|
|
|
|
" }\n"
|
|
|
|
")\n"
|
2020-03-16 20:50:31 +00:00
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_NE(nullptr, config);
|
2020-03-16 20:50:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, failed_create_authenticator)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(_, _, _)).Times(0);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
|
|
|
EXPECT_CALL(builder, dispose(_)).Times(1);
|
2020-03-18 09:17:17 +00:00
|
|
|
EXPECT_CALL(builder, addAuthProvider(_, _)).Times(1).WillOnce(Return(false));
|
2020-03-16 20:50:31 +00:00
|
|
|
|
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"authentication:\n"
|
2020-03-18 18:14:02 +00:00
|
|
|
"(\n"
|
|
|
|
" {\n"
|
|
|
|
" provider = \"test\"\n"
|
|
|
|
" settings: { }\n"
|
|
|
|
" }\n"
|
|
|
|
")\n"
|
2020-03-16 20:50:31 +00:00
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_EQ(nullptr, config);
|
2020-03-16 20:50:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, failed_missing_auth_provider)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(WFD_LOGLEVEL_ERROR, _, _)).Times(1);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
|
|
|
EXPECT_CALL(builder, dispose(_)).Times(1);
|
2020-03-16 20:50:31 +00:00
|
|
|
|
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"authentication:\n"
|
2020-03-18 18:14:02 +00:00
|
|
|
"(\n"
|
|
|
|
" {\n"
|
|
|
|
" settings: { }\n"
|
|
|
|
" }\n"
|
|
|
|
")\n"
|
2020-03-16 20:50:31 +00:00
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_EQ(nullptr, config);
|
2020-03-16 20:50:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, failed_missing_auth_settings)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(WFD_LOGLEVEL_ERROR, _, _)).Times(1);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
|
|
|
EXPECT_CALL(builder, dispose(_)).Times(1);
|
2020-03-16 20:50:31 +00:00
|
|
|
|
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"authentication:\n"
|
2020-03-18 18:14:02 +00:00
|
|
|
"(\n"
|
|
|
|
" {\n"
|
|
|
|
" provider = \"test\"\n"
|
|
|
|
" }\n"
|
|
|
|
")\n"
|
2020-03-16 20:50:31 +00:00
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_EQ(nullptr, config);
|
2020-03-16 20:50:31 +00:00
|
|
|
}
|
2020-03-17 20:51:04 +00:00
|
|
|
|
|
|
|
TEST(config, filesystems)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(_, _, _)).Times(0);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
2020-03-17 20:51:04 +00:00
|
|
|
EXPECT_CALL(builder, addFilesystem(_, _)).Times(1).WillOnce(Return(true));
|
|
|
|
|
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"filesystems:\n"
|
|
|
|
"(\n"
|
|
|
|
" {name = \"foo\", mount_point = \"/tmp/test\" }\n"
|
|
|
|
")\n"
|
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_NE(nullptr, config);
|
2020-03-17 20:51:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, filesystems_empty)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(_, _, _)).Times(0);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
2020-03-17 20:51:04 +00:00
|
|
|
EXPECT_CALL(builder, addFilesystem(_, _)).Times(0);
|
|
|
|
|
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"filesystems:\n"
|
|
|
|
"(\n"
|
|
|
|
")\n"
|
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_NE(nullptr, config);
|
2020-03-17 20:51:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, filesystems_failed_add)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(_, _, _)).Times(0);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
|
|
|
EXPECT_CALL(builder, dispose(_)).Times(1);
|
2020-03-17 20:51:04 +00:00
|
|
|
EXPECT_CALL(builder, addFilesystem(_, _)).Times(1).WillOnce(Return(false));
|
|
|
|
|
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"filesystems:\n"
|
|
|
|
"(\n"
|
|
|
|
" {name = \"foo\", mount_point = \"/tmp/test\" }\n"
|
|
|
|
")\n"
|
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_EQ(nullptr, config);
|
2020-03-17 20:51:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, filesystems_failed_missing_name)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(WFD_LOGLEVEL_ERROR, _, _)).Times(1);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
|
|
|
EXPECT_CALL(builder, dispose(_)).Times(1);
|
2020-03-17 20:51:04 +00:00
|
|
|
EXPECT_CALL(builder, addFilesystem(_, _)).Times(0);
|
|
|
|
|
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"filesystems:\n"
|
|
|
|
"(\n"
|
|
|
|
" {mount_point = \"/tmp/test\" }\n"
|
|
|
|
")\n"
|
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_EQ(nullptr, config);
|
2020-03-17 20:51:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, filesystems_failed_missing_mountpoint)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(WFD_LOGLEVEL_ERROR, _, _)).Times(1);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
|
|
|
EXPECT_CALL(builder, dispose(_)).Times(1);
|
2020-03-17 20:51:04 +00:00
|
|
|
EXPECT_CALL(builder, addFilesystem(_, _)).Times(0);
|
|
|
|
|
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"filesystems:\n"
|
|
|
|
"(\n"
|
|
|
|
" {name = \"foo\"}\n"
|
|
|
|
")\n"
|
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_EQ(nullptr, config);
|
2020-03-17 20:51:04 +00:00
|
|
|
}
|
2020-03-18 16:33:31 +00:00
|
|
|
|
|
|
|
TEST(config, log)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(_, _, _)).Times(0);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
2020-03-18 16:33:31 +00:00
|
|
|
EXPECT_CALL(builder, setLogger(_, _, _)).Times(1).WillOnce(Return(true));
|
|
|
|
|
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"log:\n"
|
|
|
|
"{\n"
|
|
|
|
" provider = \"stderr\"\n"
|
|
|
|
" level = \"all\"\n"
|
|
|
|
"}\n"
|
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_NE(nullptr, config);
|
2020-03-18 16:33:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, log_fail_set_logger)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(_, _, _)).Times(0);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
|
|
|
EXPECT_CALL(builder, dispose(_)).Times(1);
|
2020-03-18 16:33:31 +00:00
|
|
|
EXPECT_CALL(builder, setLogger(_, _, _)).Times(1).WillOnce(Return(false));
|
|
|
|
|
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"log:\n"
|
|
|
|
"{\n"
|
|
|
|
" provider = \"stderr\"\n"
|
|
|
|
" level = \"all\"\n"
|
|
|
|
"}\n"
|
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_EQ(nullptr, config);
|
2020-03-18 16:33:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, log_fail_missing_provider)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(WFD_LOGLEVEL_ERROR, _, _)).Times(1);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
|
|
|
EXPECT_CALL(builder, dispose(_)).Times(1);
|
2020-03-18 16:33:31 +00:00
|
|
|
EXPECT_CALL(builder, setLogger(_, _, _)).Times(0);
|
|
|
|
|
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"log:\n"
|
|
|
|
"{\n"
|
|
|
|
" level = \"all\"\n"
|
|
|
|
"}\n"
|
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_EQ(nullptr, config);
|
2020-03-18 16:33:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, log_fail_missing_level)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(WFD_LOGLEVEL_ERROR, _, _)).Times(1);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
|
|
|
EXPECT_CALL(builder, dispose(_)).Times(1);
|
2020-03-18 16:33:31 +00:00
|
|
|
EXPECT_CALL(builder, setLogger(_, _, _)).Times(0);
|
|
|
|
|
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"log:\n"
|
|
|
|
"{\n"
|
|
|
|
" provider = \"stderr\"\n"
|
|
|
|
" level = \"fancy\"\n"
|
|
|
|
"}\n"
|
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_EQ(nullptr, config);
|
2020-03-18 16:33:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, log_fail_invalid_level)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(WFD_LOGLEVEL_ERROR, _, _)).Times(1);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
|
|
|
EXPECT_CALL(builder, dispose(_)).Times(1);
|
2020-03-18 16:33:31 +00:00
|
|
|
EXPECT_CALL(builder, setLogger(_, _, _)).Times(0);
|
|
|
|
|
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"log:\n"
|
|
|
|
"{\n"
|
|
|
|
" provider = \"stderr\"\n"
|
|
|
|
"}\n"
|
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_EQ(nullptr, config);
|
2020-03-18 16:33:31 +00:00
|
|
|
}
|
|
|
|
|
2020-03-19 11:42:47 +00:00
|
|
|
TEST(config, set_user)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(_, _, _)).Times(0);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
2020-03-19 11:42:47 +00:00
|
|
|
EXPECT_CALL(builder, setUser(_, _)).Times(1);
|
|
|
|
|
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"user:\n"
|
|
|
|
"{\n"
|
|
|
|
" name = \"webfused\"\n"
|
|
|
|
" group = \"webfused\"\n"
|
|
|
|
"}\n"
|
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_NE(nullptr, config);
|
2020-03-19 11:42:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, set_user_fail_missing_name)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(WFD_LOGLEVEL_ERROR, _, _)).Times(1);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
|
|
|
EXPECT_CALL(builder, dispose(_)).Times(1);
|
2020-03-19 11:42:47 +00:00
|
|
|
EXPECT_CALL(builder, setUser(_, _)).Times(0);
|
|
|
|
|
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"user:\n"
|
|
|
|
"{\n"
|
|
|
|
" group = \"webfused\"\n"
|
|
|
|
"}\n"
|
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_EQ(nullptr, config);
|
2020-03-19 11:42:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(config, set_user_fail_missing_group)
|
|
|
|
{
|
|
|
|
MockLogger logger;
|
|
|
|
EXPECT_CALL(logger, log(WFD_LOGLEVEL_ERROR, _, _)).Times(1);
|
|
|
|
EXPECT_CALL(logger, onclose()).Times(1);
|
|
|
|
|
|
|
|
StrictMock<MockConfigBuilder> builder;
|
2020-03-19 16:25:26 +00:00
|
|
|
EXPECT_CALL(builder, create).Times(1).WillOnce(Return(builder.getBuilder()));
|
|
|
|
EXPECT_CALL(builder, dispose(_)).Times(1);
|
2020-03-19 11:42:47 +00:00
|
|
|
EXPECT_CALL(builder, setUser(_, _)).Times(0);
|
|
|
|
|
|
|
|
char const config_text[] =
|
|
|
|
"version = { major = 1, minor = 0 }\n"
|
|
|
|
"user:\n"
|
|
|
|
"{\n"
|
|
|
|
" name = \"webfused\"\n"
|
|
|
|
"}\n"
|
|
|
|
;
|
2020-03-19 16:25:26 +00:00
|
|
|
struct wfd_config * config = wfd_config_load_string(config_text);
|
|
|
|
ASSERT_EQ(nullptr, config);
|
2020-03-19 11:42:47 +00:00
|
|
|
}
|