refactor: port GenericArgsTests to QtTests

This commit is contained in:
sithlord48
2025-04-05 19:17:03 -04:00
committed by Nick Bolton
parent d7506697c8
commit 29a86cfbac
4 changed files with 133 additions and 242 deletions

View File

@ -1,36 +0,0 @@
/*
* Deskflow -- mouse and keyboard sharing utility
* SPDX-FileCopyrightText: (C) 2014 - 2016 Symless Ltd.
* SPDX-License-Identifier: GPL-2.0-only WITH LicenseRef-OpenSSL-Exception
*/
#pragma once
#define TEST_ENV
#include "deskflow/App.h"
#include <gmock/gmock.h>
class MockApp : public App
{
public:
MockApp() : App(nullptr, nullptr)
{
}
MOCK_METHOD(void, help, (), (override));
MOCK_METHOD(void, loadConfig, (), (override));
MOCK_METHOD(bool, loadConfig, (const std::string &), (override));
MOCK_METHOD(const char *, daemonInfo, (), (const, override));
MOCK_METHOD(const char *, daemonName, (), (const, override));
MOCK_METHOD(void, parseArgs, (int, const char *const *), (override));
MOCK_METHOD(void, version, (), (override));
MOCK_METHOD(int, standardStartup, (int, char **), (override));
MOCK_METHOD(int, runInner, (int, char **, StartupFunc), (override));
MOCK_METHOD(void, startNode, (), (override));
MOCK_METHOD(int, mainLoop, (), (override));
MOCK_METHOD(int, foregroundStartup, (int, char **), (override));
MOCK_METHOD(deskflow::Screen *, createScreen, (), (override));
MOCK_METHOD(std::string, configSection, (), (const, override));
};

View File

@ -1,206 +0,0 @@
/*
* Deskflow -- mouse and keyboard sharing utility
* SPDX-FileCopyrightText: (C) 2014 - 2016 Symless Ltd.
* SPDX-License-Identifier: GPL-2.0-only WITH LicenseRef-OpenSSL-Exception
*/
#include "deskflow/ArgParser.h"
#include "deskflow/ArgsBase.h"
#include "test/mock/deskflow/MockApp.h"
#include <gtest/gtest.h>
using namespace deskflow;
using ::testing::_;
using ::testing::Invoke;
using ::testing::NiceMock;
bool g_helpShowed = false;
bool g_versionShowed = false;
void showMockHelp()
{
g_helpShowed = true;
}
void showMockVersion()
{
g_versionShowed = true;
}
class GenericArgsParsingTests : public ::testing::Test
{
public:
void SetUp()
{
m_argParser = new ArgParser(nullptr);
m_argParser->setArgsBase(argsBase);
}
void TearDown()
{
delete m_argParser;
}
static deskflow::ArgsBase argsBase;
ArgParser *m_argParser = nullptr;
};
deskflow::ArgsBase GenericArgsParsingTests::argsBase;
TEST_F(GenericArgsParsingTests, parseGenericArgs_logLevelCmd_setLogLevel)
{
int i = 1;
const int argc = 3;
const char *kLogLevelCmd[argc] = {"stub", "--debug", "DEBUG"};
m_argParser->parseGenericArgs(argc, kLogLevelCmd, i);
std::string logFilter(argsBase.m_logFilter);
EXPECT_EQ("DEBUG", logFilter);
EXPECT_EQ(2, i);
}
TEST_F(GenericArgsParsingTests, parseGenericArgs_logFileCmd_saveLogFilename)
{
int i = 1;
const int argc = 3;
const char *kLogFileCmd[argc] = {"stub", "--log", "mock_filename"};
m_argParser->parseGenericArgs(argc, kLogFileCmd, i);
std::string logFile(argsBase.m_logFile);
EXPECT_EQ("mock_filename", logFile);
EXPECT_EQ(2, i);
}
TEST_F(GenericArgsParsingTests, parseGenericArgs_logFileCmdWithSpace_saveLogFilename)
{
int i = 1;
const int argc = 3;
const char *kLogFileCmdWithSpace[argc] = {"stub", "--log", "mo ck_filename"};
m_argParser->parseGenericArgs(argc, kLogFileCmdWithSpace, i);
std::string logFile(argsBase.m_logFile);
EXPECT_EQ("mo ck_filename", logFile);
EXPECT_EQ(2, i);
}
TEST_F(GenericArgsParsingTests, parseGenericArgs_noDeamonCmd_daemonFalse)
{
int i = 1;
const int argc = 2;
const char *kNoDeamonCmd[argc] = {"stub", "-f"};
m_argParser->parseGenericArgs(argc, kNoDeamonCmd, i);
EXPECT_FALSE(argsBase.m_daemon);
EXPECT_EQ(1, i);
}
TEST_F(GenericArgsParsingTests, parseGenericArgs_deamonCmd_daemonTrue)
{
int i = 1;
const int argc = 2;
const char *kDeamonCmd[argc] = {"stub", "--daemon"};
m_argParser->parseGenericArgs(argc, kDeamonCmd, i);
EXPECT_EQ(true, argsBase.m_daemon);
EXPECT_EQ(1, i);
}
TEST_F(GenericArgsParsingTests, parseGenericArgs_nameCmd_saveName)
{
int i = 1;
const int argc = 3;
const char *kNameCmd[argc] = {"stub", "--name", "mock"};
m_argParser->parseGenericArgs(argc, kNameCmd, i);
EXPECT_EQ("mock", argsBase.m_name);
EXPECT_EQ(2, i);
}
TEST_F(GenericArgsParsingTests, parseGenericArgs_noRestartCmd_restartFalse)
{
int i = 1;
const int argc = 2;
const char *kNoRestartCmd[argc] = {"stub", "--no-restart"};
m_argParser->parseGenericArgs(argc, kNoRestartCmd, i);
EXPECT_FALSE(argsBase.m_restartable);
EXPECT_EQ(1, i);
}
TEST_F(GenericArgsParsingTests, parseGenericArgs_restartCmd_restartTrue)
{
int i = 1;
const int argc = 2;
const char *kRestartCmd[argc] = {"stub", "--restart"};
m_argParser->parseGenericArgs(argc, kRestartCmd, i);
EXPECT_EQ(true, argsBase.m_restartable);
EXPECT_EQ(1, i);
}
TEST_F(GenericArgsParsingTests, parseGenericArgs_backendCmd_rejected)
{
int i = 1;
const int argc = 2;
const char *kBackendCmd[argc] = {"stub", "-z"};
EXPECT_FALSE(m_argParser->parseGenericArgs(argc, kBackendCmd, i));
}
TEST_F(GenericArgsParsingTests, parseGenericArgs_noHookCmd_noHookTrue)
{
int i = 1;
const int argc = 2;
const char *kNoHookCmd[argc] = {"stub", "--no-hooks"};
m_argParser->parseGenericArgs(argc, kNoHookCmd, i);
EXPECT_EQ(true, argsBase.m_noHooks);
EXPECT_EQ(1, i);
}
TEST_F(GenericArgsParsingTests, parseGenericArgs_helpCmd_showHelp)
{
g_helpShowed = false;
int i = 1;
const int argc = 2;
const char *kHelpCmd[argc] = {"stub", "--help"};
NiceMock<MockApp> app;
ArgParser argParser(&app);
argParser.setArgsBase(argsBase);
ON_CALL(app, help()).WillByDefault(Invoke(showMockHelp));
argParser.parseGenericArgs(argc, kHelpCmd, i);
EXPECT_EQ(true, g_helpShowed);
EXPECT_EQ(1, i);
}
TEST_F(GenericArgsParsingTests, parseGenericArgs_versionCmd_showVersion)
{
g_versionShowed = false;
int i = 1;
const int argc = 2;
const char *kVersionCmd[argc] = {"stub", "--version"};
NiceMock<MockApp> app;
ArgParser argParser(&app);
argParser.setArgsBase(argsBase);
ON_CALL(app, version()).WillByDefault(Invoke(showMockVersion));
argParser.parseGenericArgs(argc, kVersionCmd, i);
EXPECT_EQ(true, g_versionShowed);
EXPECT_EQ(1, i);
}

View File

@ -18,6 +18,8 @@ void ArgParserTests::initTestCase()
{
m_arch.init();
m_log.setFilter(kDEBUG2);
static deskflow::ArgsBase base;
m_parser.setArgsBase(base);
}
void ArgParserTests::isArg()
@ -320,4 +322,125 @@ void ArgParserTests::deprecatedArg_crypoPass_false()
QCOMPARE(i, 1);
}
void ArgParserTests::generic_logLevel()
{
int i = 1;
const int argc = 3;
const char *kLogLevelCmd[argc] = {"stub", "--debug", "DEBUG"};
m_parser.parseGenericArgs(argc, kLogLevelCmd, i);
QCOMPARE(m_parser.argsBase().m_logFilter, "DEBUG");
QCOMPARE(i, 2);
}
void ArgParserTests::generic_logFile()
{
int i = 1;
const int argc = 3;
const char *kLogFileCmd[argc] = {"stub", "--log", "mock_filename"};
m_parser.parseGenericArgs(argc, kLogFileCmd, i);
QCOMPARE(m_parser.argsBase().m_logFile, "mock_filename");
QCOMPARE(i, 2);
}
void ArgParserTests::generic_logFileWithSpace()
{
int i = 1;
const int argc = 3;
const char *kLogFileCmdWithSpace[argc] = {"stub", "--log", "mo ck_filename"};
m_parser.parseGenericArgs(argc, kLogFileCmdWithSpace, i);
QCOMPARE(m_parser.argsBase().m_logFile, "mo ck_filename");
QCOMPARE(i, 2);
}
void ArgParserTests::generic_foreground()
{
int i = 1;
const int argc = 2;
const char *kNoDeamonCmd[argc] = {"stub", "-f"};
m_parser.parseGenericArgs(argc, kNoDeamonCmd, i);
QVERIFY(!m_parser.argsBase().m_daemon);
QCOMPARE(i, 1);
}
void ArgParserTests::generic_daemon()
{
int i = 1;
const int argc = 2;
const char *kDeamonCmd[argc] = {"stub", "--daemon"};
m_parser.parseGenericArgs(argc, kDeamonCmd, i);
QVERIFY(m_parser.argsBase().m_daemon);
QCOMPARE(i, 1);
}
void ArgParserTests::generic_name()
{
int i = 1;
const int argc = 3;
const char *kNameCmd[argc] = {"stub", "--name", "mock"};
// Somehow cause a dump if not made here.
ArgParser parser(nullptr);
deskflow::ArgsBase base;
parser.setArgsBase(base);
parser.parseGenericArgs(argc, kNameCmd, i);
QCOMPARE(base.m_name, "mock");
QCOMPARE(i, 2);
}
void ArgParserTests::generic_noRestart()
{
int i = 1;
const int argc = 2;
const char *kNoRestartCmd[argc] = {"stub", "--no-restart"};
m_parser.parseGenericArgs(argc, kNoRestartCmd, i);
QVERIFY(!m_parser.argsBase().m_restartable);
QCOMPARE(i, 1);
}
void ArgParserTests::generic_restart()
{
int i = 1;
const int argc = 2;
const char *kRestartCmd[argc] = {"stub", "--restart"};
m_parser.parseGenericArgs(argc, kRestartCmd, i);
QVERIFY(m_parser.argsBase().m_restartable);
QCOMPARE(i, 1);
}
void ArgParserTests::generic_unknown()
{
int i = 1;
const int argc = 2;
const char *kBackendCmd[argc] = {"stub", "-z"};
QVERIFY(!m_parser.parseGenericArgs(argc, kBackendCmd, i));
}
void ArgParserTests::generic_noHook()
{
int i = 1;
const int argc = 2;
const char *kNoHookCmd[argc] = {"stub", "--no-hooks"};
m_parser.parseGenericArgs(argc, kNoHookCmd, i);
QVERIFY(m_parser.argsBase().m_noHooks);
QCOMPARE(i, 1);
}
QTEST_MAIN(ArgParserTests)

View File

@ -35,6 +35,16 @@ private slots:
void client_badArgs();
void deprecatedArg_crypoPass_true();
void deprecatedArg_crypoPass_false();
void generic_logLevel();
void generic_logFile();
void generic_logFileWithSpace();
void generic_foreground();
void generic_daemon();
void generic_name();
void generic_noRestart();
void generic_restart();
void generic_unknown();
void generic_noHook();
private:
Arch m_arch;