Add testing to Aliases subsystem
This commit is contained in:
parent
27c88b8707
commit
5a14bb6d2c
27
sources/Core/Aliases/Tests/MockAliasSource.uc
Normal file
27
sources/Core/Aliases/Tests/MockAliasSource.uc
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
/**
|
||||||
|
* Source intended for testing aliases.
|
||||||
|
* Copyright 2020 Anton Tarasenko
|
||||||
|
*------------------------------------------------------------------------------
|
||||||
|
* This file is part of Acedia.
|
||||||
|
*
|
||||||
|
* Acedia is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Acedia is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with Acedia. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
class MockAliasSource extends AliasSource
|
||||||
|
config(AcediaAliases_Tests);
|
||||||
|
|
||||||
|
defaultproperties
|
||||||
|
{
|
||||||
|
configName = "AcediaAliases_Tests"
|
||||||
|
aliasesClass = class'MockAliases'
|
||||||
|
}
|
27
sources/Core/Aliases/Tests/MockAliases.uc
Normal file
27
sources/Core/Aliases/Tests/MockAliases.uc
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
/**
|
||||||
|
* Per-object-configuration intended for testing aliases.
|
||||||
|
* Copyright 2020 Anton Tarasenko
|
||||||
|
*------------------------------------------------------------------------------
|
||||||
|
* This file is part of Acedia.
|
||||||
|
*
|
||||||
|
* Acedia is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Acedia is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with Acedia. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
class MockAliases extends Aliases
|
||||||
|
perObjectConfig
|
||||||
|
config(AcediaAliases_Tests);
|
||||||
|
|
||||||
|
defaultproperties
|
||||||
|
{
|
||||||
|
sourceClass = class'MockAliasSource'
|
||||||
|
}
|
@ -22,29 +22,109 @@ class TEST_Aliases extends TestCase
|
|||||||
|
|
||||||
protected static function TESTS()
|
protected static function TESTS()
|
||||||
{
|
{
|
||||||
local string result;
|
Test_AliasHash();
|
||||||
Context("Testing Aliases loading.");
|
Test_AliasLoading();
|
||||||
Issue("`Try` cannot resolve correct alias");
|
}
|
||||||
TEST_ExpectTrue(_().alias.Try("test", "Ford") == "car");
|
|
||||||
TEST_ExpectTrue(_().alias.Try("test", "Delorean") == "car");
|
|
||||||
TEST_ExpectTrue(_().alias.Try("test", "HardToBeAGod") == "scifi");
|
|
||||||
|
|
||||||
Issue("`Resolve` cannot resolve correct alias");
|
protected static function Test_AliasLoading()
|
||||||
_().alias.Resolve("test", "Ford", result);
|
{
|
||||||
TEST_ExpectTrue(result == "car");
|
Context("Testing loading aliases from a mock object `MockAliasSource`.");
|
||||||
_().alias.Resolve("test", "Audi", result);
|
SubTest_AliasLoadingCorrect();
|
||||||
TEST_ExpectTrue(result == "car");
|
SubTest_AliasLoadingIncorrect();
|
||||||
_().alias.Resolve("test", "Spice", result);
|
}
|
||||||
TEST_ExpectTrue(result == "scifi");
|
|
||||||
|
|
||||||
Issue("`Try` does not return original alias for non-existing alias record");
|
protected static function SubTest_AliasLoadingCorrect()
|
||||||
TEST_ExpectTrue(_().alias.Try("test", "AllFiction") == "AllFiction");
|
{
|
||||||
|
local AliasSource source;
|
||||||
|
local string outValue;
|
||||||
|
|
||||||
Issue("`Resolve` reports success when it failed");
|
Issue("`Resolve()` fails to return alias that should be loaded.");
|
||||||
TEST_ExpectFalse(_().alias.Resolve("test", "KarmicJustice", result));
|
source = _().alias.GetCustomSource(class'MockAliasSource');
|
||||||
|
TEST_ExpectTrue(source.Resolve("Global", outValue));
|
||||||
|
TEST_ExpectTrue(outValue == "value");
|
||||||
|
TEST_ExpectTrue(source.Resolve("ford", outValue));
|
||||||
|
TEST_ExpectTrue(outValue == "car");
|
||||||
|
|
||||||
Issue("`Resolve` reports failure when it succeeds");
|
Issue("`Try()` fails to return alias that should be loaded.");
|
||||||
TEST_ExpectTrue(_().alias.Resolve("test", "Delorean", result));
|
TEST_ExpectTrue(source.Try("question") == "response");
|
||||||
|
TEST_ExpectTrue(source.Try("delorean") == "car");
|
||||||
|
|
||||||
|
Issue("`ContainsAlias()` reports alias, that should be present,"
|
||||||
|
@ "as missing.");
|
||||||
|
TEST_ExpectTrue(source.ContainsAlias("Global"));
|
||||||
|
TEST_ExpectTrue(source.ContainsAlias("audi"));
|
||||||
|
|
||||||
|
Issue("Aliases in per-object-configs incorrectly handle ':'.");
|
||||||
|
TEST_ExpectTrue(source.Try("HardToBeAGod") == "sci.fi");
|
||||||
|
|
||||||
|
Issue("Aliases with empty values in alias name or their value are handled"
|
||||||
|
@ "incorrectly.");
|
||||||
|
TEST_ExpectTrue(source.Try("") == "empty");
|
||||||
|
TEST_ExpectTrue(source.Try("also") == "");
|
||||||
|
}
|
||||||
|
|
||||||
|
protected static function SubTest_AliasLoadingIncorrect()
|
||||||
|
{
|
||||||
|
local AliasSource source;
|
||||||
|
local string outValue;
|
||||||
|
Context("Testing loading aliases from a mock object `MockAliasSource`.");
|
||||||
|
Issue("`AliasAPI` cannot return value custom source.");
|
||||||
|
source = _().alias.GetCustomSource(class'MockAliasSource');
|
||||||
|
TEST_ExpectNotNone(source);
|
||||||
|
|
||||||
|
Issue("`Resolve()` reports success of finding inexistent alias.");
|
||||||
|
source = _().alias.GetCustomSource(class'MockAliasSource');
|
||||||
|
TEST_ExpectFalse(source.Resolve("noSuchThing", outValue));
|
||||||
|
|
||||||
|
Issue("`Try()` does not return given value for non-existent alias.");
|
||||||
|
TEST_ExpectTrue(source.Try("TheHellIsThis") == "TheHellIsThis");
|
||||||
|
|
||||||
|
Issue("`ContainsAlias()` reports inexistent alias as present.");
|
||||||
|
TEST_ExpectFalse(source.ContainsAlias("FordК"));
|
||||||
|
}
|
||||||
|
|
||||||
|
protected static function Test_AliasHash()
|
||||||
|
{
|
||||||
|
Context("Testing `AliasHasher`.");
|
||||||
|
SubTest_AliasHashInsertingRemoval();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected static function SubTest_AliasHashInsertingRemoval()
|
||||||
|
{
|
||||||
|
local AliasHash hasher;
|
||||||
|
local string outValue;
|
||||||
|
hasher = new class'AliasHash';
|
||||||
|
hasher.Initialize();
|
||||||
|
Issue("`AliasHash` cannot properly store added aliases.");
|
||||||
|
hasher.Insert("alias", "value").Insert("one", "more");
|
||||||
|
TEST_ExpectTrue(hasher.Contains("alias"));
|
||||||
|
TEST_ExpectTrue(hasher.Contains("one"));
|
||||||
|
TEST_ExpectTrue(hasher.Find("alias", outValue));
|
||||||
|
TEST_ExpectTrue(outValue == "value");
|
||||||
|
TEST_ExpectTrue(hasher.Find("one", outValue));
|
||||||
|
TEST_ExpectTrue(outValue == "more");
|
||||||
|
|
||||||
|
Issue("`AliasHash` reports hashing aliases that never were hashed.");
|
||||||
|
TEST_ExpectFalse(hasher.Contains("alia"));
|
||||||
|
|
||||||
|
Issue("`AliasHash` cannot properly remove stored aliases.");
|
||||||
|
hasher.Remove("alias");
|
||||||
|
TEST_ExpectFalse(hasher.Contains("alias"));
|
||||||
|
TEST_ExpectTrue(hasher.Contains("one"));
|
||||||
|
TEST_ExpectFalse(hasher.Find("alias", outValue));
|
||||||
|
outValue = "wrong";
|
||||||
|
TEST_ExpectTrue(hasher.Find("one", outValue));
|
||||||
|
TEST_ExpectTrue(outValue == "more");
|
||||||
|
|
||||||
|
Issue("`InsertIfMissing()` function cannot properly store added aliases.");
|
||||||
|
TEST_ExpectTrue(hasher.InsertIfMissing("another", "var", outValue));
|
||||||
|
TEST_ExpectTrue(hasher.Find("another", outValue));
|
||||||
|
TEST_ExpectTrue(outValue == "var");
|
||||||
|
|
||||||
|
Issue("`InsertIfMissing()` function incorrectly resolves a conflict with"
|
||||||
|
@ "an existing value.");
|
||||||
|
TEST_ExpectFalse(hasher.InsertIfMissing("one", "something", outValue));
|
||||||
|
TEST_ExpectTrue(outValue == "more");
|
||||||
}
|
}
|
||||||
|
|
||||||
defaultproperties
|
defaultproperties
|
||||||
|
Reference in New Issue
Block a user