File: mock_vstd_CLoggerBase.h

package info (click to toggle)
vcmi 1.6.5%2Bdfsg-2
  • links: PTS, VCS
  • area: contrib
  • in suites: forky, sid, trixie
  • size: 32,060 kB
  • sloc: cpp: 238,971; python: 265; sh: 224; xml: 157; ansic: 78; objc: 61; makefile: 49
file content (44 lines) | stat: -rw-r--r-- 1,008 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
/*
 * mock_vstd_CLoggerBase.h, part of VCMI engine
 *
 * Authors: listed in file AUTHORS in main folder
 *
 * License: GNU General Public License v2.0 or later
 * Full text of license available in license.txt file, in main folder
 *
 */

#pragma once


class LoggerMock : public vstd::CLoggerBase
{
public:
	void log(ELogLevel::ELogLevel level, const std::string & message) const override
	{
		//TODO: save last few normal messages and add to gtest error if VCMI error logged
		switch(level)
		{
		case ELogLevel::ERROR:
		case ELogLevel::WARN:
			ADD_FAILURE() << message;
			break;
		case ELogLevel::INFO:
			break;
		case ELogLevel::DEBUG:
			break;
		case ELogLevel::TRACE:
			break;
		}
	}

	void log(ELogLevel::ELogLevel level, const boost::format & fmt) const override
	{
		this->log(level, fmt.str());
	}

	bool isDebugEnabled() const override {return true;}
	bool isTraceEnabled() const override {return true;}
	ELogLevel::ELogLevel getEffectiveLevel() const override {return ELogLevel::TRACE;}
};