* Copyright (c) 2021 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/builtins/builtins_set.h"
#include "ecmascript/ecma_string.h"
#include "ecmascript/ecma_vm.h"
#include "ecmascript/global_env.h"
#include "ecmascript/js_array.h"
#include "ecmascript/js_handle.h"
#include "ecmascript/js_hclass.h"
#include "ecmascript/js_object-inl.h"
#include "ecmascript/js_set.h"
#include "ecmascript/js_set_iterator.h"
#include "ecmascript/js_tagged_value.h"
#include "ecmascript/js_thread.h"
#include "ecmascript/object_factory.h"
#include "ecmascript/shared_objects/js_shared_set_iterator.h"
#include "ecmascript/tests/test_helper.h"
using namespace panda::ecmascript;
using namespace panda::ecmascript::builtins;
namespace panda::test {
using BuiltinsSet = ecmascript::builtins::BuiltinsSet;
using JSSet = ecmascript::JSSet;
class BuiltinsSetTest : public BaseTestWithScope<false> {
public:
class TestClass : public base::BuiltinsBase {
public:
static JSTaggedValue TestFunc(EcmaRuntimeCallInfo *argv)
{
JSTaggedValue key = GetCallArg(argv, 0).GetTaggedValue();
if (key.IsUndefined()) {
return JSTaggedValue::Undefined();
}
JSArray *jsArray = JSArray::Cast(GetThis(argv)->GetTaggedObject());
uint32_t length = jsArray->GetArrayLength() + 1U;
jsArray->SetArrayLength(argv->GetThread(), length);
return JSTaggedValue::Undefined();
}
};
};
JSSet *CreateBuiltinsSet(JSThread *thread)
{
JSHandle<GlobalEnv> env = thread->GetEcmaVM()->GetGlobalEnv();
JSHandle<JSFunction> newTarget(env->GetBuiltinsSetFunction());
auto ecmaRuntimeCallInfo = TestHelper::CreateEcmaRuntimeCallInfo(thread, JSTaggedValue(*newTarget), 4);
ecmaRuntimeCallInfo->SetFunction(newTarget.GetTaggedValue());
ecmaRuntimeCallInfo->SetThis(JSTaggedValue::Undefined());
[[maybe_unused]] auto prev = TestHelper::SetupFrame(thread, ecmaRuntimeCallInfo);
JSTaggedValue result = BuiltinsSet::SetConstructor(ecmaRuntimeCallInfo);
TestHelper::TearDownFrame(thread, prev);
EXPECT_TRUE(result.IsECMAObject());
return JSSet::Cast(reinterpret_cast<TaggedObject *>(result.GetRawData()));
}
enum class AlgorithmType {
ADD,
HAS,
};
JSTaggedValue SetAlgorithm(JSThread *thread, JSTaggedValue jsSet, std::vector<JSTaggedValue>& args,
uint32_t argLen = 8, AlgorithmType type = AlgorithmType::ADD)
{
auto ecmaRuntimeCallInfos = TestHelper::CreateEcmaRuntimeCallInfo(thread, JSTaggedValue::Undefined(), argLen);
ecmaRuntimeCallInfos->SetFunction(JSTaggedValue::Undefined());
ecmaRuntimeCallInfos->SetThis(jsSet);
for (size_t i = 0; i < args.size(); i++) {
ecmaRuntimeCallInfos->SetCallArg(i, args[i]);
}
auto prev = TestHelper::SetupFrame(thread, ecmaRuntimeCallInfos);
JSTaggedValue result;
switch (type) {
case AlgorithmType::ADD:
result = BuiltinsSet::Add(ecmaRuntimeCallInfos);
break;
case AlgorithmType::HAS:
result = BuiltinsSet::Has(ecmaRuntimeCallInfos);
break;
default:
break;
}
TestHelper::TearDownFrame(thread, prev);
return result;
}
HWTEST_F_L0(BuiltinsSetTest, CreateAndGetSize)
{
ObjectFactory *factory = thread->GetEcmaVM()->GetFactory();
JSHandle<GlobalEnv> env = thread->GetEcmaVM()->GetGlobalEnv();
JSHandle<JSFunction> newTarget(env->GetBuiltinsSetFunction());
JSHandle<JSSet> set(thread, CreateBuiltinsSet(thread));
auto ecmaRuntimeCallInfo = TestHelper::CreateEcmaRuntimeCallInfo(thread, JSTaggedValue::Undefined(), 6);
ecmaRuntimeCallInfo->SetFunction(JSTaggedValue::Undefined());
ecmaRuntimeCallInfo->SetThis(set.GetTaggedValue());
ecmaRuntimeCallInfo->SetCallArg(0, JSTaggedValue::Undefined());
{
[[maybe_unused]] auto prev = TestHelper::SetupFrame(thread, ecmaRuntimeCallInfo);
JSTaggedValue result = BuiltinsSet::GetSize(ecmaRuntimeCallInfo);
TestHelper::TearDownFrame(thread, prev);
EXPECT_EQ(result.GetRawData(), JSTaggedValue(0).GetRawData());
}
JSHandle<TaggedArray> array(factory->NewTaggedArray(5));
for (int i = 0; i < 5; i++) {
array->Set(thread, i, JSTaggedValue(i));
}
JSHandle<JSArray> values = JSArray::CreateArrayFromList(thread, array);
auto ecmaRuntimeCallInfo1 = TestHelper::CreateEcmaRuntimeCallInfo(thread, JSTaggedValue::Undefined(), 6);
ecmaRuntimeCallInfo1->SetFunction(newTarget.GetTaggedValue());
ecmaRuntimeCallInfo1->SetThis(set.GetTaggedValue());
ecmaRuntimeCallInfo1->SetCallArg(0, values.GetTaggedValue());
ecmaRuntimeCallInfo1->SetNewTarget(newTarget.GetTaggedValue());
{
[[maybe_unused]] auto prev = TestHelper::SetupFrame(thread, ecmaRuntimeCallInfo1);
JSTaggedValue result1 = BuiltinsSet::SetConstructor(ecmaRuntimeCallInfo1);
TestHelper::TearDownFrame(thread, prev);
EXPECT_EQ(JSSet::Cast(reinterpret_cast<TaggedObject *>(result1.GetRawData()))->GetSize(thread), 5);
}
}
HWTEST_F_L0(BuiltinsSetTest, AddAndHas)
{
ObjectFactory *factory = thread->GetEcmaVM()->GetFactory();
JSHandle<JSSet> set(thread, CreateBuiltinsSet(thread));
JSHandle<JSTaggedValue> key(thread, factory->NewFromASCII("key").GetTaggedValue());
auto ecmaRuntimeCallInfo = TestHelper::CreateEcmaRuntimeCallInfo(thread, JSTaggedValue::Undefined(), 6);
ecmaRuntimeCallInfo->SetFunction(JSTaggedValue::Undefined());
ecmaRuntimeCallInfo->SetThis(set.GetTaggedValue());
ecmaRuntimeCallInfo->SetCallArg(0, key.GetTaggedValue());
[[maybe_unused]] auto prev = TestHelper::SetupFrame(thread, ecmaRuntimeCallInfo);
JSTaggedValue result1 = BuiltinsSet::Has(ecmaRuntimeCallInfo);
TestHelper::TearDownFrame(thread, prev);
EXPECT_EQ(result1.GetRawData(), JSTaggedValue::False().GetRawData());
JSTaggedValue result2 = BuiltinsSet::Add(ecmaRuntimeCallInfo);
EXPECT_TRUE(result2.IsECMAObject());
JSSet *jsSet = JSSet::Cast(reinterpret_cast<TaggedObject *>(result2.GetRawData()));
EXPECT_EQ(jsSet->GetSize(thread), 1);
JSTaggedValue jsSetTag(jsSet);
std::vector<JSTaggedValue> args{key.GetTaggedValue()};
auto result3 = SetAlgorithm(thread, jsSetTag, args, 6, AlgorithmType::HAS);
EXPECT_EQ(result3.GetRawData(), JSTaggedValue::True().GetRawData());
JSHandle<JSTaggedValue> negativeZero(thread, JSTaggedValue(-0.0));
JSHandle<JSTaggedValue> positiveZero(thread, JSTaggedValue(+0.0));
args[0] = negativeZero.GetTaggedValue();
SetAlgorithm(thread, jsSetTag, args, 6, AlgorithmType::ADD);
args[0] = positiveZero.GetTaggedValue();
auto result4 = SetAlgorithm(thread, jsSetTag, args, 6, AlgorithmType::HAS);
EXPECT_EQ(result4.GetRawData(), JSTaggedValue::True().GetRawData());
}
HWTEST_F_L0(BuiltinsSetTest, ForEach)
{
ObjectFactory *factory = thread->GetEcmaVM()->GetFactory();
JSHandle<JSSet> set(thread, CreateBuiltinsSet(thread));
char keyArray[] = "key0";
for (uint32_t i = 0U; i < 5U; i++) {
keyArray[3] = '1' + i;
JSHandle<JSTaggedValue> key(factory->NewFromASCII(keyArray));
std::vector<JSTaggedValue> args{key.GetTaggedValue()};
auto result1 = SetAlgorithm(thread, set.GetTaggedValue(), args, 6, AlgorithmType::ADD);
EXPECT_TRUE(result1.IsECMAObject());
JSSet *jsSet = JSSet::Cast(reinterpret_cast<TaggedObject *>(result1.GetRawData()));
EXPECT_EQ(jsSet->GetSize(thread), static_cast<int>(i) + 1);
}
JSHandle<JSArray> jsArray(JSArray::ArrayCreate(thread, JSTaggedNumber(0)));
JSHandle<JSFunction> func =
factory->NewJSFunction(thread->GetEcmaVM()->GetGlobalEnv(), reinterpret_cast<void *>(TestClass::TestFunc));
auto ecmaRuntimeCallInfo1 = TestHelper::CreateEcmaRuntimeCallInfo(thread, JSTaggedValue::Undefined(), 8);
ecmaRuntimeCallInfo1->SetFunction(JSTaggedValue::Undefined());
ecmaRuntimeCallInfo1->SetThis(set.GetTaggedValue());
ecmaRuntimeCallInfo1->SetCallArg(0, func.GetTaggedValue());
ecmaRuntimeCallInfo1->SetCallArg(1, jsArray.GetTaggedValue());
[[maybe_unused]] auto prev = TestHelper::SetupFrame(thread, ecmaRuntimeCallInfo1);
JSTaggedValue result2 = BuiltinsSet::ForEach(ecmaRuntimeCallInfo1);
TestHelper::TearDownFrame(thread, prev);
EXPECT_EQ(result2.GetRawData(), JSTaggedValue::VALUE_UNDEFINED);
EXPECT_EQ(jsArray->GetArrayLength(), 5U);
}
HWTEST_F_L0(BuiltinsSetTest, DeleteAndRemove)
{
ObjectFactory *factory = thread->GetEcmaVM()->GetFactory();
JSHandle<JSSet> set(thread, CreateBuiltinsSet(thread));
char keyArray[] = "key0";
for (uint32_t i = 0; i < 40; i++) {
keyArray[3] = '1' + i;
JSHandle<JSTaggedValue> key(factory->NewFromASCII(keyArray));
std::vector<JSTaggedValue> args{key.GetTaggedValue()};
auto result1 = SetAlgorithm(thread, set.GetTaggedValue(), args, 6, AlgorithmType::ADD);
EXPECT_TRUE(result1.IsECMAObject());
JSSet *jsSet = JSSet::Cast(reinterpret_cast<TaggedObject *>(result1.GetRawData()));
EXPECT_EQ(jsSet->GetSize(thread), static_cast<int>(i) + 1);
}
keyArray[3] = '1' + 8;
JSHandle<JSTaggedValue> deleteKey(factory->NewFromASCII(keyArray));
auto ecmaRuntimeCallInfo1 = TestHelper::CreateEcmaRuntimeCallInfo(thread, JSTaggedValue::Undefined(), 6);
ecmaRuntimeCallInfo1->SetFunction(JSTaggedValue::Undefined());
ecmaRuntimeCallInfo1->SetThis(set.GetTaggedValue());
ecmaRuntimeCallInfo1->SetCallArg(0, deleteKey.GetTaggedValue());
[[maybe_unused]] auto prev = TestHelper::SetupFrame(thread, ecmaRuntimeCallInfo1);
JSTaggedValue result2 = BuiltinsSet::Has(ecmaRuntimeCallInfo1);
EXPECT_EQ(result2.GetRawData(), JSTaggedValue::True().GetRawData());
JSTaggedValue result3 = BuiltinsSet::Delete(ecmaRuntimeCallInfo1);
EXPECT_EQ(result3.GetRawData(), JSTaggedValue::True().GetRawData());
JSTaggedValue result4 = BuiltinsSet::Has(ecmaRuntimeCallInfo1);
EXPECT_EQ(result4.GetRawData(), JSTaggedValue::False().GetRawData());
JSTaggedValue result5 = BuiltinsSet::GetSize(ecmaRuntimeCallInfo1);
EXPECT_EQ(result5.GetRawData(), JSTaggedValue(39).GetRawData());
JSTaggedValue result6 = BuiltinsSet::Clear(ecmaRuntimeCallInfo1);
EXPECT_EQ(result6.GetRawData(), JSTaggedValue::VALUE_UNDEFINED);
EXPECT_EQ(set->GetSize(thread), 0);
}
HWTEST_F_L0(BuiltinsSetTest, Species)
{
ObjectFactory *factory = thread->GetEcmaVM()->GetFactory();
JSHandle<GlobalEnv> env = thread->GetEcmaVM()->GetGlobalEnv();
JSHandle<JSTaggedValue> set(thread, CreateBuiltinsSet(thread));
JSHandle<JSTaggedValue> speciesSymbol = thread->GlobalConstants()->GetHandledSpeciesSymbol();
EXPECT_TRUE(!speciesSymbol->IsUndefined());
JSHandle<JSFunction> newTarget(env->GetBuiltinsSetFunction());
JSTaggedValue value =
JSObject::GetProperty(thread, JSHandle<JSTaggedValue>(newTarget), speciesSymbol).GetValue().GetTaggedValue();
JSHandle<JSTaggedValue> valueHandle(thread, value);
EXPECT_EQ(value, newTarget.GetTaggedValue());
JSHandle<JSTaggedValue> toStringTagSymbol = thread->GlobalConstants()->GetHandledToStringTagSymbol();
JSHandle<EcmaString> stringTag(JSObject::GetProperty(thread, set, toStringTagSymbol).GetValue());
JSHandle<EcmaString> str = factory->NewFromASCII("Set");
EXPECT_TRUE(!stringTag.GetTaggedValue().IsUndefined());
EXPECT_TRUE(EcmaStringAccessor::StringsAreEqual(thread, *str, *stringTag));
JSHandle<JSFunction> constructor = JSHandle<JSFunction>::Cast(JSTaggedValue::ToObject(thread, valueHandle));
EXPECT_EQ(JSTaggedValue::GetPrototype(thread, set), constructor->GetFunctionPrototype(thread));
JSHandle<JSTaggedValue> key1(factory->NewFromASCII("add"));
JSTaggedValue value1 = JSObject::GetProperty(thread, set, key1).GetValue().GetTaggedValue();
EXPECT_FALSE(value1.IsUndefined());
JSHandle<JSTaggedValue> key2(factory->NewFromASCII("has"));
JSTaggedValue value2 = JSObject::GetProperty(thread, set, key1).GetValue().GetTaggedValue();
EXPECT_FALSE(value2.IsUndefined());
JSHandle<JSTaggedValue> key3(factory->NewFromASCII("clear"));
JSTaggedValue value3 = JSObject::GetProperty(thread, set, key1).GetValue().GetTaggedValue();
EXPECT_FALSE(value3.IsUndefined());
JSHandle<JSTaggedValue> key4(factory->NewFromASCII("size"));
JSTaggedValue value4 = JSObject::GetProperty(thread, set, key1).GetValue().GetTaggedValue();
EXPECT_FALSE(value4.IsUndefined());
JSHandle<JSTaggedValue> key5(factory->NewFromASCII("delete"));
JSTaggedValue value5 = JSObject::GetProperty(thread, set, key1).GetValue().GetTaggedValue();
EXPECT_FALSE(value5.IsUndefined());
JSHandle<JSTaggedValue> key6(factory->NewFromASCII("forEach"));
JSTaggedValue value6 = JSObject::GetProperty(thread, set, key1).GetValue().GetTaggedValue();
EXPECT_FALSE(value6.IsUndefined());
}
HWTEST_F_L0(BuiltinsSetTest, GetIterator)
{
JSHandle<JSTaggedValue> set(thread, CreateBuiltinsSet(thread));
auto ecmaRuntimeCallInfo = TestHelper::CreateEcmaRuntimeCallInfo(thread, JSTaggedValue::Undefined(), 4);
ecmaRuntimeCallInfo->SetFunction(JSTaggedValue::Undefined());
ecmaRuntimeCallInfo->SetThis(set.GetTaggedValue());
[[maybe_unused]] auto prev = TestHelper::SetupFrame(thread, ecmaRuntimeCallInfo);
JSTaggedValue result = BuiltinsSet::Values(ecmaRuntimeCallInfo);
JSHandle<JSSetIterator> iter(thread, result);
EXPECT_TRUE(iter->IsJSSetIterator());
EXPECT_EQ(IterationKind::VALUE, IterationKind(iter->GetIterationKind()));
EXPECT_EQ(JSSet::Cast(set.GetTaggedValue().GetTaggedObject())->GetLinkedSet(thread), iter->GetIteratedSet(thread));
JSTaggedValue result2 = BuiltinsSet::Entries(ecmaRuntimeCallInfo);
JSHandle<JSSetIterator> iter2(thread, result2);
EXPECT_TRUE(iter2->IsJSSetIterator());
EXPECT_EQ(IterationKind::KEY_AND_VALUE, iter2->GetIterationKind());
}
HWTEST_F_L0(BuiltinsSetTest, Exception)
{
JSHandle<JSTaggedValue> set(thread, CreateBuiltinsSet(thread));
auto ecmaRuntimeCallInfo = TestHelper::CreateEcmaRuntimeCallInfo(thread, JSTaggedValue::Undefined(), 4);
ecmaRuntimeCallInfo->SetFunction(JSTaggedValue::Undefined());
ecmaRuntimeCallInfo->SetThis(set.GetTaggedValue());
[[maybe_unused]] auto prev = TestHelper::SetupFrame(thread, ecmaRuntimeCallInfo);
auto result = JSSharedSetIterator::CreateSetIterator(thread, set, IterationKind::KEY);
EXPECT_TRUE(result->IsUndefined());
TestHelper::TearDownFrame(thread, prev);
}
HWTEST_F_L0(BuiltinsSetTest, CreateSetIteratorTest001)
{
JSHandle<JSTaggedValue> jsSet(thread, CreateBuiltinsSet(thread));
EXPECT_TRUE(*jsSet != nullptr);
JSHandle<JSTaggedValue> setIteratorValue1 =
JSSetIterator::CreateSetIterator(thread, JSHandle<JSTaggedValue>(jsSet), IterationKind::KEY);
EXPECT_EQ(setIteratorValue1->IsJSSetIterator(), true);
}
HWTEST_F_L0(BuiltinsSetTest, NextInternalTest001)
{
JSTaggedValue setIteratorValue1 =
JSSetIterator::NextInternal(thread, JSHandle<JSTaggedValue>(thread, JSTaggedValue::Undefined()));
EXPECT_EQ(setIteratorValue1.IsJSSharedSetIterator(), false);
}
HWTEST_F_L0(BuiltinsSetTest, DeleteTest001)
{
JSHandle<JSSet> set(thread, CreateBuiltinsSet(thread));
JSHandle<JSTaggedValue> value1(thread, JSTaggedValue(0));
JSHandle<JSTaggedValue> value2(thread, JSTaggedValue(1));
JSSet::Add(thread, set, value1);
JSSet::Add(thread, set, value2);
JSSet::Delete(thread, set, JSHandle<JSTaggedValue>(thread, JSTaggedValue(20)));
}
HWTEST_F_L0(BuiltinsSetTest, GetValue)
{
JSHandle<JSTaggedValue> set(thread, CreateBuiltinsSet(thread));
auto ecmaRuntimeCallInfo = TestHelper::CreateEcmaRuntimeCallInfo(thread, JSTaggedValue::Undefined(), 4);
ecmaRuntimeCallInfo->SetFunction(JSTaggedValue::Undefined());
ecmaRuntimeCallInfo->SetThis(set.GetTaggedValue());
[[maybe_unused]] auto prev = TestHelper::SetupFrame(thread, ecmaRuntimeCallInfo);
JSTaggedValue result = BuiltinsSet::Values(ecmaRuntimeCallInfo);
JSHandle<JSSetIterator> iter(thread, result);
EXPECT_TRUE(result.IsJSSetIterator());
EXPECT_EQ(IterationKind::VALUE, IterationKind(iter->GetIterationKind()));
JSTaggedValue result2 = BuiltinsSet::Entries(ecmaRuntimeCallInfo);
JSHandle<JSSetIterator> iter2(thread, result2);
EXPECT_TRUE(result2.IsJSSetIterator());
EXPECT_EQ(IterationKind::KEY_AND_VALUE, iter2->GetIterationKind());
}
HWTEST_F_L0(BuiltinsSetTest, KEY_AND_VALUE_Next)
{
JSHandle<JSTaggedValue> index0(thread, JSTaggedValue(0));
JSHandle<JSTaggedValue> index1(thread, JSTaggedValue(1));
JSHandle<JSSetIterator> setIterator;
JSHandle<JSSet> set(thread, CreateBuiltinsSet(thread));
EXPECT_TRUE(*set != nullptr);
for (int i = 0; i < 3; i++) {
JSHandle<JSTaggedValue> key(thread, JSTaggedValue(i));
JSSet::Add(thread, set, key);
}
JSHandle<JSTaggedValue> setIteratorValue =
JSSetIterator::CreateSetIterator(thread, JSHandle<JSTaggedValue>(set), IterationKind::KEY_AND_VALUE);
setIterator = JSHandle<JSSetIterator>(setIteratorValue);
std::vector<JSTaggedValue> args{JSTaggedValue::Undefined()};
auto ecmaRuntimeCallInfo =
TestHelper::CreateEcmaRuntimeCallInfo(thread, args, 6, setIteratorValue.GetTaggedValue());
[[maybe_unused]] auto prev = TestHelper::SetupFrame(thread, ecmaRuntimeCallInfo);
for (int i = 0; i <= 3; i++) {
JSTaggedValue result = JSSetIterator::Next(ecmaRuntimeCallInfo);
JSHandle<JSTaggedValue> resultObj(thread, result);
if (i < 3) {
JSHandle<JSArray> arrayList(thread, JSIterator::IteratorValue(thread, resultObj).GetTaggedValue());
EXPECT_EQ(setIterator->GetNextIndex(), static_cast<uint32_t>(i+1));
EXPECT_EQ(JSArray::GetProperty(thread, JSHandle<JSTaggedValue>(arrayList), index0).GetValue()->GetInt(), i);
EXPECT_EQ(JSArray::GetProperty(thread, JSHandle<JSTaggedValue>(arrayList), index1).GetValue()->GetInt(), i);
}
else {
EXPECT_EQ(JSIterator::IteratorValue(thread, resultObj).GetTaggedValue(), JSTaggedValue::Undefined());
}
}
TestHelper::TearDownFrame(thread, prev);
}
HWTEST_F_L0(BuiltinsSetTest, KeyNext)
{
JSHandle<JSSetIterator> setIterator;
JSHandle<JSSet> jsSet(thread, CreateBuiltinsSet(thread));
EXPECT_TRUE(*jsSet != nullptr);
JSHandle<JSTaggedValue> key(thread, JSTaggedValue(0));
JSSet::Add(thread, jsSet, key);
JSHandle<JSTaggedValue> setIteratorValue =
JSSetIterator::CreateSetIterator(thread, JSHandle<JSTaggedValue>(jsSet), IterationKind::KEY);
setIterator = JSHandle<JSSetIterator>(setIteratorValue);
std::vector args{JSTaggedValue::Undefined()};
auto ecmaRuntimeCallInfo =
TestHelper::CreateEcmaRuntimeCallInfo(thread, args, 6, setIteratorValue.GetTaggedValue());
[[maybe_unused]] auto prev = TestHelper::SetupFrame(thread, ecmaRuntimeCallInfo);
JSTaggedValue result = JSSetIterator::Next(ecmaRuntimeCallInfo);
EXPECT_EQ(result.IsJSSetIterator(), false);
TestHelper::TearDownFrame(thread, prev);
}
HWTEST_F_L0(BuiltinsSetTest, ValueNext)
{
JSHandle<JSSetIterator> setIterator;
JSHandle<JSSet> jsSet(thread, CreateBuiltinsSet(thread));
EXPECT_TRUE(*jsSet != nullptr);
JSHandle<JSTaggedValue> key(thread, JSTaggedValue(0));
JSSet::Add(thread, jsSet, key);
JSHandle<JSTaggedValue> setIteratorValue =
JSSetIterator::CreateSetIterator(thread, JSHandle<JSTaggedValue>(jsSet), IterationKind::VALUE);
setIterator = JSHandle<JSSetIterator>(setIteratorValue);
std::vector args{JSTaggedValue::Undefined()};
auto ecmaRuntimeCallInfo =
TestHelper::CreateEcmaRuntimeCallInfo(thread, args, 6, setIteratorValue.GetTaggedValue());
[[maybe_unused]] auto prev = TestHelper::SetupFrame(thread, ecmaRuntimeCallInfo);
JSTaggedValue result = JSSetIterator::Next(ecmaRuntimeCallInfo);
EXPECT_EQ(result.IsJSSetIterator(), false);
TestHelper::TearDownFrame(thread, prev);
}
}