Adds a couple of helper functions for battles to run turns, prettify outputs.

This commit is contained in:
2021-08-24 21:19:44 +02:00
parent c821e6f53b
commit 1e36f8f5e3
7 changed files with 1031 additions and 14 deletions

View File

@@ -12,10 +12,7 @@ private:
size_t Line;
};
static RequirementData GetRequirementData() {
auto* ctx = asGetActiveContext();
TestEnvironment* env = static_cast<TestEnvironment*>(ctx->GetUserData());
env->AssertionCount += 1;
static RequirementData GetRequirementData(asIScriptContext* ctx) {
auto filename = ctx->GetFunction()->GetScriptSectionName();
auto line = ctx->GetLineNumber();
return RequirementData{
@@ -25,8 +22,12 @@ private:
}
static bool Require(bool value) {
auto* ctx = asGetActiveContext();
TestEnvironment* env = static_cast<TestEnvironment*>(ctx->GetUserData());
env->TotalRequirements += 1;
if (!value) {
auto data = GetRequirementData();
env->FailedRequirements += 1;
auto data = GetRequirementData(ctx);
throw RequirementFailed(data.FileName, data.Line);
}
return true;
@@ -41,8 +42,12 @@ private:
}
static bool RequireEqualsI32(i32 expected, i32 actual) {
auto* ctx = asGetActiveContext();
TestEnvironment* env = static_cast<TestEnvironment*>(ctx->GetUserData());
env->TotalRequirements += 1;
if (expected != actual) {
auto data = GetRequirementData();
env->FailedRequirements += 1;
auto data = GetRequirementData(ctx);
GetEqualityMessage(expected, actual);
throw RequirementFailed(data.FileName, data.Line, eqMsg);
}
@@ -50,8 +55,11 @@ private:
}
static bool RequireEqualsString(const std::string& expected, const std::string& actual) {
auto* ctx = asGetActiveContext();
TestEnvironment* env = static_cast<TestEnvironment*>(ctx->GetUserData());
if (expected != actual) {
auto data = GetRequirementData();
env->FailedRequirements += 1;
auto data = GetRequirementData(ctx);
std::string eqMsg;
{
std::ostringstream ss;