mirror of
https://gitee.com/openharmony/arkcompiler_ets_runtime
synced 2024-10-07 08:03:29 +00:00
22fe6190c6
Signed-off-by: hwx1163501 <hanjing35@huawei.com> issue:https://gitee.com/openharmony/arkcompiler_ets_runtime/issues/I7163U
477 lines
21 KiB
C++
477 lines
21 KiB
C++
/*
|
|
* Copyright (c) 2022 Huawei Device Co., Ltd.
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#include "ecmascript/ecma_string.h"
|
|
#include "ecmascript/containers/containers_private.h"
|
|
#include "ecmascript/ecma_string.h"
|
|
#include "ecmascript/ecma_vm.h"
|
|
#include "ecmascript/global_env.h"
|
|
#include "ecmascript/js_api/js_api_lightweightmap.h"
|
|
#include "ecmascript/js_api/js_api_lightweightmap_iterator.h"
|
|
#include "ecmascript/js_function.h"
|
|
#include "ecmascript/js_handle.h"
|
|
#include "ecmascript/js_iterator.h"
|
|
#include "ecmascript/js_object-inl.h"
|
|
#include "ecmascript/js_tagged_value.h"
|
|
#include "ecmascript/object_factory.h"
|
|
#include "ecmascript/tests/test_helper.h"
|
|
|
|
using namespace panda;
|
|
|
|
using namespace panda::ecmascript;
|
|
|
|
using namespace panda::ecmascript::containers;
|
|
|
|
namespace panda::test {
|
|
class JSAPILightWeightMapTest : public testing::Test {
|
|
public:
|
|
const static int DEFAULT_SIZE = 8;
|
|
static void SetUpTestCase()
|
|
{
|
|
GTEST_LOG_(INFO) << "SetUpTestCase";
|
|
}
|
|
|
|
static void TearDownTestCase()
|
|
{
|
|
GTEST_LOG_(INFO) << "TearDownCase";
|
|
}
|
|
|
|
void SetUp() override
|
|
{
|
|
TestHelper::CreateEcmaVMWithScope(instance, thread, scope);
|
|
}
|
|
|
|
void TearDown() override
|
|
{
|
|
TestHelper::DestroyEcmaVMWithScope(instance, scope);
|
|
}
|
|
|
|
EcmaVM *instance {nullptr};
|
|
ecmascript::EcmaHandleScope *scope {nullptr};
|
|
JSThread *thread {nullptr};
|
|
|
|
protected:
|
|
JSAPILightWeightMap *CreateLightWeightMap()
|
|
{
|
|
JSHandle<GlobalEnv> env = thread->GetEcmaVM()->GetGlobalEnv();
|
|
ObjectFactory *factory = thread->GetEcmaVM()->GetFactory();
|
|
|
|
JSHandle<JSTaggedValue> globalObject = env->GetJSGlobalObject();
|
|
JSHandle<JSTaggedValue> key(factory->NewFromASCII("ArkPrivate"));
|
|
JSHandle<JSTaggedValue> value = JSObject::GetProperty(thread,
|
|
JSHandle<JSTaggedValue>(globalObject), key).GetValue();
|
|
|
|
auto objCallInfo = TestHelper::CreateEcmaRuntimeCallInfo(thread, JSTaggedValue::Undefined(), 6);
|
|
objCallInfo->SetFunction(JSTaggedValue::Undefined());
|
|
objCallInfo->SetThis(value.GetTaggedValue());
|
|
objCallInfo->SetCallArg(0, JSTaggedValue(static_cast<int>(containers::ContainerTag::LightWeightMap)));
|
|
|
|
auto prev = TestHelper::SetupFrame(thread, objCallInfo);
|
|
JSHandle<JSTaggedValue> constructor =
|
|
JSHandle<JSTaggedValue>(thread, containers::ContainersPrivate::Load(objCallInfo));
|
|
TestHelper::TearDownFrame(thread, prev);
|
|
JSHandle<JSAPILightWeightMap> lightWeightMap = JSHandle<JSAPILightWeightMap>::
|
|
Cast(factory->NewJSObjectByConstructor(JSHandle<JSFunction>(constructor), constructor));
|
|
JSHandle<JSTaggedValue> hashArray = JSHandle<JSTaggedValue>(factory->NewTaggedArray(DEFAULT_SIZE));
|
|
JSHandle<JSTaggedValue> keyArray = JSHandle<JSTaggedValue>(factory->NewTaggedArray(DEFAULT_SIZE));
|
|
JSHandle<JSTaggedValue> valueArray = JSHandle<JSTaggedValue>(factory->NewTaggedArray(DEFAULT_SIZE));
|
|
lightWeightMap->SetHashes(thread, hashArray);
|
|
lightWeightMap->SetKeys(thread, keyArray);
|
|
lightWeightMap->SetValues(thread, valueArray);
|
|
lightWeightMap->SetLength(0);
|
|
return *lightWeightMap;
|
|
}
|
|
};
|
|
|
|
HWTEST_F_L0(JSAPILightWeightMapTest, LightWeightMapCreate)
|
|
{
|
|
JSAPILightWeightMap *lightWeightMap = CreateLightWeightMap();
|
|
EXPECT_TRUE(lightWeightMap != nullptr);
|
|
}
|
|
|
|
HWTEST_F_L0(JSAPILightWeightMapTest, SetHasKeyGetHasValue)
|
|
{
|
|
JSAPILightWeightMap *lightWeightMap = CreateLightWeightMap();
|
|
|
|
JSHandle<JSTaggedValue> key(thread, JSTaggedValue(1));
|
|
JSHandle<JSTaggedValue> value(thread, JSTaggedValue(2));
|
|
JSHandle<JSAPILightWeightMap> lwm(thread, lightWeightMap);
|
|
JSAPILightWeightMap::Set(thread, lwm, key, value);
|
|
EXPECT_TRUE(JSTaggedValue::Equal(thread, JSHandle<JSTaggedValue>(thread,
|
|
JSAPILightWeightMap::Get(thread, lwm, key)), value));
|
|
|
|
JSHandle<JSTaggedValue> key1(thread, JSTaggedValue(2));
|
|
JSHandle<JSTaggedValue> value1(thread, JSTaggedValue(3));
|
|
JSAPILightWeightMap::Set(thread, lwm, key1, value1);
|
|
|
|
JSHandle<JSTaggedValue> key2(thread, JSTaggedValue(3));
|
|
JSHandle<JSTaggedValue> value2(thread, JSTaggedValue(4));
|
|
JSAPILightWeightMap::Set(thread, lwm, key2, value2);
|
|
|
|
// test species
|
|
JSHandle<GlobalEnv> env = thread->GetEcmaVM()->GetGlobalEnv();
|
|
JSHandle<JSTaggedValue> key3 = env->GetSpeciesSymbol();
|
|
JSHandle<JSTaggedValue> value3(thread, JSTaggedValue(5));
|
|
JSAPILightWeightMap::Set(thread, lwm, key3, value3);
|
|
|
|
JSHandle<JSTaggedValue> key4(thread, JSTaggedValue(10));
|
|
JSHandle<JSTaggedValue> value4(thread, JSTaggedValue(10));
|
|
JSAPILightWeightMap::Set(thread, lwm, key4, value4);
|
|
EXPECT_TRUE(JSTaggedValue::Equal(thread, JSHandle<JSTaggedValue>(thread,
|
|
JSAPILightWeightMap::Get(thread, lwm, key4)), value4));
|
|
|
|
// change value on Existed key
|
|
JSHandle<JSTaggedValue> value5(thread, JSTaggedValue(100));
|
|
JSAPILightWeightMap::Set(thread, lwm, key4, value5);
|
|
EXPECT_TRUE(JSTaggedValue::Equal(thread, JSHandle<JSTaggedValue>(thread,
|
|
JSAPILightWeightMap::Get(thread, lwm, key4)), value5));
|
|
|
|
EXPECT_TRUE(JSTaggedValue::Equal(thread, JSHandle<JSTaggedValue>(thread,
|
|
JSAPILightWeightMap::Get(thread, lwm, key)), value));
|
|
|
|
EXPECT_EQ(JSAPILightWeightMap::HasKey(thread, lwm, key1), JSTaggedValue::True());
|
|
EXPECT_EQ(JSAPILightWeightMap::HasKey(thread, lwm, key), JSTaggedValue::True());
|
|
EXPECT_EQ(JSAPILightWeightMap::HasKey(thread, lwm, key3), JSTaggedValue::True());
|
|
EXPECT_EQ(JSAPILightWeightMap::HasKey(thread, lwm, value), JSTaggedValue::True());
|
|
}
|
|
|
|
HWTEST_F_L0(JSAPILightWeightMapTest, GetIndexOfKeyAndGetIndexOfValue)
|
|
{
|
|
constexpr uint32_t NODE_NUMBERS = 8;
|
|
ObjectFactory *factory = thread->GetEcmaVM()->GetFactory();
|
|
JSMutableHandle<JSTaggedValue> key(thread, JSTaggedValue::Undefined());
|
|
JSMutableHandle<JSTaggedValue> value(thread, JSTaggedValue::Undefined());
|
|
std::string myKey("mykey");
|
|
std::string myValue("myvalue");
|
|
JSHandle<JSAPILightWeightMap> lwm(thread, CreateLightWeightMap());
|
|
for (uint32_t i = 0; i < NODE_NUMBERS; i++) {
|
|
std::string ikey = myKey + std::to_string(i);
|
|
std::string ivalue = myValue + std::to_string(i);
|
|
key.Update(factory->NewFromStdString(ikey).GetTaggedValue());
|
|
value.Update(factory->NewFromStdString(ivalue).GetTaggedValue());
|
|
JSAPILightWeightMap::Set(thread, lwm, key, value);
|
|
EXPECT_TRUE(JSAPILightWeightMap::GetIndexOfKey(thread, lwm, key) != -1);
|
|
EXPECT_TRUE(JSAPILightWeightMap::GetIndexOfValue(thread, lwm, value) != -1);
|
|
uint32_t length = lwm->GetLength();
|
|
EXPECT_EQ(length, i + 1);
|
|
}
|
|
std::string ivalue = myValue + std::to_string(NODE_NUMBERS);
|
|
value.Update(factory->NewFromStdString(ivalue).GetTaggedValue());
|
|
EXPECT_TRUE(JSAPILightWeightMap::GetIndexOfValue(thread, lwm, value) == -1);
|
|
}
|
|
|
|
HWTEST_F_L0(JSAPILightWeightMapTest, IsEmptyGetKeyAtGetValue)
|
|
{
|
|
JSHandle<JSAPILightWeightMap> lwm(thread, CreateLightWeightMap());
|
|
|
|
JSHandle<JSTaggedValue> key(thread, JSTaggedValue(1));
|
|
JSHandle<JSTaggedValue> value(thread, JSTaggedValue(2));
|
|
JSAPILightWeightMap::Set(thread, lwm, key, value);
|
|
|
|
JSHandle<JSTaggedValue> key1(thread, JSTaggedValue(2));
|
|
JSHandle<JSTaggedValue> value1(thread, JSTaggedValue(3));
|
|
JSAPILightWeightMap::Set(thread, lwm, key1, value1);
|
|
|
|
JSHandle<JSTaggedValue> key2(thread, JSTaggedValue(3));
|
|
JSHandle<JSTaggedValue> value2(thread, JSTaggedValue(4));
|
|
JSAPILightWeightMap::Set(thread, lwm, key2, value2);
|
|
|
|
JSHandle<JSTaggedValue> result =
|
|
JSHandle<JSTaggedValue>(thread, JSAPILightWeightMap::GetValueAt(thread, lwm, 0));
|
|
EXPECT_TRUE(JSTaggedValue::Equal(thread, result, value));
|
|
result = JSHandle<JSTaggedValue>(thread, JSAPILightWeightMap::GetValueAt(thread, lwm, 1));
|
|
EXPECT_TRUE(JSTaggedValue::Equal(thread, result, value1));
|
|
result = JSHandle<JSTaggedValue>(thread, JSAPILightWeightMap::GetValueAt(thread, lwm, 2));
|
|
EXPECT_TRUE(JSTaggedValue::Equal(thread, result, value2));
|
|
|
|
result = JSHandle<JSTaggedValue>(thread, JSAPILightWeightMap::GetKeyAt(thread, lwm, 0));
|
|
EXPECT_TRUE(JSTaggedValue::Equal(thread, result, key));
|
|
result = JSHandle<JSTaggedValue>(thread, JSAPILightWeightMap::GetKeyAt(thread, lwm, 1));
|
|
EXPECT_TRUE(JSTaggedValue::Equal(thread, result, key1));
|
|
result = JSHandle<JSTaggedValue>(thread, JSAPILightWeightMap::GetKeyAt(thread, lwm, 2));
|
|
EXPECT_TRUE(JSTaggedValue::Equal(thread, result, key2));
|
|
|
|
EXPECT_EQ(lwm->IsEmpty(), JSTaggedValue::False());
|
|
JSAPILightWeightMap::Clear(thread, lwm);
|
|
EXPECT_EQ(lwm->IsEmpty(), JSTaggedValue::True());
|
|
}
|
|
|
|
HWTEST_F_L0(JSAPILightWeightMapTest, Remove)
|
|
{
|
|
JSHandle<JSAPILightWeightMap> lwm(thread, CreateLightWeightMap());
|
|
JSHandle<TaggedArray> valueArray(thread,
|
|
JSTaggedValue(TaggedArray::Cast(lwm->GetValues().GetTaggedObject())));
|
|
|
|
JSHandle<JSTaggedValue> key(thread, JSTaggedValue(1));
|
|
JSHandle<JSTaggedValue> value(thread, JSTaggedValue(2));
|
|
JSAPILightWeightMap::Set(thread, lwm, key, value);
|
|
|
|
JSHandle<JSTaggedValue> key1(thread, JSTaggedValue(2));
|
|
JSHandle<JSTaggedValue> value1(thread, JSTaggedValue(3));
|
|
JSAPILightWeightMap::Set(thread, lwm, key1, value1);
|
|
|
|
JSHandle<JSTaggedValue> key2(thread, JSTaggedValue(3));
|
|
JSHandle<JSTaggedValue> value2(thread, JSTaggedValue(4));
|
|
JSAPILightWeightMap::Set(thread, lwm, key2, value2);
|
|
|
|
JSHandle<JSTaggedValue> key3(thread, JSTaggedValue(4));
|
|
|
|
JSHandle<JSTaggedValue> result =
|
|
JSHandle<JSTaggedValue>(thread, JSAPILightWeightMap::Remove(thread, lwm, key2));
|
|
JSHandle<JSTaggedValue> resultNoExist =
|
|
JSHandle<JSTaggedValue>(thread, JSAPILightWeightMap::Remove(thread, lwm, key3));
|
|
EXPECT_TRUE(JSTaggedValue::Equal(thread, result, value2));
|
|
bool isKeyExist = true;
|
|
if (resultNoExist->IsUndefined()) {
|
|
isKeyExist = false;
|
|
}
|
|
EXPECT_FALSE(isKeyExist);
|
|
}
|
|
|
|
HWTEST_F_L0(JSAPILightWeightMapTest, RemoveAt)
|
|
{
|
|
JSHandle<JSAPILightWeightMap> lwm(thread, CreateLightWeightMap());
|
|
JSHandle<TaggedArray> valueArray(thread,
|
|
JSTaggedValue(TaggedArray::Cast(lwm->GetValues().GetTaggedObject())));
|
|
|
|
JSHandle<JSTaggedValue> key(thread, JSTaggedValue(1));
|
|
JSHandle<JSTaggedValue> value(thread, JSTaggedValue(2));
|
|
JSAPILightWeightMap::Set(thread, lwm, key, value);
|
|
|
|
JSHandle<JSTaggedValue> key1(thread, JSTaggedValue(2));
|
|
JSHandle<JSTaggedValue> value1(thread, JSTaggedValue(3));
|
|
JSAPILightWeightMap::Set(thread, lwm, key1, value1);
|
|
|
|
JSHandle<JSTaggedValue> key2(thread, JSTaggedValue(3));
|
|
JSHandle<JSTaggedValue> value2(thread, JSTaggedValue(4));
|
|
JSAPILightWeightMap::Set(thread, lwm, key2, value2);
|
|
|
|
int32_t removeIndex = JSAPILightWeightMap::GetIndexOfKey(thread, lwm, key1);
|
|
EXPECT_EQ(JSAPILightWeightMap::RemoveAt(thread, lwm, removeIndex), JSTaggedValue::True());
|
|
JSHandle<JSTaggedValue> result(thread, JSAPILightWeightMap::Get(thread, lwm, key1));
|
|
bool isSuccessRemove = false;
|
|
if (result->IsUndefined()) {
|
|
isSuccessRemove = true;
|
|
}
|
|
EXPECT_TRUE(isSuccessRemove);
|
|
EXPECT_EQ(JSAPILightWeightMap::HasValue(thread, lwm, value1), JSTaggedValue::False());
|
|
EXPECT_TRUE(lwm->GetLength() == 2);
|
|
|
|
EXPECT_EQ(JSAPILightWeightMap::RemoveAt(thread, lwm, -1), JSTaggedValue::False());
|
|
EXPECT_EQ(JSAPILightWeightMap::RemoveAt(thread, lwm, 10), JSTaggedValue::False());
|
|
}
|
|
|
|
HWTEST_F_L0(JSAPILightWeightMapTest, SetValueAt)
|
|
{
|
|
JSHandle<JSAPILightWeightMap> lwm(thread, CreateLightWeightMap());
|
|
|
|
JSHandle<JSTaggedValue> key(thread, JSTaggedValue(1));
|
|
JSHandle<JSTaggedValue> value(thread, JSTaggedValue(2));
|
|
JSAPILightWeightMap::Set(thread, lwm, key, value);
|
|
EXPECT_TRUE(JSTaggedValue::Equal(thread, JSHandle<JSTaggedValue>(thread,
|
|
JSAPILightWeightMap::Get(thread, lwm, key)), value));
|
|
|
|
JSHandle<JSTaggedValue> key1(thread, JSTaggedValue(2));
|
|
JSHandle<JSTaggedValue> value1(thread, JSTaggedValue(3));
|
|
JSAPILightWeightMap::Set(thread, lwm, key1, value1);
|
|
|
|
JSHandle<JSTaggedValue> key2(thread, JSTaggedValue(3));
|
|
JSHandle<JSTaggedValue> value2(thread, JSTaggedValue(4));
|
|
JSAPILightWeightMap::Set(thread, lwm, key2, value2);
|
|
|
|
JSHandle<JSTaggedValue> value3(thread, JSTaggedValue(5));
|
|
|
|
int32_t index = JSAPILightWeightMap::GetIndexOfKey(thread, lwm, key);
|
|
JSAPILightWeightMap::SetValueAt(thread, lwm, index, value3);
|
|
EXPECT_TRUE(JSTaggedValue::Equal(thread, JSHandle<JSTaggedValue>(thread,
|
|
JSAPILightWeightMap::Get(thread, lwm, key)), value3));
|
|
}
|
|
|
|
HWTEST_F_L0(JSAPILightWeightMapTest, GetStateOfKey)
|
|
{
|
|
JSHandle<JSAPILightWeightMap> lwm(thread, CreateLightWeightMap());
|
|
|
|
JSHandle<JSTaggedValue> key1(thread, JSTaggedValue(1));
|
|
JSHandle<JSTaggedValue> value1(thread, JSTaggedValue(1));
|
|
JSAPILightWeightMap::Set(thread, lwm, key1, value1);
|
|
KeyState keyState1 = JSAPILightWeightMap::GetStateOfKey(thread, lwm, key1);
|
|
EXPECT_TRUE(keyState1.existed);
|
|
|
|
JSHandle<JSTaggedValue> key2(thread, JSTaggedValue(2));
|
|
KeyState keyState2 = JSAPILightWeightMap::GetStateOfKey(thread, lwm, key2);
|
|
EXPECT_FALSE(keyState2.existed);
|
|
|
|
// hash Collision
|
|
std::vector<double> setVector = {0.0, 1224.0, 1285.0, 1463.0, 4307.0, 5135.0,
|
|
5903.0, 6603.0, 6780.0, 8416.0, 9401.0, 9740.0};
|
|
for (uint32_t i = 0; i < setVector.size() - 1; i++) {
|
|
JSHandle<JSTaggedValue> key3(thread, JSTaggedValue(setVector[i]));
|
|
JSHandle<JSTaggedValue> value3(thread, JSTaggedValue(setVector[i]));
|
|
JSAPILightWeightMap::Set(thread, lwm, key3, value3);
|
|
}
|
|
|
|
// check
|
|
for (uint32_t i = 0; i < setVector.size() - 1; i++) {
|
|
JSHandle<JSTaggedValue> key4(thread, JSTaggedValue(setVector[i]));
|
|
KeyState keyState4 = JSAPILightWeightMap::GetStateOfKey(thread, lwm, key4);
|
|
EXPECT_TRUE(keyState4.existed);
|
|
}
|
|
JSHandle<JSTaggedValue> key5(thread, JSTaggedValue(setVector[setVector.size() - 1]));
|
|
KeyState keyState5 = JSAPILightWeightMap::GetStateOfKey(thread, lwm, key5);
|
|
EXPECT_FALSE(keyState5.existed);
|
|
|
|
JSHandle<JSTaggedValue> key6(thread, JSTaggedValue(0));
|
|
KeyState keyState6 = JSAPILightWeightMap::GetStateOfKey(thread, lwm, key6);
|
|
EXPECT_TRUE(keyState6.existed);
|
|
}
|
|
|
|
HWTEST_F_L0(JSAPILightWeightMapTest, IncreaseCapacityTo)
|
|
{
|
|
constexpr uint32_t NODE_NUMBERS = 10;
|
|
ObjectFactory *factory = thread->GetEcmaVM()->GetFactory();
|
|
JSMutableHandle<JSTaggedValue> key(thread, JSTaggedValue::Undefined());
|
|
JSMutableHandle<JSTaggedValue> value(thread, JSTaggedValue::Undefined());
|
|
std::string myKey("mykey");
|
|
std::string myValue("myvalue");
|
|
JSHandle<JSAPILightWeightMap> lwm(thread, CreateLightWeightMap());
|
|
for (uint32_t i = 0; i < NODE_NUMBERS; i++) {
|
|
std::string ikey = myKey + std::to_string(i);
|
|
std::string ivalue = myValue + std::to_string(i);
|
|
key.Update(factory->NewFromStdString(ikey).GetTaggedValue());
|
|
value.Update(factory->NewFromStdString(ivalue).GetTaggedValue());
|
|
JSAPILightWeightMap::Set(thread, lwm, key, value);
|
|
EXPECT_TRUE(JSAPILightWeightMap::GetIndexOfKey(thread, lwm, key) != -1);
|
|
EXPECT_TRUE(JSAPILightWeightMap::GetIndexOfValue(thread, lwm, value) != -1);
|
|
uint32_t length = lwm->GetLength();
|
|
EXPECT_EQ(length, i + 1);
|
|
}
|
|
EXPECT_EQ(JSAPILightWeightMap::IncreaseCapacityTo(thread, lwm, 15), JSTaggedValue::True());
|
|
EXPECT_EQ(JSAPILightWeightMap::IncreaseCapacityTo(thread, lwm, 9), JSTaggedValue::False());
|
|
}
|
|
|
|
HWTEST_F_L0(JSAPILightWeightMapTest, Iterator)
|
|
{
|
|
constexpr uint32_t NODE_NUMBERS = 8;
|
|
ObjectFactory *factory = thread->GetEcmaVM()->GetFactory();
|
|
JSHandle<JSAPILightWeightMap> lwm(thread, CreateLightWeightMap());
|
|
|
|
JSMutableHandle<JSTaggedValue> key(thread, JSTaggedValue::Undefined());
|
|
JSMutableHandle<JSTaggedValue> value(thread, JSTaggedValue::Undefined());
|
|
for (uint32_t i = 0; i < NODE_NUMBERS; i++) {
|
|
key.Update(JSTaggedValue(i));
|
|
value.Update(JSTaggedValue(i + 1));
|
|
JSAPILightWeightMap::Set(thread, lwm, key, value);
|
|
}
|
|
|
|
// test key or value
|
|
JSHandle<JSTaggedValue> keyIter(factory->NewJSAPILightWeightMapIterator(lwm, IterationKind::KEY));
|
|
JSHandle<JSTaggedValue> valueIter(factory->NewJSAPILightWeightMapIterator(lwm, IterationKind::VALUE));
|
|
JSMutableHandle<JSTaggedValue> keyIterResult(thread, JSTaggedValue::Undefined());
|
|
JSMutableHandle<JSTaggedValue> valueIterResult(thread, JSTaggedValue::Undefined());
|
|
JSMutableHandle<JSTaggedValue> keyHandle(thread, JSTaggedValue::Undefined());
|
|
for (uint32_t i = 0; i < NODE_NUMBERS; i++) {
|
|
keyIterResult.Update(JSIterator::IteratorStep(thread, keyIter).GetTaggedValue());
|
|
valueIterResult.Update(JSIterator::IteratorStep(thread, valueIter).GetTaggedValue());
|
|
JSTaggedValue k = JSIterator::IteratorValue(thread, keyIterResult).GetTaggedValue();
|
|
keyHandle.Update(k);
|
|
JSTaggedValue v = JSIterator::IteratorValue(thread, valueIterResult).GetTaggedValue();
|
|
EXPECT_EQ(JSAPILightWeightMap::HasKey(thread, lwm, keyHandle), JSTaggedValue::True());
|
|
EXPECT_EQ(JSAPILightWeightMap::Get(thread, lwm, keyHandle), v);
|
|
}
|
|
|
|
// test key and value
|
|
for (uint32_t i = 0; i < NODE_NUMBERS; i++) {
|
|
JSTaggedValue k = JSTaggedValue(i);
|
|
JSTaggedValue v = JSTaggedValue(i + 1);
|
|
keyHandle.Update(k);
|
|
EXPECT_EQ(JSAPILightWeightMap::HasKey(thread, lwm, keyHandle), JSTaggedValue::True());
|
|
EXPECT_EQ(JSAPILightWeightMap::Get(thread, lwm, keyHandle), v);
|
|
}
|
|
}
|
|
|
|
HWTEST_F_L0(JSAPILightWeightMapTest, IsEmptyHasValueHasAll)
|
|
{
|
|
constexpr uint32_t NODE_NUMBERS = 8;
|
|
ObjectFactory *factory = thread->GetEcmaVM()->GetFactory();
|
|
JSHandle<JSAPILightWeightMap> lwp(thread, CreateLightWeightMap());
|
|
JSHandle<JSAPILightWeightMap> hasAllLwp(thread, CreateLightWeightMap());
|
|
JSMutableHandle<JSTaggedValue> key1(thread, JSTaggedValue::Undefined());
|
|
JSMutableHandle<JSTaggedValue> value1(thread, JSTaggedValue::Undefined());
|
|
JSMutableHandle<JSTaggedValue> value2(thread, JSTaggedValue::Undefined());
|
|
JSMutableHandle<JSTaggedValue> value3(thread, JSTaggedValue::Undefined());
|
|
|
|
std::string tValue;
|
|
// test IsEmpty
|
|
EXPECT_EQ(lwp->IsEmpty(), JSTaggedValue::True());
|
|
// test Set
|
|
std::string myKey1("mykey");
|
|
std::string myValue1("myvalue");
|
|
for (uint32_t i = 0; i < NODE_NUMBERS; i++) {
|
|
std::string iKey1 = myKey1 + std::to_string(i);
|
|
std::string iValue1 = myValue1 + std::to_string(i + 1);
|
|
key1.Update(factory->NewFromStdString(iKey1).GetTaggedValue());
|
|
value1.Update(factory->NewFromStdString(iValue1).GetTaggedValue());
|
|
JSAPILightWeightMap::Set(thread, lwp, key1, value1);
|
|
}
|
|
EXPECT_EQ(lwp->GetLength(), NODE_NUMBERS);
|
|
|
|
// test HasValue
|
|
for (uint32_t i = 0; i < NODE_NUMBERS; i++) {
|
|
tValue = myValue1 + std::to_string(i + 1);
|
|
value1.Update(factory->NewFromStdString(tValue).GetTaggedValue());
|
|
EXPECT_EQ(JSAPILightWeightMap::HasValue(thread, lwp, value1), JSTaggedValue::True());
|
|
}
|
|
tValue = myValue1 + std::to_string(NODE_NUMBERS + 1);
|
|
value1.Update(factory->NewFromStdString(tValue).GetTaggedValue());
|
|
EXPECT_EQ(JSAPILightWeightMap::HasValue(thread, lwp, value1), JSTaggedValue::False());
|
|
|
|
// test HasAll
|
|
for (uint32_t i = 0; i < NODE_NUMBERS - 5; i++) {
|
|
if (i == 1) {
|
|
std::string mykey2("destKey");
|
|
std::string myValue2("destValue");
|
|
std::string iKey2 = mykey2 + std::to_string(i);
|
|
std::string iValue2 = myValue2 + std::to_string(i);
|
|
key1.Update(factory->NewFromStdString(iKey2).GetTaggedValue());
|
|
value1.Update(factory->NewFromStdString(iValue2).GetTaggedValue());
|
|
JSAPILightWeightMap::Set(thread, hasAllLwp, key1, value1);
|
|
} else {
|
|
std::string iKey = myKey1 + std::to_string(i);
|
|
std::string iValue = myValue1 + std::to_string(i + 1);
|
|
key1.Update(factory->NewFromStdString(iValue).GetTaggedValue());
|
|
value1.Update(factory->NewFromStdString(iValue).GetTaggedValue());
|
|
JSAPILightWeightMap::Set(thread, hasAllLwp, key1, value2);
|
|
}
|
|
}
|
|
EXPECT_EQ(hasAllLwp->GetLength(), NODE_NUMBERS - 5);
|
|
EXPECT_EQ(JSAPILightWeightMap::HasAll(thread, lwp, hasAllLwp), JSTaggedValue::False());
|
|
EXPECT_EQ(JSAPILightWeightMap::HasAll(thread, hasAllLwp, lwp), JSTaggedValue::False());
|
|
}
|
|
|
|
/**
|
|
* @tc.name: GetIteratorObj
|
|
* @tc.desc:
|
|
* @tc.type: FUNC
|
|
* @tc.require:
|
|
*/
|
|
HWTEST_F_L0(JSAPILightWeightMapTest, GetIteratorObj)
|
|
{
|
|
JSHandle<JSAPILightWeightMap> lwp(thread, CreateLightWeightMap());
|
|
JSHandle<JSTaggedValue> iteratorObj(thread, JSAPILightWeightMap::GetIteratorObj(
|
|
thread, lwp, IterationKind::KEY_AND_VALUE));
|
|
EXPECT_TRUE(iteratorObj->IsJSAPILightWeightMapIterator());
|
|
}
|
|
} // namespace panda::test
|