Browse Source

Change old mixed collection tests into new ones

pull/8/head
Anton Tarasenko 2 years ago
parent
commit
e2abcb3fd4
  1. 47
      sources/Data/Collections/Tests/TEST_CollectionsMixed.uc

47
sources/Data/Collections/Tests/TEST_CollectionsMixed.uc

@ -1,6 +1,6 @@
/** /**
* Set of tests for `AssociativeArray` class. * Set of tests for `ArrayList` and `HashTable` classes.
* Copyright 2020 Anton Tarasenko * Copyright 2022 Anton Tarasenko
*------------------------------------------------------------------------------ *------------------------------------------------------------------------------
* This file is part of Acedia. * This file is part of Acedia.
* *
@ -27,16 +27,14 @@ protected static function TESTS()
Context("Testing accessing collections by JSON pointers."); Context("Testing accessing collections by JSON pointers.");
Test_GetBy(); Test_GetBy();
Test_GetTypeBy(); Test_GetTypeBy();
Context("Testing erasing collections with keys via `Empty()` method.");
Test_EmptyWithKeys();
} }
protected static function Test_GetBy() protected static function Test_GetBy()
{ {
local AcediaObject result; local AcediaObject result;
local AssociativeArray obj; local HashTable obj;
Issue("`GetItemBy()` does not return correct objects."); Issue("`GetItemBy()` does not return correct objects.");
obj = __().json.ParseObjectWith( obj = __().json.ParseHashTableWith(
__().text.ParseString(default.complexJSONObject)); __().text.ParseString(default.complexJSONObject));
TEST_ExpectTrue(obj.GetItemBy(P("")) == obj); TEST_ExpectTrue(obj.GetItemBy(P("")) == obj);
result = obj.GetItemBy(P("/innerObject/array/1")); result = obj.GetItemBy(P("/innerObject/array/1"));
@ -55,7 +53,7 @@ protected static function Test_GetBy()
TEST_ExpectNotNone(IntBox(result)); TEST_ExpectNotNone(IntBox(result));
TEST_ExpectTrue(IntBox(result).Get() == 324532); TEST_ExpectTrue(IntBox(result).Get() == 324532);
TEST_ExpectNotNone( TEST_ExpectNotNone(
DynamicArray(obj.GetItemBy(P("/innerObject/array")))); ArrayList(obj.GetItemBy(P("/innerObject/array"))));
Issue("`GetItemBy()` does not return `none` for incorrect pointers"); Issue("`GetItemBy()` does not return `none` for incorrect pointers");
TEST_ExpectNone(obj.GetItemBy(P("//"))); TEST_ExpectNone(obj.GetItemBy(P("//")));
@ -66,14 +64,14 @@ protected static function Test_GetBy()
protected static function Test_GetTypeBy() protected static function Test_GetTypeBy()
{ {
local AssociativeArray obj; local HashTable obj;
obj = __().json.ParseObjectWith( obj = __().json.ParseHashTableWith(
__().text.ParseString(default.complexJSONObject)); __().text.ParseString(default.complexJSONObject));
obj.SetItem(P("byte"), __().ref.byte(56)); obj.SetItem(P("byte"), __().ref.byte(56));
Issue("`Get<Type>By()` methods do not return correct" Issue("`Get<Type>By()` methods do not return correct"
@ "existing values."); @ "existing values.");
TEST_ExpectTrue(obj.GetAssociativeArrayBy(P("")) == obj); TEST_ExpectTrue(obj.GetHashTableBy(P("")) == obj);
TEST_ExpectNotNone(obj.GetDynamicArrayBy(P("/innerObject/array"))); TEST_ExpectNotNone(obj.GetArrayListBy(P("/innerObject/array")));
TEST_ExpectTrue( TEST_ExpectTrue(
obj.GetBoolBy(P("/innerObject/array/1"), true) obj.GetBoolBy(P("/innerObject/array/1"), true)
== false); == false);
@ -98,33 +96,6 @@ protected static function Test_GetTypeBy()
TEST_ExpectNone(obj.GetTextBy(P(""))); TEST_ExpectNone(obj.GetTextBy(P("")));
} }
protected static function Test_EmptyWithKeys()
{
local Text outerKey, innerKey1, innerKey2, innerKey3;
local DynamicArray middleArray;
local AssociativeArray outerObject, innerObject1, innerObject2;
outerKey = __().text.FromString("first");
innerKey1 = __().text.FromString("third?");
innerKey2 = __().text.FromString("Or not?");
innerKey3 = __().text.FromString("Like hell if I know!!!1111");
outerObject = __().collections.EmptyAssociativeArray();
innerObject1 = __().collections.EmptyAssociativeArray();
innerObject2 = __().collections.EmptyAssociativeArray();
middleArray = __().collections.EmptyDynamicArray();
innerObject1.SetItem(innerKey1, __().box.int(4));
innerObject1.SetItem(innerKey2, __().box.float(-4.6));
innerObject2.SetItem(innerKey2, __().ref.bool(true));
innerObject2.SetItem(innerKey3, none);
middleArray.AddItem(innerObject1).AddItem(innerObject2);
outerObject.SetItem(outerKey, middleArray);
outerObject.Empty(true);
Issue("Collection keys are not deallocated by `Empty(true)` method");
TEST_ExpectFalse(outerKey.IsAllocated());
TEST_ExpectFalse(innerKey1.IsAllocated());
TEST_ExpectFalse(innerKey2.IsAllocated());
TEST_ExpectFalse(innerKey3.IsAllocated());
}
defaultproperties defaultproperties
{ {
caseGroup = "Collections" caseGroup = "Collections"

Loading…
Cancel
Save