view tests/js-logger/main.cpp @ 105:378fdc2c7b56

Irccd: cleanup logging system, #485
author David Demelier <markand@malikania.fr>
date Wed, 27 Apr 2016 12:38:18 +0200
parents 1125d90b3b44
children 1ed760f6e0c6
line wrap: on
line source

/*
 * main.cpp -- test Irccd.Logger API
 *
 * Copyright (c) 2013-2016 David Demelier <markand@malikania.fr>
 *
 * Permission to use, copy, modify, and/or distribute this software for any
 * purpose with or without fee is hereby granted, provided that the above
 * copyright notice and this permission notice appear in all copies.
 *
 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
 */

#include <gtest/gtest.h>

#include <irccd/sysconfig.hpp>

#include <irccd/js-irccd.hpp>
#include <irccd/js-logger.hpp>
#include <irccd/logger.hpp>

using namespace irccd;

namespace {

std::string lineInfo;
std::string lineWarning;
std::string lineDebug;

} // !namespace

class TestLogger : public log::Interface {
public:
	void info(const std::string &line) override
	{
		lineInfo = line;
	}

	void warning(const std::string &line) override
	{
		lineWarning = line;
	}

	void debug(const std::string &line) override
	{
		lineDebug = line;
	}
};

TEST(TestJsLogger, info)
{
	duk::Context ctx;

	loadJsIrccd(ctx);
	loadJsLogger(ctx);

	try {
		duk::putGlobal(ctx, "\xff""\xff""name", "test");

		if (duk::pevalString(ctx, "Irccd.Logger.info(\"hello!\");") != 0)
			throw duk::error(ctx, -1);

		ASSERT_EQ("plugin test: hello!", lineInfo);
	} catch (const std::exception &ex) {
		FAIL() << ex.what();
	}
}

TEST(TestJsLogger, warning)
{
	duk::Context ctx;

	loadJsIrccd(ctx);
	loadJsLogger(ctx);

	try {
		duk::putGlobal(ctx, "\xff""\xff""name", "test");

		if (duk::pevalString(ctx, "Irccd.Logger.warning(\"FAIL!\");") != 0)
			throw duk::error(ctx, -1);

		ASSERT_EQ("plugin test: FAIL!", lineWarning);
	} catch (const std::exception &ex) {
		FAIL() << ex.what();
	}
}

#if !defined(NDEBUG)

TEST(TestJsLogger, debug)
{
	duk::Context ctx;

	loadJsIrccd(ctx);
	loadJsLogger(ctx);

	try {
		duk::putGlobal(ctx, "\xff""\xff""name", "test");

		if (duk::pevalString(ctx, "Irccd.Logger.debug(\"starting\");") != 0)
			throw duk::error(ctx, -1);

		ASSERT_EQ("plugin test: starting", lineDebug);
	} catch (const std::exception &ex) {
		FAIL() << ex.what();
	}
}

#endif

int main(int argc, char **argv)
{
	testing::InitGoogleTest(&argc, argv);

	log::setVerbose(true);
	log::setInterface(std::make_unique<TestLogger>());

	return RUN_ALL_TESTS();
}