2
0
mirror of https://github.com/rehlds/rehlds.git synced 2025-01-16 00:28:20 +03:00

FlightRecorder: write all console and log messages to the flight log

Refactored tests
This commit is contained in:
dreamstalker 2015-06-28 21:15:11 +04:00
parent c0889990db
commit 8aac19ce00
26 changed files with 226 additions and 19 deletions

View File

@ -0,0 +1,22 @@
package org.rehlds.flightrec.decoders.rehlds;
import org.rehlds.flightrec.api.DecodedExtraData;
import org.rehlds.flightrec.api.FlightrecMessage;
import org.rehlds.flightrec.api.FlightrecMessageType;
import org.rehlds.flightrec.api.MessageDecoder;
import org.rehlds.flightrec.api.util.UtilSizeBuf;
public class AllocEntPrivateDataV2Decoder implements MessageDecoder {
@Override
public FlightrecMessageType getMessageType() {
return new FlightrecMessageType("rehlds", "AllocEntPrivateData", 2, false);
}
@Override
public DecodedExtraData decode(FlightrecMessage msg) {
UtilSizeBuf sb = msg.getDataSizebuf();
long ptr = sb.readUInt32();
long size = sb.readUInt32();
return DecodedExtraData.create("pPrivData", "0x" + Long.toHexString(ptr), "size", "" + size);
}
}

View File

@ -0,0 +1,22 @@
package org.rehlds.flightrec.decoders.rehlds;
import org.rehlds.flightrec.api.DecodedExtraData;
import org.rehlds.flightrec.api.FlightrecMessage;
import org.rehlds.flightrec.api.FlightrecMessageType;
import org.rehlds.flightrec.api.MessageDecoder;
import org.rehlds.flightrec.api.util.UtilSizeBuf;
public class LogV1Decoder implements MessageDecoder {
@Override
public FlightrecMessageType getMessageType() {
return new FlightrecMessageType("rehlds", "Log", 1, false);
}
@Override
public DecodedExtraData decode(FlightrecMessage msg) {
UtilSizeBuf sb = msg.getDataSizebuf();
String prefix = sb.readString();
String message = sb.readString();
return DecodedExtraData.create("prefix", prefix, "message", message);
}
}

View File

@ -11,5 +11,8 @@ public class RehldsDecodersModule extends SimpleDecoderModule {
registerDecoder(new AllocEntPrivateDataV1Decoder());
registerDecoder(new FrameV2Decoder());
registerDecoder(new LogV1Decoder());
registerDecoder(new AllocEntPrivateDataV2Decoder());
}
}

View File

@ -163,6 +163,10 @@ void setupToolchain(NativeBinarySpec b) {
cfg.singleDefines 'HOOK_ENGINE'
}
if (unitTestExecutable) {
cfg.singleDefines 'REHLDS_UNIT_TESTS'
}
if (rehldsFixes) {
cfg.singleDefines 'REHLDS_FIXES', 'REHLDS_CHECKS'
}

View File

@ -72,6 +72,10 @@ void Log_Printf(const char *fmt, ...)
Q_vsnprintf(&string[Q_strlen(string)], sizeof(string) - Q_strlen(string), fmt, argptr);
va_end(argptr);
#ifdef REHLDS_FLIGHT_REC
FR_Log("REHLDS_LOG", string);
#endif
if (g_psvs.log.net_log_ || firstLog != NULL)
{
if (g_psvs.log.net_log_)

View File

@ -1336,6 +1336,10 @@ void Con_Printf(const char *fmt, ...)
Q_vsnprintf(Dest, sizeof(Dest), fmt, va);
va_end(va);
#ifdef REHLDS_FLIGHT_REC
FR_Log("REHLDS_CON", Dest);
#endif
Sys_Printf("%s", Dest);
if (sv_redirected)
{
@ -1381,6 +1385,34 @@ void Con_SafePrintf(const char *fmt, ...)
}
/* <8e00b> ../engine/sys_dll.c:2459 */
#if defined(REHLDS_FIXES) && defined(REHLDS_FLIGHT_REC)
// Always print debug logs to the flight recorder
void Con_DPrintf(const char *fmt, ...)
{
va_list argptr;
va_start(argptr, fmt);
char Dest[4096];
Q_vsnprintf(Dest, sizeof(Dest), fmt, argptr);
va_end(argptr);
FR_Log("REHLDS_CONDBG", Dest);
if (developer.value != 0.0f)
{
#ifdef _WIN32
OutputDebugStringA(Dest);
if (con_debuglog)
Con_DebugLog("qconsole.log", "%s", Dest);
#else
vfprintf(stdout, "%s", Dest);
fflush(stdout);
#endif // _WIN32
}
}
#else //defined(REHLDS_FIXES) and defined(REHLDS_FLIGHT_REC)
void Con_DPrintf(const char *fmt, ...)
{
va_list argptr;
@ -1391,6 +1423,7 @@ void Con_DPrintf(const char *fmt, ...)
#ifdef _WIN32
char Dest[4096];
Q_vsnprintf(Dest, sizeof(Dest), fmt, argptr);
OutputDebugStringA(Dest);
if (con_debuglog)
Con_DebugLog("qconsole.log", "%s", Dest);
@ -1401,4 +1434,4 @@ void Con_DPrintf(const char *fmt, ...)
}
va_end(argptr);
}
#endif //defined(REHLDS_FIXES) and defined(REHLDS_FLIGHT_REC)

View File

@ -268,6 +268,7 @@
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release Play|Win32'">true</ExcludedFromBuild>
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release Swds Play|Win32'">true</ExcludedFromBuild>
</ClCompile>
<ClCompile Include="..\unittests\rehlds_tests_shared.cpp" />
<ClCompile Include="..\unittests\struct_offsets_tests.cpp">
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild>
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug Swds|Win32'">true</ExcludedFromBuild>
@ -546,6 +547,7 @@
<ClInclude Include="..\testsuite\player.h" />
<ClInclude Include="..\testsuite\recorder.h" />
<ClInclude Include="..\testsuite\testsuite.h" />
<ClInclude Include="..\unittests\rehlds_tests_shared.h" />
<ClInclude Include="..\version\version.h" />
</ItemGroup>
<ItemGroup>
@ -904,7 +906,7 @@
<WarningLevel>Level3</WarningLevel>
<Optimization>Disabled</Optimization>
<SDLCheck>true</SDLCheck>
<PreprocessorDefinitions>REHLDS_FLIGHT_REC;REHLDS_OPT_PEDANTIC;REHLDS_SELF;_BUILD_FROM_IDE;USE_BREAKPAD_HANDLER;DEDICATED;SWDS;_CRT_SECURE_NO_WARNINGS;_DEBUG;%(PreprocessorDefinitions)</PreprocessorDefinitions>
<PreprocessorDefinitions>REHLDS_FLIGHT_REC;REHLDS_OPT_PEDANTIC;REHLDS_SELF;REHLDS_UNIT_TESTS;_BUILD_FROM_IDE;USE_BREAKPAD_HANDLER;DEDICATED;SWDS;_CRT_SECURE_NO_WARNINGS;_DEBUG;%(PreprocessorDefinitions)</PreprocessorDefinitions>
<RuntimeLibrary>MultiThreadedDebug</RuntimeLibrary>
<PrecompiledHeader>Use</PrecompiledHeader>
<PrecompiledHeaderFile>precompiled.h</PrecompiledHeaderFile>
@ -940,7 +942,7 @@
<WarningLevel>Level3</WarningLevel>
<Optimization>Disabled</Optimization>
<SDLCheck>true</SDLCheck>
<PreprocessorDefinitions>REHLDS_FLIGHT_REC;REHLDS_OPT_PEDANTIC;REHLDS_FIXES;REHLDS_SELF;_BUILD_FROM_IDE;USE_BREAKPAD_HANDLER;DEDICATED;SWDS;_CRT_SECURE_NO_WARNINGS;_DEBUG;%(PreprocessorDefinitions)</PreprocessorDefinitions>
<PreprocessorDefinitions>REHLDS_FLIGHT_REC;REHLDS_OPT_PEDANTIC;REHLDS_FIXES;REHLDS_SELF;REHLDS_UNIT_TESTS;_BUILD_FROM_IDE;USE_BREAKPAD_HANDLER;DEDICATED;SWDS;_CRT_SECURE_NO_WARNINGS;_DEBUG;%(PreprocessorDefinitions)</PreprocessorDefinitions>
<RuntimeLibrary>MultiThreadedDebug</RuntimeLibrary>
<PrecompiledHeader>Use</PrecompiledHeader>
<PrecompiledHeaderFile>precompiled.h</PrecompiledHeaderFile>

View File

@ -340,6 +340,9 @@
<ClCompile Include="..\unittests\info_tests.cpp">
<Filter>unittests</Filter>
</ClCompile>
<ClCompile Include="..\unittests\rehlds_tests_shared.cpp">
<Filter>unittests</Filter>
</ClCompile>
</ItemGroup>
<ItemGroup>
<ClInclude Include="..\hookers\memory.h">
@ -1053,6 +1056,9 @@
<ClInclude Include="..\public\iosutil.h">
<Filter>public</Filter>
</ClInclude>
<ClInclude Include="..\unittests\rehlds_tests_shared.h">
<Filter>unittests</Filter>
</ClInclude>
</ItemGroup>
<ItemGroup>
<None Include="..\linux\appversion.sh">

View File

@ -116,6 +116,10 @@
inline void* sys_allocmem(unsigned int size) {
return VirtualAlloc(NULL, size, MEM_COMMIT, PAGE_READWRITE);
}
inline void sys_freemem(void* ptr, unsigned int size) {
VirtualFree(ptr, 0, MEM_RELEASE);
}
#else // _WIN32
#ifndef PAGESIZE
#define PAGESIZE 4096
@ -153,6 +157,9 @@
inline void* sys_allocmem(unsigned int size) {
return mmap(NULL, size, PROT_READ | PROT_WRITE, MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
}
inline void sys_freemem(void* ptr, unsigned int size) {
munmap(ptr, size);
}
#define WSAENOPROTOOPT ENOPROTOOPT

View File

@ -35,7 +35,7 @@
#include "model.h"
#define REHLDS_API_VERSION_MAJOR 1
#define REHLDS_API_VERSION_MINOR 1
#define REHLDS_API_VERSION_MINOR 2
//Steam_NotifyClientConnect hook
typedef IHookChain<qboolean, IGameClient*, const void*, unsigned int> IRehldsHook_Steam_NotifyClientConnect;
@ -165,6 +165,7 @@ struct RehldsFuncs_t {
double(*GetRealTime)();
int*(*GetMsgBadRead)();
cmd_source_t*(*GetCmdSource)();
void(*Log)(const char* prefix, const char* msg);
};
class IRehldsApi {

View File

@ -57,6 +57,11 @@ CRehldsFlightRecorder::CRehldsFlightRecorder() {
m_DataRegionPtr = m_DataRegion + DATA_REGION_HEADER;
}
CRehldsFlightRecorder::~CRehldsFlightRecorder() {
sys_freemem(m_MetaRegion, META_REGION_SIZE);
sys_freemem(m_DataRegion, DATA_REGION_SIZE);
}
void CRehldsFlightRecorder::InitHeadersContent() {
m_pMetaHeader->version = FLIGHT_RECORDER_VERSION;
m_pMetaHeader->regionSize = META_REGION_SIZE;

View File

@ -96,6 +96,7 @@ private:
public:
CRehldsFlightRecorder();
virtual ~CRehldsFlightRecorder();
void dump(const char* fname);
virtual void StartMessage(uint16 msg, bool entrance);

View File

@ -23,18 +23,27 @@ void FR_Init() {
g_FlightRecorder = new CRehldsFlightRecorder();
}
void FR_Shutdown() {
if (g_FlightRecorder) {
delete g_FlightRecorder;
g_FlightRecorder = NULL;
}
}
#ifdef REHLDS_FLIGHT_REC
uint16 g_FRMsg_Frame;
uint16 g_FRMsg_FreeEntPrivateData;
uint16 g_FRMsg_AllocEntPrivateData;
uint16 g_FRMsg_Log;
cvar_t rehlds_flrec_frame = { "rehlds_flrec_frame", "1", 0, 1.0f, NULL };
cvar_t rehlds_flrec_pvdata = { "rehlds_flrec_privdata", "1", 0, 1.0f, NULL };
void FR_CheckInit() {
#ifdef HOOK_ENGINE
if (!g_FlightRecorder)
#if defined(HOOK_ENGINE)
if (!g_FlightRecorder) {
FR_Init();
}
#endif
}
@ -57,6 +66,7 @@ void FR_Rehlds_Init() {
g_FRMsg_Frame = g_FlightRecorder->RegisterMessage("rehlds", "Frame", 2, true);
g_FRMsg_FreeEntPrivateData = g_FlightRecorder->RegisterMessage("rehlds", "FreeEntPrivateData", 1, false);
g_FRMsg_AllocEntPrivateData = g_FlightRecorder->RegisterMessage("rehlds", "AllocEntPrivateData", 2, false);
g_FRMsg_Log = g_FlightRecorder->RegisterMessage("rehlds", "Log", 1, false);
}
void FR_StartFrame(long frameCounter) {
@ -89,4 +99,15 @@ void FR_FreeEntPrivateData(void* data) {
g_FlightRecorder->EndMessage(g_FRMsg_FreeEntPrivateData, true);
}
void FR_Log(const char* prefix, const char* msg) {
FR_CheckInit();
if (g_FlightRecorder == NULL) {
return; //During server initialization some messages could be written in console/log before flightrecorder is initialized
}
g_FlightRecorder->StartMessage(g_FRMsg_Log, true);
g_FlightRecorder->WriteString(prefix);
g_FlightRecorder->WriteString(msg);
g_FlightRecorder->EndMessage(g_FRMsg_Log, true);
}
#endif //REHLDS_FLIGHT_REC

View File

@ -22,6 +22,7 @@
extern CRehldsFlightRecorder* g_FlightRecorder;
extern void FR_Init();
extern void FR_Shutdown();
#ifdef REHLDS_FLIGHT_REC
@ -40,5 +41,6 @@ extern void FR_StartFrame(long frameCounter);
extern void FR_EndFrame(long frameCounter);
extern void FR_FreeEntPrivateData(void* data);
extern void FR_AllocEntPrivateData(void* res, int size);
extern void FR_Log(const char* prefix, const char* msg);
#endif //REHLDS_FLIGHT_REC

View File

@ -55,6 +55,12 @@ cmd_source_t* GetCmdSource_api() {
return &cmd_source;
}
void Log_api(const char* prefix, const char* msg) {
#ifdef REHLDS_FLIGHT_REC
FR_Log(prefix, msg);
#endif
}
CRehldsServerStatic g_RehldsServerStatic;
CRehldsServerData g_RehldsServerData;
CRehldsHookchains g_RehldsHookchains;
@ -80,7 +86,8 @@ RehldsFuncs_t g_RehldsApiFuncs =
&GetBuildNumber_api,
&GetRealTime_api,
&GetMsgBadRead_api,
&GetCmdSource_api
&GetCmdSource_api,
&Log_api
};
sizebuf_t* GetNetMessage_api()

View File

@ -1,4 +1,5 @@
#include "precompiled.h"
#include "rehlds_tests_shared.h"
#include "cppunitlite/GradleAdapter.h"
int main(int argc, char* argv[]) {

View File

@ -1,4 +1,5 @@
#include "precompiled.h"
#include "rehlds_tests_shared.h"
#include "cppunitlite/TestHarness.h"
TEST(BitsWritingReading, MSG, 1000)

View File

@ -1,7 +1,9 @@
#include "precompiled.h"
#include "rehlds_tests_shared.h"
#include "cppunitlite/TestHarness.h"
TEST(CRC32C_Hash, CRC32C, 1000) {
Sys_CheckCpuInstructionsSupport();
CHECK("SSE4.2 Support", cpuinfo.sse4_2);

View File

@ -1,4 +1,5 @@
#include "precompiled.h"
#include "rehlds_tests_shared.h"
#include "cppunitlite/TestHarness.h"
#pragma pack(push, 1)
@ -239,6 +240,8 @@ void _DeltaSimpleTests(delta_t* delta, delta_simpletest_data_t* tests, int tests
TEST(MarkFieldsTest_Simple_Primitives, Delta, 1000) {
EngineInitializer engInitGuard;
delta_t* delta = _CreateTestDeltaDesc();
delta_simpletest_data_t testdata[] = {
@ -254,11 +257,11 @@ TEST(MarkFieldsTest_Simple_Primitives, Delta, 1000) {
{ "Float_1BlockCheck", 0x71, 0x71, true, "f_18", []() { dst2.f_18 = 0; } },
};
_DeltaSimpleTests(delta, testdata, ARRAYSIZE(testdata));
SV_Shutdown();
}
TEST(MarkFieldsTest_InterBlock, Delta, 1000) {
EngineInitializer engInitGuard;
delta_t* delta = _CreateTestDeltaDesc();
delta_simpletest_data_t testdata[] = {
@ -279,11 +282,11 @@ TEST(MarkFieldsTest_InterBlock, Delta, 1000) {
{ "Interblock2_val_3b", 0x71, 0x71, true, "i_5D", []() { dst2.i_5D &= 0x00FFFFFF; } },
};
_DeltaSimpleTests(delta, testdata, ARRAYSIZE(testdata));
SV_Shutdown();
}
TEST(MarkFieldsTest_Strings, Delta, 1000) {
EngineInitializer engInitGuard;
delta_t* delta = _CreateTestDeltaDesc();
delta_simpletest_data_t testdata[] = {
@ -296,11 +299,11 @@ TEST(MarkFieldsTest_Strings, Delta, 1000) {
{ "Str_case_check", 'c', 'c', true, "", []() { dst1.s_24[0] = 'C'; } },
};
_DeltaSimpleTests(delta, testdata, ARRAYSIZE(testdata));
SV_Shutdown();
}
TEST(MarkFieldsTest_TimeWindow, Delta, 1000) {
EngineInitializer engInitGuard;
#ifdef REHLDS_FIXES
bool rehlds_fixes = true;
#else
@ -315,12 +318,11 @@ TEST(MarkFieldsTest_TimeWindow, Delta, 1000) {
{ "TimeWindow_Above_Precision2", 'c', 'c', true, "w8_1C", []() { dst2.w8_1C = 0.1f; dst1.w8_1C = 0.12f; } },
};
_DeltaSimpleTests(delta, testdata, ARRAYSIZE(testdata));
SV_Shutdown();
}
TEST(TestDelta_Test, Delta, 1000)
{
TEST(TestDelta_Test, Delta, 1000) {
EngineInitializer engInitGuard;
delta_t* delta = _CreateTestDeltaDesc();
delta_test_struct_t testdata[4], from;
@ -363,6 +365,4 @@ TEST(TestDelta_Test, Delta, 1000)
if (tested != result[i])
rehlds_syserror("TestDelta_Test: returned bitcount %i is not equal to true value %i", tested, result[i]);
}
SV_Shutdown();
}

View File

@ -1,7 +1,10 @@
#include "precompiled.h"
#include "rehlds_tests_shared.h"
#include "cppunitlite/TestHarness.h"
TEST(PrefixedKeysRemove, Info, 1000) {
EngineInitializer engInitGuard;
struct testdata_t {
const char* inData;
const char* outData;
@ -31,6 +34,8 @@ TEST(PrefixedKeysRemove, Info, 1000) {
}
TEST(SetValueForStarKey, Info, 1000) {
EngineInitializer engInitGuard;
struct testdata_t {
const char* initialInfo;
const char* key;
@ -91,6 +96,8 @@ TEST(SetValueForStarKey, Info, 1000) {
}
TEST(RemoveKeyValue, Info, 1000) {
EngineInitializer engInitGuard;
struct testdata_t {
const char* initialInfo;
const char* key;
@ -124,6 +131,8 @@ TEST(RemoveKeyValue, Info, 1000) {
}
TEST(GetKeyValue, Info, 1000) {
EngineInitializer engInitGuard;
struct testdata_t {
const char* info;
const char* key;

View File

@ -1,4 +1,5 @@
#include "precompiled.h"
#include "rehlds_tests_shared.h"
#include "cppunitlite/TestHarness.h"
TEST(AngleVectorsTest, MathLib, 1000) {

View File

@ -0,0 +1,32 @@
#include "precompiled.h"
#include "rehlds_tests_shared.h"
static uint8 g_TestMemoryBuf[1024 * 1024 * 4];
void Tests_InitEngine() {
Memory_Init(g_TestMemoryBuf, sizeof(g_TestMemoryBuf));
FR_Init();
#ifdef REHLDS_FLIGHT_REC
FR_Rehlds_Init();
#endif //REHLDS_FLIGHT_REC
Cbuf_Init();
Cmd_Init();
Cvar_Init();
Cvar_CmdInit();
}
void Tests_ShutdownEngine() {
Cvar_Shutdown();
Cmd_Shutdown();
mainzone = NULL;
hunk_base = NULL;
hunk_size = 0;
FR_Shutdown();
SV_Shutdown();
}

View File

@ -0,0 +1,18 @@
#pragma once
#include "osconfig.h"
#include "engine.h"
extern void Tests_InitEngine();
extern void Tests_ShutdownEngine();
class EngineInitializer {
public:
EngineInitializer() {
Tests_InitEngine();
}
~EngineInitializer() {
Tests_ShutdownEngine();
}
};

View File

@ -1,4 +1,5 @@
#include "precompiled.h"
#include "rehlds_tests_shared.h"
#include "cppunitlite/TestHarness.h"
#pragma warning(push)

View File

@ -1,4 +1,5 @@
#include "precompiled.h"
#include "rehlds_tests_shared.h"
#include "cppunitlite/TestHarness.h"

View File

@ -1,4 +1,5 @@
#include "precompiled.h"
#include "rehlds_tests_shared.h"
#include "cppunitlite/TestHarness.h"
TEST(UTF8ToFromUChar32, UNICODE_STRTOOLS, 1000)