view tests/js-logger/main.cpp @ 0:1158cffe5a5e

Initial import
author David Demelier <markand@malikania.fr>
date Mon, 08 Feb 2016 16:43:14 +0100
parents
children f8160d515a76
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-config.h>

#include <logger.h>

#include <js-irccd.h>
#include <js-logger.h>

using namespace irccd;

namespace {

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

} // !namespace

class TestLogger : public log::Interface {
public:
	void write(log::Level level, const std::string &line) noexcept override
	{
		switch (level) {
		case log::Level::Info:
			lineInfo = line;
			break;
		case log::Level::Warning:
			lineWarning = line;
			break;
		case log::Level::Debug:
			lineDebug = line;
			break;
		default:
			break;
		}
	}
};

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

	loadJsIrccd(ctx);
	loadJsLogger(ctx);

	try {
		ctx.putGlobal("\xff""\xff""name", "test");
		ctx.peval(js::Script{"Irccd.Logger.info(\"hello!\");"});

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

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

	loadJsIrccd(ctx);
	loadJsLogger(ctx);

	try {
		ctx.putGlobal("\xff""\xff""name", "test");
		ctx.peval(js::Script{"Irccd.Logger.warning(\"FAIL!\");"});

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

#if !defined(NDEBUG)

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

	loadJsIrccd(ctx);
	loadJsLogger(ctx);

	try {
		ctx.putGlobal("\xff""\xff""name", "test");
		ctx.peval(js::Script{"Irccd.Logger.debug(\"starting\");"});

		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();
}