/* * 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-inl.h" #include "ecmascript/object_factory.h" #include "ecmascript/tests/test_helper.h" using namespace panda::ecmascript; namespace panda::test { class LineEcmaStringTest : public testing::Test { public: static void SetUpTestCase() { GTEST_LOG_(INFO) << "SetUpTestCase"; } static void TearDownTestCase() { GTEST_LOG_(INFO) << "TearDownCase"; } void SetUp() override { TestHelper::CreateEcmaVMWithScope(ecmaVMPtr, thread, scope); } void TearDown() override { TestHelper::DestroyEcmaVMWithScope(ecmaVMPtr, scope); } EcmaVM *ecmaVMPtr {nullptr}; ecmascript::EcmaHandleScope *scope {nullptr}; JSThread *thread {nullptr}; }; /* * @tc.name: ComputeSizeUtf8 * @tc.desc: Check whether the value returned through calling ComputeSizeUtf8 function is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(LineEcmaStringTest, ComputeSizeUtf8) { uint32_t scale = 3333; for (uint32_t i = EcmaString::MAX_STRING_LENGTH - 1; i > scale; i = i - scale) { uint32_t length = i; EXPECT_EQ(LineEcmaString::ComputeSizeUtf8(length), length + LineEcmaString::SIZE); } } /* * @tc.name: ComputeSizeUtf16 * @tc.desc: Check whether the value returned through calling ComputeSizeUtf16 function is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(LineEcmaStringTest, ComputeSizeUtf16) { uint32_t scale = 3333; for (uint32_t i = EcmaString::MAX_STRING_LENGTH - 1; i > scale; i = i - scale) { uint32_t length = i; EXPECT_EQ(LineEcmaString::ComputeSizeUtf16(length), 2 * length + LineEcmaString::SIZE); } } class EcmaStringAccessorTest : public testing::Test { public: static void SetUpTestCase() { GTEST_LOG_(INFO) << "SetUpTestCase"; } static void TearDownTestCase() { GTEST_LOG_(INFO) << "TearDownCase"; } void SetUp() override { TestHelper::CreateEcmaVMWithScope(ecmaVMPtr, thread, scope); } void TearDown() override { TestHelper::DestroyEcmaVMWithScope(ecmaVMPtr, scope); } EcmaVM *ecmaVMPtr {nullptr}; ecmascript::EcmaHandleScope *scope {nullptr}; JSThread *thread {nullptr}; }; /* * @tc.name: CreateLineString * @tc.desc: Check whether the EcmaString created through calling CreateLineString function is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, CreateLineString) { // CreateLineString( , true, ). size_t sizeAllocComp = 5; JSHandle handleEcmaStrAllocComp(thread, EcmaStringAccessor::CreateLineString(ecmaVMPtr, sizeAllocComp, true)); for (uint32_t i = 0; i < sizeAllocComp; i++) { EXPECT_EQ(EcmaStringAccessor(handleEcmaStrAllocComp).Get(i), 0U); } EXPECT_EQ(EcmaStringAccessor(handleEcmaStrAllocComp).GetLength(), sizeAllocComp); EXPECT_TRUE(EcmaStringAccessor(handleEcmaStrAllocComp).IsUtf8()); EXPECT_FALSE(EcmaStringAccessor(handleEcmaStrAllocComp).IsUtf16()); // CreateLineString( , false, ). size_t sizeAllocNotComp = 5; JSHandle handleEcmaStrAllocNotComp(thread, EcmaStringAccessor::CreateLineString(ecmaVMPtr, sizeAllocNotComp, false)); for (uint32_t i = 0; i < sizeAllocNotComp; i++) { EXPECT_EQ(EcmaStringAccessor(handleEcmaStrAllocNotComp).Get(i), 0U); } EXPECT_EQ(EcmaStringAccessor(handleEcmaStrAllocNotComp).GetLength(), sizeAllocNotComp); EXPECT_FALSE(EcmaStringAccessor(handleEcmaStrAllocNotComp).IsUtf8()); EXPECT_TRUE(EcmaStringAccessor(handleEcmaStrAllocNotComp).IsUtf16()); } /* * @tc.name: CreateEmptyString * @tc.desc: Check whether the EcmaString created through calling CreateEmptyString function is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, CreateEmptyString) { JSHandle handleEcmaStrEmpty(thread, EcmaStringAccessor::CreateEmptyString(ecmaVMPtr)); EXPECT_EQ(EcmaStringAccessor(handleEcmaStrEmpty).GetLength(), 0U); EXPECT_TRUE(EcmaStringAccessor(handleEcmaStrEmpty).IsUtf8()); EXPECT_FALSE(EcmaStringAccessor(handleEcmaStrEmpty).IsUtf16()); } /* * @tc.name: CreateFromUtf8 * @tc.desc: Check whether the EcmaString created through calling CreateFromUtf8 function is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, CreateFromUtf8) { uint8_t arrayU8[] = {"xyz123!@#"}; size_t lengthEcmaStrU8 = sizeof(arrayU8) - 1; JSHandle handleEcmaStrU8(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8[0], lengthEcmaStrU8, true)); for (uint32_t i = 0; i < lengthEcmaStrU8; i++) { EXPECT_EQ(arrayU8[i], EcmaStringAccessor(handleEcmaStrU8).Get(i)); } EXPECT_EQ(EcmaStringAccessor(handleEcmaStrU8).GetLength(), lengthEcmaStrU8); EXPECT_TRUE(EcmaStringAccessor(handleEcmaStrU8).IsUtf8()); EXPECT_FALSE(EcmaStringAccessor(handleEcmaStrU8).IsUtf16()); } /* * @tc.name: CreateFromUtf16 * @tc.desc: Check whether the EcmaString created through calling CreateFromUtf16 function is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, CreateFromUtf16) { // CreateFromUtf16( , , , true). uint16_t arrayU16Comp[] = {1, 23, 45, 67, 127}; size_t lengthEcmaStrU16Comp = sizeof(arrayU16Comp) / sizeof(arrayU16Comp[0]); JSHandle handleEcmaStrU16Comp(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16Comp[0], lengthEcmaStrU16Comp, true)); EXPECT_EQ(EcmaStringAccessor(handleEcmaStrU16Comp).GetLength(), lengthEcmaStrU16Comp); EXPECT_TRUE(EcmaStringAccessor(handleEcmaStrU16Comp).IsUtf8()); EXPECT_FALSE(EcmaStringAccessor(handleEcmaStrU16Comp).IsUtf16()); // CreateFromUtf16( , , , false). uint16_t arrayU16NotComp[] = {127, 33, 128, 12, 256, 11100, 65535}; size_t lengthEcmaStrU16NotComp = sizeof(arrayU16NotComp) / sizeof(arrayU16NotComp[0]); JSHandle handleEcmaStrU16NotComp(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotComp[0], lengthEcmaStrU16NotComp, false)); EXPECT_EQ(EcmaStringAccessor(handleEcmaStrU16NotComp).GetLength(), lengthEcmaStrU16NotComp); EXPECT_FALSE(EcmaStringAccessor(handleEcmaStrU16NotComp).IsUtf8()); EXPECT_TRUE(EcmaStringAccessor(handleEcmaStrU16NotComp).IsUtf16()); } /* * @tc.name: Concat_001 * @tc.desc: Check whether the EcmaString returned through calling Concat function between EcmaString made by * CreateFromUtf8() and EcmaString made by CreateFromUtf8() is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, Concat_001) { // Concat(). EcmaString made by CreateFromUtf8() and EcmaString made by CreateFromUtf8(). uint8_t arrayFrontU8[] = {"abcdef"}; uint8_t arrayBackU8[] = {"ABCDEF"}; uint32_t lengthEcmaStrFrontU8 = sizeof(arrayFrontU8) - 1; uint32_t lengthEcmaStrBackU8 = sizeof(arrayBackU8) - 1; JSHandle handleEcmaStrFrontU8(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayFrontU8[0], lengthEcmaStrFrontU8, true)); JSHandle handleEcmaStrBackU8(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayBackU8[0], lengthEcmaStrBackU8, true)); JSHandle handleEcmaStrConcatU8(thread, EcmaStringAccessor::Concat(ecmaVMPtr, handleEcmaStrFrontU8, handleEcmaStrBackU8)); EXPECT_TRUE(EcmaStringAccessor(handleEcmaStrConcatU8).IsUtf8()); for (uint32_t i = 0; i < lengthEcmaStrFrontU8; i++) { EXPECT_EQ(EcmaStringAccessor(handleEcmaStrConcatU8).Get(i), arrayFrontU8[i]); } for (uint32_t i = 0; i < lengthEcmaStrBackU8; i++) { EXPECT_EQ(EcmaStringAccessor(handleEcmaStrConcatU8).Get(i + lengthEcmaStrFrontU8), arrayBackU8[i]); } EXPECT_EQ(EcmaStringAccessor(handleEcmaStrConcatU8).GetLength(), lengthEcmaStrFrontU8 + lengthEcmaStrBackU8); } /* * @tc.name: Concat_002 * @tc.desc: Check whether the EcmaString returned through calling Concat function between EcmaString made by * CreateFromUtf16( , , , false) and EcmaString made by CreateFromUtf16( , , , false) is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, Concat_002) { // Concat(). EcmaString made by CreateFromUtf16( , , , false) and EcmaString made by CreateFromUtf16( , , , false). uint16_t arrayFrontU16NotComp[] = {128, 129, 256, 11100, 65535, 100}; uint16_t arrayBackU16NotComp[] = {88, 768, 1, 270, 345, 333}; uint32_t lengthEcmaStrFrontU16NotComp = sizeof(arrayFrontU16NotComp) / sizeof(arrayFrontU16NotComp[0]); uint32_t lengthEcmaStrBackU16NotComp = sizeof(arrayBackU16NotComp) / sizeof(arrayBackU16NotComp[0]); JSHandle handleEcmaStrFrontU16NotComp(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayFrontU16NotComp[0], lengthEcmaStrFrontU16NotComp, false)); JSHandle handleEcmaStrBackU16NotComp(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayBackU16NotComp[0], lengthEcmaStrBackU16NotComp, false)); JSHandle handleEcmaStrConcatU16NotComp(thread, EcmaStringAccessor::Concat(ecmaVMPtr, handleEcmaStrFrontU16NotComp, handleEcmaStrBackU16NotComp)); EXPECT_TRUE(EcmaStringAccessor(handleEcmaStrConcatU16NotComp).IsUtf16()); for (uint32_t i = 0; i < lengthEcmaStrFrontU16NotComp; i++) { EXPECT_EQ(EcmaStringAccessor(handleEcmaStrConcatU16NotComp).Get(i), arrayFrontU16NotComp[i]); } for (uint32_t i = 0; i < lengthEcmaStrBackU16NotComp; i++) { EXPECT_EQ(EcmaStringAccessor(handleEcmaStrConcatU16NotComp).Get(i + lengthEcmaStrFrontU16NotComp), arrayBackU16NotComp[i]); } EXPECT_EQ(EcmaStringAccessor(handleEcmaStrConcatU16NotComp).GetLength(), lengthEcmaStrFrontU16NotComp + lengthEcmaStrBackU16NotComp); } /* * @tc.name: Concat_003 * @tc.desc: Check whether the EcmaString returned through calling Concat function between EcmaString made by * CreateFromUtf8() and EcmaString made by CreateFromUtf16( , , , false) is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, Concat_003) { // Concat(). EcmaString made by CreateFromUtf8() and EcmaString made by CreateFromUtf16( , , , false). uint8_t arrayFrontU8[] = {"abcdef"}; uint16_t arrayBackU16NotComp[] = {88, 768, 1, 270, 345, 333}; uint32_t lengthEcmaStrFrontU8 = sizeof(arrayFrontU8) - 1; uint32_t lengthEcmaStrBackU16NotComp = sizeof(arrayBackU16NotComp) / sizeof(arrayBackU16NotComp[0]); JSHandle handleEcmaStrFrontU8(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayFrontU8[0], lengthEcmaStrFrontU8, true)); JSHandle handleEcmaStrBackU16NotComp(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayBackU16NotComp[0], lengthEcmaStrBackU16NotComp, false)); JSHandle handleEcmaStrConcatU8U16NotComp(thread, EcmaStringAccessor::Concat(ecmaVMPtr, handleEcmaStrFrontU8, handleEcmaStrBackU16NotComp)); EXPECT_TRUE(EcmaStringAccessor(handleEcmaStrConcatU8U16NotComp).IsUtf16()); for (uint32_t i = 0; i < lengthEcmaStrFrontU8; i++) { EXPECT_EQ(EcmaStringAccessor(handleEcmaStrConcatU8U16NotComp).Get(i), arrayFrontU8[i]); } for (uint32_t i = 0; i < lengthEcmaStrBackU16NotComp; i++) { EXPECT_EQ(EcmaStringAccessor(handleEcmaStrConcatU8U16NotComp).Get(i + lengthEcmaStrFrontU8), arrayBackU16NotComp[i]); } EXPECT_EQ(EcmaStringAccessor(handleEcmaStrConcatU8U16NotComp).GetLength(), lengthEcmaStrFrontU8 + lengthEcmaStrBackU16NotComp); } /* * @tc.name: FastSubString_001 * @tc.desc: Check whether the EcmaString returned through calling FastSubString function from EcmaString made by * CreateFromUtf8() is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, FastSubString_001) { // FastSubString(). From EcmaString made by CreateFromUtf8(). uint8_t arrayU8[6] = {3, 7, 19, 54, 99}; uint32_t lengthEcmaStrU8 = sizeof(arrayU8) - 1; JSHandle handleEcmaStrU8(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8[0], lengthEcmaStrU8, true)); uint32_t indexStartSubU8 = 2; uint32_t lengthSubU8 = 2; JSHandle handleEcmaStrSubU8(thread, EcmaStringAccessor::FastSubString(ecmaVMPtr, handleEcmaStrU8, indexStartSubU8, lengthSubU8)); for (uint32_t i = 0; i < lengthSubU8; i++) { EXPECT_EQ(EcmaStringAccessor(handleEcmaStrSubU8).Get(i), EcmaStringAccessor(handleEcmaStrU8).Get(i + indexStartSubU8)); } EXPECT_EQ(EcmaStringAccessor(handleEcmaStrSubU8).GetLength(), lengthSubU8); } /* * @tc.name: FastSubString_002 * @tc.desc: Check whether the EcmaString returned through calling FastSubString function from EcmaString made by * CreateFromUtf16( , , , true) is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, FastSubString_002) { // FastSubString(). From EcmaString made by CreateFromUtf16( , , , true). uint16_t arrayU16Comp[] = {1, 12, 34, 56, 127}; uint32_t lengthEcmaStrU16Comp = sizeof(arrayU16Comp) / sizeof(arrayU16Comp[0]); JSHandle handleEcmaStrU16Comp(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16Comp[0], lengthEcmaStrU16Comp, true)); uint32_t indexStartSubU16Comp = 0; uint32_t lengthSubU16Comp = 2; JSHandle handleEcmaStrSubU16Comp(thread, EcmaStringAccessor::FastSubString(ecmaVMPtr, handleEcmaStrU16Comp, indexStartSubU16Comp, lengthSubU16Comp)); for (uint32_t i = 0; i < lengthSubU16Comp; i++) { EXPECT_EQ(EcmaStringAccessor(handleEcmaStrSubU16Comp).Get(i), EcmaStringAccessor(handleEcmaStrU16Comp).Get(i + indexStartSubU16Comp)); } EXPECT_EQ(EcmaStringAccessor(handleEcmaStrSubU16Comp).GetLength(), lengthSubU16Comp); } /* * @tc.name: FastSubString_003 * @tc.desc: Check whether the EcmaString returned through calling FastSubString function from EcmaString made by * CreateFromUtf16( , , , false) is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, FastSubString_003) { // FastSubString(). From EcmaString made by CreateFromUtf16( , , , false). uint16_t arrayU16NotComp[] = {19, 54, 256, 11100, 65535}; uint32_t lengthEcmaStrU16NotComp = sizeof(arrayU16NotComp) / sizeof(arrayU16NotComp[0]); JSHandle handleEcmaStrU16NotComp(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotComp[0], lengthEcmaStrU16NotComp, false)); uint32_t indexStartSubU16NotComp = 0; uint32_t lengthSubU16NotComp = 2; JSHandle handleEcmaStrSubU16NotComp(thread, EcmaStringAccessor::FastSubString( ecmaVMPtr, handleEcmaStrU16NotComp, indexStartSubU16NotComp, lengthSubU16NotComp)); for (uint32_t i = 0; i < lengthSubU16NotComp; i++) { EXPECT_EQ(EcmaStringAccessor(handleEcmaStrSubU16NotComp).Get(i), EcmaStringAccessor(handleEcmaStrU16NotComp).Get(i + indexStartSubU16NotComp)); } EXPECT_EQ(EcmaStringAccessor(handleEcmaStrSubU16NotComp).GetLength(), lengthSubU16NotComp); } /* * @tc.name: FastSubString_004 * @tc.desc: Check whether the EcmaString returned through calling FastSubString function from EcmaString * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, FastSubString_004) { ObjectFactory* factory = ecmaVMPtr->GetFactory(); { JSHandle sourceString = factory->NewFromUtf8("整数integer"); JSHandle tmpString = factory->NewFromASCII("integer"); EXPECT_TRUE(EcmaStringAccessor(sourceString).IsUtf16()); EcmaString *res = EcmaStringAccessor::FastSubString(ecmaVMPtr, sourceString, 2, 7); EXPECT_TRUE(EcmaStringAccessor(res).IsUtf8()); EXPECT_TRUE(EcmaStringAccessor::StringsAreEqual(res, *tmpString)); } { JSHandle sourceString = factory->NewFromUtf8("整数integer"); JSHandle tmpString = factory->NewFromUtf8("整数"); EXPECT_TRUE(EcmaStringAccessor(sourceString).IsUtf16()); EcmaString *res = EcmaStringAccessor::FastSubString(ecmaVMPtr, sourceString, 0, 2); EXPECT_TRUE(EcmaStringAccessor(res).IsUtf16()); EXPECT_TRUE(EcmaStringAccessor::StringsAreEqual(res, *tmpString)); } { JSHandle sourceString = factory->NewFromUtf8("整数integer"); JSHandle tmpString = factory->NewFromUtf8("数intege"); EXPECT_TRUE(EcmaStringAccessor(sourceString).IsUtf16()); EcmaString *res = EcmaStringAccessor::FastSubString(ecmaVMPtr, sourceString, 1, 7); EXPECT_TRUE(EcmaStringAccessor(res).IsUtf16()); EXPECT_TRUE(EcmaStringAccessor::StringsAreEqual(res, *tmpString)); } { JSHandle sourceString = factory->NewFromASCII("integer123"); JSHandle tmpString = factory->NewFromASCII("integer"); EXPECT_TRUE(EcmaStringAccessor(sourceString).IsUtf8()); EcmaString *res = EcmaStringAccessor::FastSubString(ecmaVMPtr, sourceString, 0, 7); EXPECT_TRUE(EcmaStringAccessor(res).IsUtf8()); EXPECT_TRUE(EcmaStringAccessor::StringsAreEqual(res, *tmpString)); } } /* * @tc.name: GetUtf8Length * @tc.desc: Check whether the value returned through calling GetUtf8Length function is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, GetUtf8Length) { uint8_t arrayU8[6] = {3, 7, 19, 54, 99}; uint16_t arrayU16Comp[] = {1, 12, 34, 56, 127}; uint16_t arrayU16NotComp[] = {19, 54, 256, 11100, 65535}; uint32_t lengthEcmaStrU8 = sizeof(arrayU8) - 1; uint32_t lengthEcmaStrU16Comp = sizeof(arrayU16Comp) / sizeof(arrayU16Comp[0]); uint32_t lengthEcmaStrU16NotComp = sizeof(arrayU16NotComp) / sizeof(arrayU16NotComp[0]); JSHandle handleEcmaStrU8(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8[0], lengthEcmaStrU8, true)); JSHandle handleEcmaStrU16Comp(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16Comp[0], lengthEcmaStrU16Comp, true)); JSHandle handleEcmaStrU16NotComp(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotComp[0], lengthEcmaStrU16NotComp, false)); EXPECT_EQ(EcmaStringAccessor(handleEcmaStrU8).GetUtf8Length(), lengthEcmaStrU8 + 1); EXPECT_EQ(EcmaStringAccessor(handleEcmaStrU16Comp).GetUtf8Length(), lengthEcmaStrU16Comp + 1); EXPECT_EQ(EcmaStringAccessor(handleEcmaStrU16NotComp).GetUtf8Length(), 2 * lengthEcmaStrU16NotComp + 1); } /* * @tc.name: ObjectSize * @tc.desc: Check whether the value returned through calling ObjectSize function is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, ObjectSize) { JSHandle handleEcmaStrEmpty(thread, EcmaStringAccessor::CreateEmptyString(ecmaVMPtr)); EXPECT_EQ(EcmaStringAccessor(handleEcmaStrEmpty).ObjectSize(), EcmaString::SIZE + 0); size_t lengthEcmaStrAllocComp = 5; JSHandle handleEcmaStrAllocComp(thread, EcmaStringAccessor::CreateLineString(ecmaVMPtr, lengthEcmaStrAllocComp, true)); EXPECT_EQ(EcmaStringAccessor(handleEcmaStrAllocComp).ObjectSize(), EcmaString::SIZE + sizeof(uint8_t) * lengthEcmaStrAllocComp); size_t lengthEcmaStrAllocNotComp = 5; JSHandle handleEcmaStrAllocNotComp(thread, EcmaStringAccessor::CreateLineString(ecmaVMPtr, lengthEcmaStrAllocNotComp, false)); EXPECT_EQ(EcmaStringAccessor(handleEcmaStrAllocNotComp).ObjectSize(), EcmaString::SIZE + sizeof(uint16_t) * lengthEcmaStrAllocNotComp); uint8_t arrayU8[] = {"abcde"}; size_t lengthEcmaStrU8 = sizeof(arrayU8) - 1; JSHandle handleEcmaStrU8(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8[0], lengthEcmaStrU8, true)); EXPECT_EQ(EcmaStringAccessor(handleEcmaStrU8).ObjectSize(), EcmaString::SIZE + sizeof(uint8_t) * lengthEcmaStrU8); // ObjectSize(). EcmaString made by CreateFromUtf16( , , , true). uint16_t arrayU16Comp[] = {1, 23, 45, 67, 127}; size_t lengthEcmaStrU16Comp = sizeof(arrayU16Comp) / sizeof(arrayU16Comp[0]); JSHandle handleEcmaStrU16Comp(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16Comp[0], lengthEcmaStrU16Comp, true)); EXPECT_EQ(EcmaStringAccessor(handleEcmaStrU16Comp).ObjectSize(), EcmaString::SIZE + sizeof(uint8_t) * lengthEcmaStrU16Comp); // ObjectSize(). EcmaString made by CreateFromUtf16( , , , false). uint16_t arrayU16NotComp[] = {127, 128, 256, 11100, 65535}; size_t lengthEcmaStrU16NotComp = sizeof(arrayU16NotComp) / sizeof(arrayU16NotComp[0]); JSHandle handleEcmaStrU16NotComp(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotComp[0], lengthEcmaStrU16NotComp, false)); EXPECT_EQ(EcmaStringAccessor(handleEcmaStrU16NotComp).ObjectSize(), EcmaString::SIZE + sizeof(uint16_t) * lengthEcmaStrU16NotComp); } /* * @tc.name: SetInternString * @tc.desc: Call SetInternString function, check whether the bool returned through calling IsInternString function * is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, SetInternString) { uint8_t arrayU8[] = {"abc"}; uint32_t lengthEcmaStrU8 = sizeof(arrayU8) - 1; JSHandle handleEcmaStrU8(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8[0], lengthEcmaStrU8, true)); EXPECT_FALSE(EcmaStringAccessor(handleEcmaStrU8).IsInternString()); EcmaStringAccessor(handleEcmaStrU8).SetInternString(); EXPECT_TRUE(EcmaStringAccessor(handleEcmaStrU8).IsInternString()); uint16_t arrayU16Comp[] = {97, 98, 99}; uint32_t lengthEcmaStrU16Comp = sizeof(arrayU16Comp) / sizeof(arrayU16Comp[0]); JSHandle handleEcmaStrU16Comp(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16Comp[0], lengthEcmaStrU16Comp, true)); EXPECT_FALSE(EcmaStringAccessor(handleEcmaStrU16Comp).IsInternString()); EcmaStringAccessor(handleEcmaStrU16Comp).SetInternString(); EXPECT_TRUE(EcmaStringAccessor(handleEcmaStrU16Comp).IsInternString()); uint16_t arrayU16NotComp[] = {97, 98, 99}; uint32_t lengthEcmaStrU16NotComp = sizeof(arrayU16NotComp) / sizeof(arrayU16NotComp[0]); JSHandle handleEcmaStrU16NotComp(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotComp[0], lengthEcmaStrU16NotComp, true)); EXPECT_FALSE(EcmaStringAccessor(handleEcmaStrU16NotComp).IsInternString()); EcmaStringAccessor(handleEcmaStrU16NotComp).SetInternString(); EXPECT_TRUE(EcmaStringAccessor(handleEcmaStrU16NotComp).IsInternString()); } /* * @tc.name: GetDataUtf8 * @tc.desc: Check whether the pointer returned through calling GetDataUtf8 function is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, GetDataUtf8) { // From EcmaString made by CreateFromUtf8(). uint8_t arrayU8[] = {"abcde"}; uint32_t lengthEcmaStrU8 = sizeof(arrayU8) - 1; JSHandle handleEcmaStrU8(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8[0], lengthEcmaStrU8, true)); for (uint32_t i = 0; i < lengthEcmaStrU8; i++) { EXPECT_EQ(*(EcmaStringAccessor(handleEcmaStrU8).GetDataUtf8() + i), arrayU8[i]); } // From EcmaString made by CreateFromUtf16( , , , true). uint16_t arrayU16Comp[] = {3, 1, 34, 123, 127, 111, 42, 3, 20, 10}; uint32_t lengthEcmaStrU16Comp = sizeof(arrayU16Comp) / sizeof(arrayU16Comp[0]); JSHandle handleEcmaStrU16Comp(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16Comp[0], lengthEcmaStrU16Comp, true)); for (uint32_t i = 0; i < sizeof(arrayU16Comp) / arrayU16Comp[0]; i++) { EXPECT_EQ(*(EcmaStringAccessor(handleEcmaStrU16Comp).GetDataUtf8() + i), arrayU16Comp[i]); } } /* * @tc.name: GetDataUtf16 * @tc.desc: Check whether the pointer returned through calling GetDataUtf16 function is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, GetDataUtf16) { // From EcmaString made by CreateFromUtf16( , , , false). uint16_t arrayU16NotComp[] = {67, 777, 1999, 1, 45, 66, 23456, 65535, 127, 333}; uint32_t lengthEcmaStrU16NotComp = sizeof(arrayU16NotComp) / sizeof(arrayU16NotComp[0]); JSHandle handleEcmaStrU16NotComp(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotComp[0], lengthEcmaStrU16NotComp, false)); for (uint32_t i = 0; i < lengthEcmaStrU16NotComp; i++) { EXPECT_EQ(*(EcmaStringAccessor(handleEcmaStrU16NotComp).GetDataUtf16() + i), arrayU16NotComp[i]); } } /* * @tc.name: WriteToFlatUtf8 * @tc.desc: Check whether the returned value and the changed array through a source EcmaString's calling * WriteToFlatUtf8 function are within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, WriteToFlatUtf8) { // WriteToFlatUtf8(). From EcmaString made by CreateFromUtf8(). uint8_t arrayU8CopyFrom[6] = {1, 12, 34, 56, 127}; uint32_t lengthEcmaStrU8CopyFrom = sizeof(arrayU8CopyFrom) - 1; JSHandle handleEcmaStrU8CopyFrom(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8CopyFrom[0], lengthEcmaStrU8CopyFrom, true)); const size_t lengthArrayU8Target = 6; uint8_t arrayU8CopyTo[lengthArrayU8Target]; size_t lengthReturnU8 = EcmaStringAccessor(handleEcmaStrU8CopyFrom) .WriteToFlatUtf8(&arrayU8CopyTo[0], lengthArrayU8Target); EXPECT_EQ(lengthReturnU8, lengthArrayU8Target); for (uint32_t i = 0; i < lengthReturnU8 - 1; i++) { EXPECT_EQ(arrayU8CopyTo[i], arrayU8CopyFrom[i]); } EXPECT_EQ(arrayU8CopyTo[lengthReturnU8 - 1], 0); // CopyDataUtf8(). From EcmaString made by CreateFromUtf16( , , , true). uint16_t arrayU16CompCopyFrom[] = {1, 12, 34, 56, 127}; uint32_t lengthEcmaStrU16CompCopyFrom = sizeof(arrayU16CompCopyFrom) / sizeof(arrayU16CompCopyFrom[0]); JSHandle handleEcmaStrU16CompCopyFrom(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompCopyFrom[0], lengthEcmaStrU16CompCopyFrom, true)); const size_t lengthArrayU16Target = 6; uint8_t arrayU8CompCopyTo[lengthArrayU16Target]; size_t lengthReturnU16Comp = EcmaStringAccessor(handleEcmaStrU16CompCopyFrom) .WriteToFlatUtf8(&arrayU8CompCopyTo[0], lengthArrayU16Target); EXPECT_EQ(lengthReturnU16Comp, lengthArrayU16Target); for (uint32_t i = 0; i < lengthReturnU16Comp - 1; i++) { EXPECT_EQ(arrayU8CompCopyTo[i], arrayU16CompCopyFrom[i]); } EXPECT_EQ(arrayU8CompCopyTo[lengthReturnU16Comp - 1], 0U); } /* * @tc.name: WriteToFlatUtf16 * @tc.desc: Check whether the returned value and the changed array through a source EcmaString's calling * WriteToFlatUtf16 function are within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, WriteToFlatUtf16) { // WriteToFlatUtf16(). From EcmaString made by CreateFromUtf16( , , , false). uint16_t arrayU16NotCompCopyFrom[10] = {67, 777, 1999, 1, 45, 66, 23456, 65535, 127, 333}; uint32_t lengthEcmaStrU16NotCompCopyFrom = sizeof(arrayU16NotCompCopyFrom) / sizeof(arrayU16NotCompCopyFrom[0]); JSHandle handleEcmaStrU16NotCompCopyFrom(thread, EcmaStringAccessor::CreateFromUtf16( ecmaVMPtr, &arrayU16NotCompCopyFrom[0], lengthEcmaStrU16NotCompCopyFrom, false)); const size_t lengthArrayU16Target = 13; uint16_t arrayU16NotCompCopyTo[lengthArrayU16Target]; uint8_t defaultOneByteValueOfArrayU16NotCompCopyTo = 244; int checkResUtf16 = memset_s(&arrayU16NotCompCopyTo[0], sizeof(uint16_t) * lengthArrayU16Target, defaultOneByteValueOfArrayU16NotCompCopyTo, sizeof(uint16_t) * lengthArrayU16Target); EXPECT_TRUE(checkResUtf16 == 0); size_t lengthReturnU16NotComp = EcmaStringAccessor(handleEcmaStrU16NotCompCopyFrom) .WriteToFlatUtf16(&arrayU16NotCompCopyTo[0], lengthArrayU16Target); EXPECT_EQ(lengthReturnU16NotComp, lengthEcmaStrU16NotCompCopyFrom); for (uint32_t i = 0; i < lengthReturnU16NotComp; i++) { EXPECT_EQ(arrayU16NotCompCopyTo[i], EcmaStringAccessor(handleEcmaStrU16NotCompCopyFrom).Get(i)); } for (uint32_t i = lengthReturnU16NotComp; i < lengthArrayU16Target; i++) { EXPECT_EQ(arrayU16NotCompCopyTo[i], ((uint16_t)defaultOneByteValueOfArrayU16NotCompCopyTo) * (1 + (1 << 8))); } } /* * @tc.name: ReadData_001 * @tc.desc: Check whether the target EcmaString made by CreateLineString( , true, ) changed through calling ReadData * function with a source EcmaString made by CreateFromUtf8() is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, ReadData_001) { // ReadData(). From EcmaString made by CreateFromUtf8() to EcmaString made by CreateLineString( , true, ). uint8_t arrayU8WriteFrom[6] = {1, 12, 34, 56, 127}; uint32_t lengthEcmaStrU8WriteFrom = sizeof(arrayU8WriteFrom) - 1; JSHandle handleEcmaStrU8WriteFrom(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8WriteFrom[0], lengthEcmaStrU8WriteFrom, true)); size_t sizeEcmaStrU8WriteTo = 5; JSHandle handleEcmaStrAllocTrueWriteTo(thread, EcmaStringAccessor::CreateLineString(ecmaVMPtr, sizeEcmaStrU8WriteTo, true)); uint32_t indexStartWriteFromArrayU8 = 2; uint32_t lengthWriteFromArrayU8 = 2; EcmaStringAccessor::ReadData(*handleEcmaStrAllocTrueWriteTo, *handleEcmaStrU8WriteFrom, indexStartWriteFromArrayU8, sizeEcmaStrU8WriteTo, lengthWriteFromArrayU8); for (uint32_t i = 0; i < lengthWriteFromArrayU8; i++) { EXPECT_EQ(EcmaStringAccessor(handleEcmaStrAllocTrueWriteTo).Get(i + indexStartWriteFromArrayU8), EcmaStringAccessor(handleEcmaStrU8WriteFrom).Get(i)); } } /* * @tc.name: ReadData_002 * @tc.desc: Check whether the target EcmaString made by CreateLineString( , false, ) changed through calling * ReadData function with a source EcmaString made by CreateFromUtf16( , , , false) is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, ReadData_002) { /* ReadData(). From EcmaString made by CreateFromUtf16( , , , false) to EcmaStringU16 made by * CreateLineString( , false, ). */ uint16_t arrayU16WriteFrom[10] = {67, 777, 1999, 1, 45, 66, 23456, 65535, 127, 333}; uint32_t lengthEcmaStrU16WriteFrom = sizeof(arrayU16WriteFrom) / sizeof(arrayU16WriteFrom[0]); JSHandle handleEcmaStrU16WriteFrom(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16WriteFrom[0], lengthEcmaStrU16WriteFrom, false)); size_t sizeEcmaStrU16WriteTo = 10; JSHandle handleEcmaStrU16WriteTo(thread, EcmaStringAccessor::CreateLineString(ecmaVMPtr, sizeEcmaStrU16WriteTo, false)); uint32_t indexStartWriteFromArrayU16 = 3; uint32_t numBytesWriteFromArrayU16 = 2 * 3; EcmaStringAccessor::ReadData(*handleEcmaStrU16WriteTo, *handleEcmaStrU16WriteFrom, indexStartWriteFromArrayU16, sizeEcmaStrU16WriteTo, numBytesWriteFromArrayU16); for (uint32_t i = 0; i < (numBytesWriteFromArrayU16 / 2); i++) { EXPECT_EQ(EcmaStringAccessor(handleEcmaStrU16WriteTo).Get(i + indexStartWriteFromArrayU16), EcmaStringAccessor(handleEcmaStrU16WriteFrom).Get(i)); } } /* * @tc.name: ReadData_003 * @tc.desc: Check whether the target EcmaString made by CreateLineString( , false, ) changed through calling * ReadData function with a source EcmaString made by CreateFromUtf8() is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, ReadData_003) { // ReadData(). From EcmaString made by CreateFromUtf8() to EcmaString made by CreateLineString( , false, ). uint8_t arrayU8WriteFrom[6] = {1, 12, 34, 56, 127}; uint32_t lengthEcmaStrU8WriteFrom = sizeof(arrayU8WriteFrom) - 1; JSHandle handleEcmaStrU8WriteFrom(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8WriteFrom[0], lengthEcmaStrU8WriteFrom, true)); size_t sizeEcmaStrU16WriteTo = 10; JSHandle handleEcmaStrU16WriteTo(thread, EcmaStringAccessor::CreateLineString(ecmaVMPtr, sizeEcmaStrU16WriteTo, false)); uint32_t indexStartWriteFromU8ToU16 = 1; uint32_t numBytesWriteFromU8ToU16 = 4; EcmaStringAccessor::ReadData(*handleEcmaStrU16WriteTo, *handleEcmaStrU8WriteFrom, indexStartWriteFromU8ToU16, sizeEcmaStrU16WriteTo, numBytesWriteFromU8ToU16); for (uint32_t i = 0; i < numBytesWriteFromU8ToU16; i++) { EXPECT_EQ(EcmaStringAccessor(handleEcmaStrU16WriteTo).Get(i + indexStartWriteFromU8ToU16), EcmaStringAccessor(handleEcmaStrU8WriteFrom).Get(i)); } } /* * @tc.name: Set_001 * @tc.desc: Check whether the target EcmaString made by CreateLineString( , true, ) changed through calling Set * function from a source char is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, Set_001) { // Set(). From char to EcmaString made by CreateLineString( , true, ). char u8Write = 'a'; size_t sizeEcmaStrU8WriteTo = 5; JSHandle handleEcmaStrAllocTrueWriteTo(thread, EcmaStringAccessor::CreateLineString(ecmaVMPtr, sizeEcmaStrU8WriteTo, true)); uint32_t indexAtWriteFromU8 = 4; EcmaStringAccessor(handleEcmaStrAllocTrueWriteTo).Set(indexAtWriteFromU8, u8Write); EXPECT_EQ(EcmaStringAccessor(handleEcmaStrAllocTrueWriteTo).Get(indexAtWriteFromU8), u8Write); } /* * @tc.name: Set_002 * @tc.desc: Check whether the target EcmaString made by CreateLineString( , false, ) changed through calling * Set function with a source char is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, Set_002) { // Set(). From char to EcmaString made by CreateLineString( , false, ). size_t sizeEcmaStrU16WriteTo = 10; JSHandle handleEcmaStrU16WriteTo(thread, EcmaStringAccessor::CreateLineString(ecmaVMPtr, sizeEcmaStrU16WriteTo, false)); char u8Write = 'a'; uint32_t indexAt = 4; EcmaStringAccessor(handleEcmaStrU16WriteTo).Set(indexAt, u8Write); EXPECT_EQ(EcmaStringAccessor(handleEcmaStrU16WriteTo).Get(indexAt), u8Write); } /* * @tc.name: GetHashcode_001 * @tc.desc: Check whether the value returned through an EcmaString made by CreateFromUtf8() calling GetHashcode * function is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, GetHashcode_001) { // GetHashcode(). EcmaString made by CreateFromUtf8(). uint8_t arrayU8[] = {"abc"}; uint32_t lengthEcmaStrU8 = sizeof(arrayU8) - 1; JSHandle handleEcmaStrU8(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8[0], lengthEcmaStrU8, true)); uint32_t hashExpect = 0; for (uint32_t i = 0; i < lengthEcmaStrU8; i++) { hashExpect = hashExpect * 31 + arrayU8[i]; } EXPECT_EQ(EcmaStringAccessor(handleEcmaStrU8).GetHashcode(), hashExpect); } /* * @tc.name: GetHashcode_002 * @tc.desc: Check whether the value returned through an EcmaString made by CreateFromUtf16( , , , true) calling * GetHashcode function is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, GetHashcode_002) { // GetHashcode(). EcmaString made by CreateFromUtf16( , , , true). uint16_t arrayU16Comp[] = {45, 92, 78, 24}; uint32_t lengthEcmaStrU16Comp = sizeof(arrayU16Comp) / sizeof(arrayU16Comp[0]); JSHandle handleEcmaStrU16Comp(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16Comp[0], lengthEcmaStrU16Comp, true)); uint32_t hashExpect = 0; for (uint32_t i = 0; i < lengthEcmaStrU16Comp; i++) { hashExpect = hashExpect * 31 + arrayU16Comp[i]; } EXPECT_EQ(EcmaStringAccessor(handleEcmaStrU16Comp).GetHashcode(), hashExpect); } /* * @tc.name: GetHashcode_003 * @tc.desc: Check whether the value returned through an EcmaString made by CreateFromUtf16( , , , false) calling * GetHashcode function is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, GetHashcode_003) { // GetHashcode(). EcmaString made by CreateFromUtf16( , , , false). uint16_t arrayU16NotComp[] = {199, 1, 256, 65535, 777}; uint32_t lengthEcmaStrU16NotComp = sizeof(arrayU16NotComp) / sizeof(arrayU16NotComp[0]); JSHandle handleEcmaStrU16NotComp(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotComp[0], lengthEcmaStrU16NotComp, false)); uint32_t hashExpect = 0; for (uint32_t i = 0; i < lengthEcmaStrU16NotComp; i++) { hashExpect = hashExpect * 31 + arrayU16NotComp[i]; } EXPECT_EQ(EcmaStringAccessor(handleEcmaStrU16NotComp).GetHashcode(), hashExpect); } /* * @tc.name: GetHashcode_004 * @tc.desc: Check whether the value returned through an EcmaString made by CreateEmptyString() calling GetHashcode * function is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, GetHashcode_004) { // GetHashcode(). EcmaString made by CreateEmptyString(). JSHandle handleEcmaStrEmpty(thread, EcmaStringAccessor::CreateEmptyString(ecmaVMPtr)); EXPECT_EQ(EcmaStringAccessor(handleEcmaStrEmpty).GetHashcode(), 0U); } /* * @tc.name: GetHashcode_005 * @tc.desc: Check whether the value returned through an EcmaString made by CreateLineString(, true/false, ) calling * GetHashcode function is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, GetHashcode_005) { // GetHashcode(). EcmaString made by CreateLineString(). size_t sizeAlloc = 5; JSHandle handleEcmaStrAllocComp(thread, EcmaStringAccessor::CreateLineString(ecmaVMPtr, sizeAlloc, true)); JSHandle handleEcmaStrAllocNotComp(thread, EcmaStringAccessor::CreateLineString(ecmaVMPtr, sizeAlloc, false)); EXPECT_EQ(EcmaStringAccessor(handleEcmaStrAllocComp).GetHashcode(), 0U); EXPECT_EQ(EcmaStringAccessor(handleEcmaStrAllocNotComp).GetHashcode(), 0U); } /* * @tc.name: ComputeHashcodeUtf8 * @tc.desc: Check whether the value returned through calling ComputeHashcodeUtf8 function with an Array(uint8_t) is * within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, ComputeHashcodeUtf8) { uint8_t arrayU8[] = {"abc"}; uint32_t lengthEcmaStrU8 = sizeof(arrayU8) - 1; uint32_t hashExpect = 0; for (uint32_t i = 0; i < lengthEcmaStrU8; i++) { hashExpect = hashExpect * 31 + arrayU8[i]; } EXPECT_EQ(EcmaStringAccessor::ComputeHashcodeUtf8(&arrayU8[0], lengthEcmaStrU8, true), hashExpect); } /* * @tc.name: ComputeHashcodeUtf16 * @tc.desc: Check whether the value returned through calling ComputeHashcodeUtf16 function with an Array(uint16_t) is * within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, ComputeHashcodeUtf16) { uint16_t arrayU16[] = {199, 1, 256, 65535, 777}; uint32_t lengthEcmaStrU16 = sizeof(arrayU16) / sizeof(arrayU16[0]); uint32_t hashExpect = 0; for (uint32_t i = 0; i < lengthEcmaStrU16; i++) { hashExpect = hashExpect * 31 + arrayU16[i]; } EXPECT_EQ(EcmaStringAccessor::ComputeHashcodeUtf16(&arrayU16[0], lengthEcmaStrU16), hashExpect); } /* * @tc.name: IndexOf_001 * @tc.desc: Check whether the value returned through a source EcmaString made by CreateFromUtf8() calling IndexOf * function with a target EcmaString made by CreateFromUtf8() is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, IndexOf_001) { // IndexOf(). Find EcmaString made by CreateFromUtf8() From EcmaString made by CreateFromUtf8(). uint8_t arrayU8From[7] = {23, 25, 1, 3, 39, 80}; uint8_t arrayU8Target[4] = {1, 3, 39}; uint32_t lengthEcmaStrU8From = sizeof(arrayU8From) - 1; uint32_t lengthEcmaStrU8Target = sizeof(arrayU8Target) - 1; JSHandle handleEcmaStr(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8From[0], lengthEcmaStrU8From, true)); JSHandle handleEcmaStr1(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8Target[0], lengthEcmaStrU8Target, true)); int32_t posStart = 0; EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStr, handleEcmaStr1, posStart), 2); EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStr1, handleEcmaStr, posStart), -1); posStart = -1; EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStr, handleEcmaStr1, posStart), 2); posStart = 1; EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStr, handleEcmaStr1, posStart), 2); posStart = 2; EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStr, handleEcmaStr1, posStart), 2); posStart = 3; EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStr, handleEcmaStr1, posStart), -1); } /* * @tc.name: IndexOf_002 * @tc.desc: Check whether the value returned through a source EcmaString made by CreateFromUtf16( , , , false) calling * IndexOf function with a target EcmaString made by CreateFromUtf8() is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, IndexOf_002) { // IndexOf(). Find EcmaString made by CreateFromUtf8() From EcmaString made by CreateFromUtf16( , , , false). uint8_t arrayU8Target[4] = {1, 3, 39}; uint16_t arrayU16NotCompFromNo1[] = {67, 65535, 127, 777, 1453, 44, 1, 3, 39, 80, 333}; uint32_t lengthEcmaStrU8Target = sizeof(arrayU8Target) - 1; uint32_t lengthEcmaStrU16NotCompFromNo1 = sizeof(arrayU16NotCompFromNo1) / sizeof(arrayU16NotCompFromNo1[0]); JSHandle handleEcmaStr(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8Target[0], lengthEcmaStrU8Target, true)); JSHandle handleEcmaStr1(thread, EcmaStringAccessor::CreateFromUtf16( ecmaVMPtr, &arrayU16NotCompFromNo1[0], lengthEcmaStrU16NotCompFromNo1, false)); int32_t posStart = 0; EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStr1, handleEcmaStr, posStart), 6); EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStr, handleEcmaStr1, posStart), -1); posStart = -1; EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStr1, handleEcmaStr, posStart), 6); posStart = 1; EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStr1, handleEcmaStr, posStart), 6); posStart = 6; EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStr1, handleEcmaStr, posStart), 6); posStart = 7; EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStr1, handleEcmaStr, posStart), -1); } /* * @tc.name: IndexOf_003 * @tc.desc: Check whether the value returned through a source EcmaString made by CreateFromUtf16( , , , false) calling * IndexOf function with a target EcmaString made by CreateFromUtf16( , , , false) is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, IndexOf_003) { /* IndexOf(). Find EcmaString made by CreateFromUtf16( , , , false) From EcmaString made by * CreateFromUtf16( , , , false). */ uint16_t arrayU16NotCompTarget[] = {1453, 44}; uint16_t arrayU16NotCompFrom[] = {67, 65535, 127, 777, 1453, 44, 1, 3, 39, 80, 333}; uint32_t lengthEcmaStrU16NotCompTarget = sizeof(arrayU16NotCompTarget) / sizeof(arrayU16NotCompTarget[0]); uint32_t lengthEcmaStrU16NotCompFrom = sizeof(arrayU16NotCompFrom) / sizeof(arrayU16NotCompFrom[0]); JSHandle handleEcmaStrU16NotCompTarget(thread, EcmaStringAccessor::CreateFromUtf16( ecmaVMPtr, &arrayU16NotCompTarget[0], lengthEcmaStrU16NotCompTarget, false)); JSHandle handleEcmaStrU16NotCompFrom(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompFrom[0], lengthEcmaStrU16NotCompFrom, false)); int32_t posStart = 0; EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStrU16NotCompFrom, handleEcmaStrU16NotCompTarget, posStart), 4); EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStrU16NotCompTarget, handleEcmaStrU16NotCompFrom, posStart), -1); posStart = -1; EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStrU16NotCompFrom, handleEcmaStrU16NotCompTarget, posStart), 4); posStart = 1; EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStrU16NotCompFrom, handleEcmaStrU16NotCompTarget, posStart), 4); posStart = 4; EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStrU16NotCompFrom, handleEcmaStrU16NotCompTarget, posStart), 4); posStart = 5; EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStrU16NotCompFrom, handleEcmaStrU16NotCompTarget, posStart), -1); } /* * @tc.name: IndexOf_004 * @tc.desc: Check whether the value returned through a source EcmaString made by CreateFromUtf8() calling IndexOf * function with a target EcmaString made by CreateFromUtf16() is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, IndexOf_004) { // IndexOf(). Find EcmaString made by CreateFromUtf16() From EcmaString made by CreateFromUtf8(). uint16_t ecmaStrU16NotCompTarget[] = {3, 39, 80}; uint8_t arrayU8From[7] = {23, 25, 1, 3, 39, 80}; uint32_t lengthEcmaStrU16NotCompTarget = sizeof(ecmaStrU16NotCompTarget) / sizeof(ecmaStrU16NotCompTarget[0]); uint32_t lengthEcmaStrU8From = sizeof(arrayU8From) - 1; JSHandle handleEcmaStrU16NotCompTarget(thread, EcmaStringAccessor::CreateFromUtf16( ecmaVMPtr, &ecmaStrU16NotCompTarget[0], lengthEcmaStrU16NotCompTarget, true)); JSHandle handleEcmaStrU8From(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8From[0], lengthEcmaStrU8From, true)); int32_t posStart = 0; EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStrU8From, handleEcmaStrU16NotCompTarget, posStart), 3); EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStrU16NotCompTarget, handleEcmaStrU8From, posStart), -1); posStart = -1; EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStrU8From, handleEcmaStrU16NotCompTarget, posStart), 3); posStart = 1; EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStrU8From, handleEcmaStrU16NotCompTarget, posStart), 3); posStart = 3; EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStrU8From, handleEcmaStrU16NotCompTarget, posStart), 3); posStart = 4; EXPECT_EQ(EcmaStringAccessor::IndexOf(ecmaVMPtr, handleEcmaStrU8From, handleEcmaStrU16NotCompTarget, posStart), -1); } /* * @tc.name: Compare_001 * @tc.desc: Check whether the value returned through calling Compare function between EcmaStrings made by * CreateFromUtf8() is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, Compare_001) { // Compare(). Between EcmaStrings made by CreateFromUtf8(). uint8_t arrayU8No1[3] = {1, 23}; uint8_t arrayU8No2[4] = {1, 23, 49}; uint8_t arrayU8No3[6] = {1, 23, 45, 97, 127}; uint32_t lengthEcmaStrU8No1 = sizeof(arrayU8No1) - 1; uint32_t lengthEcmaStrU8No2 = sizeof(arrayU8No2) - 1; uint32_t lengthEcmaStrU8No3 = sizeof(arrayU8No3) - 1; JSHandle handleEcmaStrU8No1(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8No1[0], lengthEcmaStrU8No1, true)); JSHandle handleEcmaStrU8No2(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8No2[0], lengthEcmaStrU8No2, true)); JSHandle handleEcmaStrU8No3(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8No3[0], lengthEcmaStrU8No3, true)); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU8No1, handleEcmaStrU8No2), -1); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU8No2, handleEcmaStrU8No1), 1); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU8No2, handleEcmaStrU8No3), 49 - 45); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU8No3, handleEcmaStrU8No2), 45 - 49); } /* * @tc.name: Compare_002 * @tc.desc: Check whether the value returned through calling Compare function between EcmaStrings made by * CreateFromUtf16( , , , true) is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, Compare_002) { // Compare(). Between EcmaStrings made by CreateFromUtf16( , , , true). uint16_t arrayU16CompNo1[] = {1, 23}; uint16_t arrayU16CompNo2[] = {1, 23, 49}; uint16_t arrayU16CompNo3[] = {1, 23, 45, 97, 127}; uint32_t lengthEcmaStrU16CompNo1 = sizeof(arrayU16CompNo1) / sizeof(arrayU16CompNo1[0]); uint32_t lengthEcmaStrU16CompNo2 = sizeof(arrayU16CompNo2) / sizeof(arrayU16CompNo2[0]); uint32_t lengthEcmaStrU16CompNo3 = sizeof(arrayU16CompNo3) / sizeof(arrayU16CompNo3[0]); JSHandle handleEcmaStrU16CompNo1(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompNo1[0], lengthEcmaStrU16CompNo1, true)); JSHandle handleEcmaStrU16CompNo2(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompNo2[0], lengthEcmaStrU16CompNo2, true)); JSHandle handleEcmaStrU16CompNo3(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompNo3[0], lengthEcmaStrU16CompNo3, true)); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU16CompNo1, handleEcmaStrU16CompNo2), -1); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU16CompNo2, handleEcmaStrU16CompNo1), 1); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU16CompNo2, handleEcmaStrU16CompNo3), 49 - 45); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU16CompNo3, handleEcmaStrU16CompNo2), 45 - 49); } /* * @tc.name: Compare_003 * @tc.desc: Check whether the value returned through calling Compare function between EcmaString made by * CreateFromUtf8() and EcmaString made by CreateFromUtf16( , , , true) made by CreateFromUtf16( , , , true) is within * expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, Compare_003) { // Compare(). EcmaString made by CreateFromUtf8() and EcmaString made by CreateFromUtf16( , , , true). uint8_t arrayU8No1[3] = {1, 23}; uint8_t arrayU8No2[4] = {1, 23, 49}; uint16_t arrayU16CompNo1[] = {1, 23}; uint16_t arrayU16CompNo2[] = {1, 23, 49}; uint16_t arrayU16CompNo3[] = {1, 23, 45, 97, 127}; uint32_t lengthEcmaStrU8No1 = sizeof(arrayU8No1) - 1; uint32_t lengthEcmaStrU8No2 = sizeof(arrayU8No2) - 1; uint32_t lengthEcmaStrU16CompNo1 = sizeof(arrayU16CompNo1) / sizeof(arrayU16CompNo1[0]); uint32_t lengthEcmaStrU16CompNo2 = sizeof(arrayU16CompNo2) / sizeof(arrayU16CompNo2[0]); uint32_t lengthEcmaStrU16CompNo3 = sizeof(arrayU16CompNo3) / sizeof(arrayU16CompNo3[0]); JSHandle handleEcmaStrU8No1(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8No1[0], lengthEcmaStrU8No1, true)); JSHandle handleEcmaStrU8No2(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8No2[0], lengthEcmaStrU8No2, true)); JSHandle handleEcmaStrU16CompNo1(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompNo1[0], lengthEcmaStrU16CompNo1, true)); JSHandle handleEcmaStrU16CompNo2(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompNo2[0], lengthEcmaStrU16CompNo2, true)); JSHandle handleEcmaStrU16CompNo3(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompNo3[0], lengthEcmaStrU16CompNo3, true)); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU8No1, handleEcmaStrU16CompNo1), 0); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU16CompNo1, handleEcmaStrU8No1), 0); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU8No1, handleEcmaStrU16CompNo2), -1); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU16CompNo2, handleEcmaStrU8No1), 1); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU8No2, handleEcmaStrU16CompNo3), 49 - 45); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU16CompNo3, handleEcmaStrU8No2), 45 - 49); } /* * @tc.name: Compare_004 * @tc.desc: Check whether the value returned through calling Compare function between EcmaStrings made by * CreateFromUtf16( , , , false) is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, Compare_004) { // Compare(). Between EcmaStrings made by CreateFromUtf16( , , , false). uint16_t arrayU16NotCompNo1[] = {1, 23}; uint16_t arrayU16NotCompNo2[] = {1, 23, 49}; uint16_t arrayU16NotCompNo3[] = {1, 23, 456, 6789, 65535, 127}; uint32_t lengthEcmaStrU16NotCompNo1 = sizeof(arrayU16NotCompNo1) / sizeof(arrayU16NotCompNo1[0]); uint32_t lengthEcmaStrU16NotCompNo2 = sizeof(arrayU16NotCompNo2) / sizeof(arrayU16NotCompNo2[0]); uint32_t lengthEcmaStrU16NotCompNo3 = sizeof(arrayU16NotCompNo3) / sizeof(arrayU16NotCompNo3[0]); JSHandle handleEcmaStrU16NotCompNo1(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo1[0], lengthEcmaStrU16NotCompNo1, true)); JSHandle handleEcmaStrU16NotCompNo2(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo2[0], lengthEcmaStrU16NotCompNo2, true)); JSHandle handleEcmaStrU16NotCompNo3(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo3[0], lengthEcmaStrU16NotCompNo3, false)); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU16NotCompNo1, handleEcmaStrU16NotCompNo2), -1); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU16NotCompNo2, handleEcmaStrU16NotCompNo1), 1); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU16NotCompNo2, handleEcmaStrU16NotCompNo3), 49 - 456); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU16NotCompNo3, handleEcmaStrU16NotCompNo2), 456 - 49); } /* * @tc.name: Compare_005 * @tc.desc: Check whether the value returned through calling Compare function between EcmaString made by * CreateFromUtf8() and EcmaString made by CreateFromUtf16( , , , false) is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, Compare_005) { // Compare(). EcmaString made by CreateFromUtf8() and EcmaString made by CreateFromUtf16( , , , false). uint8_t arrayU8No1[3] = {1, 23}; uint8_t arrayU8No2[4] = {1, 23, 49}; uint16_t arrayU16NotCompNo1[] = {1, 23}; uint16_t arrayU16NotCompNo2[] = {1, 23, 49}; uint16_t arrayU16NotCompNo3[] = {1, 23, 456, 6789, 65535, 127}; uint32_t lengthEcmaStrU8No1 = sizeof(arrayU8No1) - 1; uint32_t lengthEcmaStrU8No2 = sizeof(arrayU8No2) - 1; uint32_t lengthEcmaStrU16NotCompNo1 = sizeof(arrayU16NotCompNo1) / sizeof(arrayU16NotCompNo1[0]); uint32_t lengthEcmaStrU16NotCompNo2 = sizeof(arrayU16NotCompNo2) / sizeof(arrayU16NotCompNo2[0]); uint32_t lengthEcmaStrU16NotCompNo3 = sizeof(arrayU16NotCompNo3) / sizeof(arrayU16NotCompNo3[0]); JSHandle handleEcmaStrU8No1(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8No1[0], lengthEcmaStrU8No1, true)); JSHandle handleEcmaStrU8No2(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8No2[0], lengthEcmaStrU8No2, true)); JSHandle handleEcmaStrU16NotCompNo1(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo1[0], lengthEcmaStrU16NotCompNo1, true)); JSHandle handleEcmaStrU16NotCompNo2(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo2[0], lengthEcmaStrU16NotCompNo2, true)); JSHandle handleEcmaStrU16NotCompNo3(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo3[0], lengthEcmaStrU16NotCompNo3, false)); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU8No1, handleEcmaStrU16NotCompNo1), 0); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU16NotCompNo1, handleEcmaStrU8No1), 0); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU8No1, handleEcmaStrU16NotCompNo2), -1); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU16NotCompNo2, handleEcmaStrU8No1), 1); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU8No2, handleEcmaStrU16NotCompNo3), 49 - 456); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU16NotCompNo3, handleEcmaStrU8No2), 456 - 49); } /* * @tc.name: Compare_006 * @tc.desc: Check whether the value returned through calling Compare function between EcmaString made by * CreateFromUtf16( , , , true) and EcmaString made by CreateFromUtf16( , , , false) is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, Compare_006) { // Compare(). EcmaString made by CreateFromUtf16( , , , true) and EcmaString made by CreateFromUtf16( , , , false). uint16_t arrayU16CompNo1[] = {1, 23}; uint16_t arrayU16CompNo2[] = {1, 23, 49}; uint16_t arrayU16NotCompNo1[] = {1, 23}; uint16_t arrayU16NotCompNo2[] = {1, 23, 49}; uint16_t arrayU16NotCompNo3[] = {1, 23, 456, 6789, 65535, 127}; uint32_t lengthEcmaStrU16CompNo1 = sizeof(arrayU16CompNo1) / sizeof(arrayU16CompNo1[0]); uint32_t lengthEcmaStrU16CompNo2 = sizeof(arrayU16CompNo2) / sizeof(arrayU16CompNo2[0]); uint32_t lengthEcmaStrU16NotCompNo1 = sizeof(arrayU16NotCompNo1) / sizeof(arrayU16NotCompNo1[0]); uint32_t lengthEcmaStrU16NotCompNo2 = sizeof(arrayU16NotCompNo2) / sizeof(arrayU16NotCompNo2[0]); uint32_t lengthEcmaStrU16NotCompNo3 = sizeof(arrayU16NotCompNo3) / sizeof(arrayU16NotCompNo3[0]); JSHandle handleEcmaStrU16CompNo1(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompNo1[0], lengthEcmaStrU16CompNo1, true)); JSHandle handleEcmaStrU16CompNo2(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompNo2[0], lengthEcmaStrU16CompNo2, true)); JSHandle handleEcmaStrU16NotCompNo1(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo1[0], lengthEcmaStrU16NotCompNo1, true)); JSHandle handleEcmaStrU16NotCompNo2(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo2[0], lengthEcmaStrU16NotCompNo2, true)); JSHandle handleEcmaStrU16NotCompNo3(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo3[0], lengthEcmaStrU16NotCompNo3, false)); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU16CompNo1, handleEcmaStrU16NotCompNo1), 0); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU16NotCompNo1, handleEcmaStrU16CompNo1), 0); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU16CompNo1, handleEcmaStrU16NotCompNo2), -1); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU16NotCompNo2, handleEcmaStrU16CompNo1), 1); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU16CompNo2, handleEcmaStrU16NotCompNo3), 49 - 456); EXPECT_EQ(EcmaStringAccessor::Compare(ecmaVMPtr, handleEcmaStrU16NotCompNo3, handleEcmaStrU16CompNo2), 456 - 49); } /* * @tc.name: StringsAreEqual_001 * @tc.desc: Check whether the bool returned through calling StringsAreEqual function with two EcmaStrings made by * CreateFromUtf8() is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, StringsAreEqual_001) { // StringsAreEqual(). uint8_t arrayU8No1[4] = {45, 92, 78}; uint8_t arrayU8No2[4] = {45, 92, 78}; uint8_t arrayU8No3[5] = {45, 92, 78, 1}; uint32_t lengthEcmaStrU8No1 = sizeof(arrayU8No1) - 1; uint32_t lengthEcmaStrU8No2 = sizeof(arrayU8No2) - 1; uint32_t lengthEcmaStrU8No3 = sizeof(arrayU8No3) - 1; JSHandle handleEcmaStrU8No1(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8No1[0], lengthEcmaStrU8No1, true)); JSHandle handleEcmaStrU8No2(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8No2[0], lengthEcmaStrU8No2, true)); JSHandle handleEcmaStrU8No3(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8No3[0], lengthEcmaStrU8No3, true)); EXPECT_TRUE(EcmaStringAccessor::StringsAreEqual(*handleEcmaStrU8No1, *handleEcmaStrU8No2)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqual(*handleEcmaStrU8No1, *handleEcmaStrU8No3)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqual(*handleEcmaStrU8No3, *handleEcmaStrU8No1)); } /* * @tc.name: StringsAreEqual_002 * @tc.desc: Check whether the bool returned through calling StringsAreEqual function with a EcmaString made by * CreateFromUtf8() and a EcmaString made by CreateFromUtf16(, , , true) is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, StringsAreEqual_002) { // StringsAreEqual(). uint8_t arrayU8No1[4] = {45, 92, 78}; uint16_t arrayU16CompNo2[] = {45, 92, 78}; uint16_t arrayU16CompNo3[] = {45, 92, 78, 1}; uint32_t lengthEcmaStrU8No1 = sizeof(arrayU8No1) - 1; uint32_t lengthEcmaStrU16CompNo2 = sizeof(arrayU16CompNo2) / sizeof(arrayU16CompNo2[0]); uint32_t lengthEcmaStrU16CompNo3 = sizeof(arrayU16CompNo3) / sizeof(arrayU16CompNo3[0]); JSHandle handleEcmaStrU8No1(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8No1[0], lengthEcmaStrU8No1, true)); JSHandle handleEcmaStrU16CompNo2(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompNo2[0], lengthEcmaStrU16CompNo2, true)); JSHandle handleEcmaStrU16CompNo3(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompNo3[0], lengthEcmaStrU16CompNo3, true)); EXPECT_TRUE(EcmaStringAccessor::StringsAreEqual(*handleEcmaStrU8No1, *handleEcmaStrU16CompNo2)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqual(*handleEcmaStrU8No1, *handleEcmaStrU16CompNo3)); } /* * @tc.name: StringsAreEqual_003 * @tc.desc: Check whether the bool returned through calling StringsAreEqual function with two EcmaStrings made by * CreateFromUtf16(, , , true) is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, StringsAreEqual_003) { // StringsAreEqual(). uint16_t arrayU16CompNo1[] = {45, 92, 78}; uint16_t arrayU16CompNo2[] = {45, 92, 78}; uint16_t arrayU16CompNo3[] = {45, 92, 78, 1}; uint32_t lengthEcmaStrU16CompNo1 = sizeof(arrayU16CompNo1) / sizeof(arrayU16CompNo1[0]); uint32_t lengthEcmaStrU16CompNo2 = sizeof(arrayU16CompNo2) / sizeof(arrayU16CompNo2[0]); uint32_t lengthEcmaStrU16CompNo3 = sizeof(arrayU16CompNo3) / sizeof(arrayU16CompNo3[0]); JSHandle handleEcmaStrU16CompNo1(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompNo1[0], lengthEcmaStrU16CompNo1, true)); JSHandle handleEcmaStrU16CompNo2(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompNo2[0], lengthEcmaStrU16CompNo2, true)); JSHandle handleEcmaStrU16CompNo3(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompNo3[0], lengthEcmaStrU16CompNo3, true)); EXPECT_TRUE(EcmaStringAccessor::StringsAreEqual(*handleEcmaStrU16CompNo1, *handleEcmaStrU16CompNo2)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqual(*handleEcmaStrU16CompNo1, *handleEcmaStrU16CompNo3)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqual(*handleEcmaStrU16CompNo3, *handleEcmaStrU16CompNo1)); } /* * @tc.name: StringsAreEqual_004 * @tc.desc: Check whether the bool returned through calling StringsAreEqual function with a EcmaString made by * CreateFromUtf8() and a EcmaString made by CreateFromUtf16(, , , false) is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, StringsAreEqual_004) { // StringsAreEqual(). uint8_t arrayU8No1[4] = {45, 92, 78}; uint16_t arrayU16NotCompNo1[] = {45, 92, 78}; uint32_t lengthEcmaStrU8No1 = sizeof(arrayU8No1) - 1; uint32_t lengthEcmaStrU16NotCompNo1 = sizeof(arrayU16NotCompNo1) / sizeof(arrayU16NotCompNo1[0]); JSHandle handleEcmaStrU8No1(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8No1[0], lengthEcmaStrU8No1, true)); JSHandle handleEcmaStrU16NotCompNo1(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo1[0], lengthEcmaStrU16NotCompNo1, true)); EXPECT_TRUE(EcmaStringAccessor::StringsAreEqual(*handleEcmaStrU8No1, *handleEcmaStrU16NotCompNo1)); EXPECT_TRUE(EcmaStringAccessor::StringsAreEqual(*handleEcmaStrU16NotCompNo1, *handleEcmaStrU8No1)); } /* * @tc.name: StringsAreEqual_005 * @tc.desc: Check whether the bool returned through calling StringsAreEqual function with a EcmaString made by * CreateFromUtf16(, , , true) and a EcmaString made by CreateFromUtf16(, , , false) is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, StringsAreEqual_005) { // StringsAreEqual(). uint16_t arrayU16CompNo1[] = {45, 92, 78}; uint16_t arrayU16NotCompNo1[] = {45, 92, 78}; uint32_t lengthEcmaStrU16CompNo1 = sizeof(arrayU16CompNo1) / sizeof(arrayU16CompNo1[0]); uint32_t lengthEcmaStrU16NotCompNo1 = sizeof(arrayU16NotCompNo1) / sizeof(arrayU16NotCompNo1[0]); JSHandle handleEcmaStrU16CompNo1(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompNo1[0], lengthEcmaStrU16CompNo1, true)); JSHandle handleEcmaStrU16NotCompNo1(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo1[0], lengthEcmaStrU16NotCompNo1, true)); EXPECT_TRUE(EcmaStringAccessor::StringsAreEqual(*handleEcmaStrU16CompNo1, *handleEcmaStrU16NotCompNo1)); EXPECT_TRUE(EcmaStringAccessor::StringsAreEqual(*handleEcmaStrU16NotCompNo1, *handleEcmaStrU16CompNo1)); } /* * @tc.name: StringsAreEqual_006 * @tc.desc: Check whether the bool returned through calling StringsAreEqual function with two EcmaStrings made by * CreateFromUtf16(, , , false) is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, StringsAreEqual_006) { // StringsAreEqual(). uint16_t arrayU16NotCompNo1[] = {234, 345, 127, 2345, 65535, 5}; uint16_t arrayU16NotCompNo2[] = {234, 345, 127, 2345, 65535, 5}; uint16_t arrayU16NotCompNo3[] = {1, 234, 345, 127, 2345, 65535, 5}; uint32_t lengthEcmaStrU16NotCompNo1 = sizeof(arrayU16NotCompNo1) / sizeof(arrayU16NotCompNo1[0]); uint32_t lengthEcmaStrU16NotCompNo2 = sizeof(arrayU16NotCompNo2) / sizeof(arrayU16NotCompNo2[0]); uint32_t lengthEcmaStrU16NotCompNo3 = sizeof(arrayU16NotCompNo3) / sizeof(arrayU16NotCompNo3[0]); JSHandle handleEcmaStrU16NotCompNo1(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo1[0], lengthEcmaStrU16NotCompNo1, false)); JSHandle handleEcmaStrU16NotCompNo2(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo2[0], lengthEcmaStrU16NotCompNo2, false)); JSHandle handleEcmaStrU16NotCompNo3(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo3[0], lengthEcmaStrU16NotCompNo3, false)); EXPECT_TRUE(EcmaStringAccessor::StringsAreEqual(*handleEcmaStrU16NotCompNo1, *handleEcmaStrU16NotCompNo2)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqual(*handleEcmaStrU16NotCompNo1, *handleEcmaStrU16NotCompNo3)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqual(*handleEcmaStrU16NotCompNo3, *handleEcmaStrU16NotCompNo1)); } /* * @tc.name: StringsAreEqualUtf8_001 * @tc.desc: Check whether the bool returned through calling StringsAreEqualUtf8 function with an EcmaString made by * CreateFromUtf8() and an Array(uint8_t) is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, StringsAreEqualUtf8_001) { // StringsAreEqualUtf8(). EcmaString made by CreateFromUtf8(), Array:U8. uint8_t arrayU8No1[4] = {45, 92, 78}; uint8_t arrayU8No2[5] = {45, 92, 78, 24}; uint8_t arrayU8No3[3] = {45, 92}; uint32_t lengthEcmaStrU8No1 = sizeof(arrayU8No1) - 1; uint32_t lengthEcmaStrU8No2 = sizeof(arrayU8No2) - 1; uint32_t lengthEcmaStrU8No3 = sizeof(arrayU8No3) - 1; JSHandle handleEcmaStrU8No1(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8No1[0], lengthEcmaStrU8No1, true)); JSHandle handleEcmaStrU8No2(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8No2[0], lengthEcmaStrU8No2, true)); JSHandle handleEcmaStrU8No3(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8No3[0], lengthEcmaStrU8No3, true)); EXPECT_TRUE(EcmaStringAccessor::StringsAreEqualUtf8( *handleEcmaStrU8No1, &arrayU8No1[0], lengthEcmaStrU8No1, true)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqualUtf8( *handleEcmaStrU8No1, &arrayU8No1[0], lengthEcmaStrU8No1, false)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqualUtf8( *handleEcmaStrU8No2, &arrayU8No1[0], lengthEcmaStrU8No1, true)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqualUtf8( *handleEcmaStrU8No3, &arrayU8No1[0], lengthEcmaStrU8No1, true)); } /* * @tc.name: StringsAreEqualUtf8_002 * @tc.desc: Check whether the bool returned through calling StringsAreEqualUtf8 function with an EcmaString made by * CreateFromUtf16( , , , true) and an Array(uint8_t) is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, StringsAreEqualUtf8_002) { // StringsAreEqualUtf8(). EcmaString made by CreateFromUtf16( , , , true), Array:U8. uint8_t arrayU8No1[4] = {45, 92, 78}; uint16_t arrayU16CompNo1[] = {45, 92, 78}; uint16_t arrayU16CompNo2[] = {45, 92, 78, 24}; uint16_t arrayU16CompNo3[] = {45, 92}; uint32_t lengthEcmaStrU8No1 = sizeof(arrayU8No1) - 1; uint32_t lengthEcmaStrU16CompNo1 = sizeof(arrayU16CompNo1) / sizeof(arrayU16CompNo1[0]); uint32_t lengthEcmaStrU16CompNo2 = sizeof(arrayU16CompNo2) / sizeof(arrayU16CompNo2[0]); uint32_t lengthEcmaStrU16CompNo3 = sizeof(arrayU16CompNo3) / sizeof(arrayU16CompNo3[0]); JSHandle handleEcmaStrU16CompNo1(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompNo1[0], lengthEcmaStrU16CompNo1, true)); JSHandle handleEcmaStrU16CompNo2(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompNo2[0], lengthEcmaStrU16CompNo2, true)); JSHandle handleEcmaStrU16CompNo3(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompNo3[0], lengthEcmaStrU16CompNo3, true)); EXPECT_TRUE(EcmaStringAccessor::StringsAreEqualUtf8( *handleEcmaStrU16CompNo1, &arrayU8No1[0], lengthEcmaStrU8No1, true)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqualUtf8( *handleEcmaStrU16CompNo1, &arrayU8No1[0], lengthEcmaStrU8No1, false)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqualUtf8( *handleEcmaStrU16CompNo2, &arrayU8No1[0], lengthEcmaStrU8No1, true)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqualUtf8( *handleEcmaStrU16CompNo3, &arrayU8No1[0], lengthEcmaStrU8No1, true)); } /* * @tc.name: StringsAreEqualUtf8_003 * @tc.desc: Check whether the bool returned through calling StringsAreEqualUtf8 function with an EcmaString made by * CreateFromUtf16( , , , false) and an Array(uint8_t) is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, StringsAreEqualUtf8_003) { // StringsAreEqualUtf8(). EcmaString made by CreateFromUtf16( , , , false), Array:U8. uint8_t arrayU8No1[4] = {45, 92, 78}; uint16_t arrayU16NotCompNo1[] = {45, 92, 78}; uint16_t arrayU16NotCompNo2[] = {45, 92, 78, 24}; uint16_t arrayU16NotCompNo3[] = {45, 92}; uint16_t arrayU16NotCompNo4[] = {25645, 25692, 25678}; uint32_t lengthEcmaStrU8No1 = sizeof(arrayU8No1) - 1; uint32_t lengthEcmaStrU16NotCompNo1 = sizeof(arrayU16NotCompNo1) / sizeof(arrayU16NotCompNo1[0]); uint32_t lengthEcmaStrU16NotCompNo2 = sizeof(arrayU16NotCompNo2) / sizeof(arrayU16NotCompNo2[0]); uint32_t lengthEcmaStrU16NotCompNo3 = sizeof(arrayU16NotCompNo3) / sizeof(arrayU16NotCompNo3[0]); uint32_t lengthEcmaStrU16NotCompNo4 = sizeof(arrayU16NotCompNo4) / sizeof(arrayU16NotCompNo4[0]); JSHandle handleEcmaStrU16NotCompNo1(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo1[0], lengthEcmaStrU16NotCompNo1, true)); JSHandle handleEcmaStrU16NotCompNo2(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo2[0], lengthEcmaStrU16NotCompNo2, true)); JSHandle handleEcmaStrU16NotCompNo3(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo3[0], lengthEcmaStrU16NotCompNo3, true)); JSHandle handleEcmaStrU16NotCompNo4(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo4[0], lengthEcmaStrU16NotCompNo4, false)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqualUtf8( *handleEcmaStrU16NotCompNo1, &arrayU8No1[0], lengthEcmaStrU8No1, false)); EXPECT_TRUE(EcmaStringAccessor::StringsAreEqualUtf8( *handleEcmaStrU16NotCompNo1, &arrayU8No1[0], lengthEcmaStrU8No1, true)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqualUtf8( *handleEcmaStrU16NotCompNo2, &arrayU8No1[0], lengthEcmaStrU8No1, false)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqualUtf8( *handleEcmaStrU16NotCompNo3, &arrayU8No1[0], lengthEcmaStrU8No1, false)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqualUtf8( *handleEcmaStrU16NotCompNo4, &arrayU8No1[0], lengthEcmaStrU8No1, false)); } /* * @tc.name: StringsAreEqualUtf16_001 * @tc.desc: Check whether the bool returned through calling StringsAreEqualUtf16 function with an EcmaString made by * CreateFromUtf8() and an Array(uint16_t) is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, StringsAreEqualUtf16_001) { // StringsAreEqualUtf16(). EcmaString made by CreateFromUtf8, Array:U16(1-127). uint8_t arrayU8No1[4] = {45, 92, 78}; uint8_t arrayU8No2[5] = {45, 92, 78, 24}; uint8_t arrayU8No3[3] = {45, 92}; uint16_t arrayU16NotCompNo1[] = {45, 92, 78}; uint32_t lengthEcmaStrU8No1 = sizeof(arrayU8No1) - 1; uint32_t lengthEcmaStrU8No2 = sizeof(arrayU8No2) - 1; uint32_t lengthEcmaStrU8No3 = sizeof(arrayU8No3) - 1; uint32_t lengthEcmaStrU16NotCompNo1 = sizeof(arrayU16NotCompNo1) / sizeof(arrayU16NotCompNo1[0]); JSHandle handleEcmaStrU8No1(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8No1[0], lengthEcmaStrU8No1, true)); JSHandle handleEcmaStrU8No2(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8No2[0], lengthEcmaStrU8No2, true)); JSHandle handleEcmaStrU8No3(thread, EcmaStringAccessor::CreateFromUtf8(ecmaVMPtr, &arrayU8No3[0], lengthEcmaStrU8No3, true)); EXPECT_TRUE(EcmaStringAccessor::StringsAreEqualUtf16( *handleEcmaStrU8No1, &arrayU16NotCompNo1[0], lengthEcmaStrU16NotCompNo1)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqualUtf16( *handleEcmaStrU8No2, &arrayU16NotCompNo1[0], lengthEcmaStrU16NotCompNo1)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqualUtf16( *handleEcmaStrU8No3, &arrayU16NotCompNo1[0], lengthEcmaStrU16NotCompNo1)); } /* * @tc.name: StringsAreEqualUtf16_002 * @tc.desc: Check whether the bool returned through calling StringsAreEqualUtf16 function with an EcmaString made by * CreateFromUtf16( , , , true) and an Array(uint16_t) is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, StringsAreEqualUtf16_002) { // StringsAreEqualUtf16(). EcmaString made by CreateFromUtf16( , , , true), Array:U16(1-127). uint16_t arrayU16CompNo1[] = {45, 92, 78}; uint16_t arrayU16CompNo2[] = {45, 92, 78, 24}; uint16_t arrayU16CompNo3[] = {45, 92}; uint16_t arrayU16CompNo4[] = {25645, 25692, 25678}; // 25645 % 256 == 45... uint32_t lengthEcmaStrU16CompNo1 = sizeof(arrayU16CompNo1) / sizeof(arrayU16CompNo1[0]); uint32_t lengthEcmaStrU16CompNo2 = sizeof(arrayU16CompNo2) / sizeof(arrayU16CompNo2[0]); uint32_t lengthEcmaStrU16CompNo3 = sizeof(arrayU16CompNo3) / sizeof(arrayU16CompNo3[0]); uint32_t lengthEcmaStrU16CompNo4 = sizeof(arrayU16CompNo4) / sizeof(arrayU16CompNo4[0]); JSHandle handleEcmaStrU16CompNo1(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompNo1[0], lengthEcmaStrU16CompNo1, true)); JSHandle handleEcmaStrU16CompNo2(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompNo2[0], lengthEcmaStrU16CompNo2, true)); JSHandle handleEcmaStrU16CompNo3(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompNo3[0], lengthEcmaStrU16CompNo3, true)); JSHandle handleEcmaStrU16CompNo4(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16CompNo4[0], lengthEcmaStrU16CompNo4, true)); EXPECT_TRUE(EcmaStringAccessor::StringsAreEqualUtf16( *handleEcmaStrU16CompNo1, &arrayU16CompNo1[0], lengthEcmaStrU16CompNo1)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqualUtf16( *handleEcmaStrU16CompNo2, &arrayU16CompNo1[0], lengthEcmaStrU16CompNo1)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqualUtf16( *handleEcmaStrU16CompNo3, &arrayU16CompNo1[0], lengthEcmaStrU16CompNo1)); EXPECT_TRUE(EcmaStringAccessor::StringsAreEqualUtf16( *handleEcmaStrU16CompNo4, &arrayU16CompNo1[0], lengthEcmaStrU16CompNo1)); } /* * @tc.name: StringsAreEqualUtf16_003 * @tc.desc: Check whether the bool returned through calling StringsAreEqualUtf16 function with an EcmaString made by * CreateFromUtf16( , , , false) and an Array(uint16_t) is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, StringsAreEqualUtf16_003) { // StringsAreEqualUtf16(). EcmaString made by CreateFromUtf16( , , , false), Array:U16(0-65535). uint16_t arrayU16NotCompNo1[] = {25645, 25692, 25678}; uint16_t arrayU16NotCompNo2[] = {25645, 25692, 78}; // 25645 % 256 == 45... uint16_t arrayU16NotCompNo3[] = {25645, 25692, 25678, 65535}; uint16_t arrayU16NotCompNo4[] = {25645, 25692}; uint32_t lengthEcmaStrU16NotCompNo1 = sizeof(arrayU16NotCompNo1) / sizeof(arrayU16NotCompNo1[0]); uint32_t lengthEcmaStrU16NotCompNo2 = sizeof(arrayU16NotCompNo2) / sizeof(arrayU16NotCompNo2[0]); uint32_t lengthEcmaStrU16NotCompNo3 = sizeof(arrayU16NotCompNo3) / sizeof(arrayU16NotCompNo3[0]); uint32_t lengthEcmaStrU16NotCompNo4 = sizeof(arrayU16NotCompNo4) / sizeof(arrayU16NotCompNo4[0]); JSHandle handleEcmaStrU16NotCompNo1(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo1[0], lengthEcmaStrU16NotCompNo1, false)); JSHandle handleEcmaStrU16NotCompNo2(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo2[0], lengthEcmaStrU16NotCompNo2, false)); JSHandle handleEcmaStrU16NotCompNo3(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo3[0], lengthEcmaStrU16NotCompNo3, false)); JSHandle handleEcmaStrU16NotCompNo4(thread, EcmaStringAccessor::CreateFromUtf16(ecmaVMPtr, &arrayU16NotCompNo4[0], lengthEcmaStrU16NotCompNo4, false)); EXPECT_TRUE(EcmaStringAccessor::StringsAreEqualUtf16(*handleEcmaStrU16NotCompNo1, &arrayU16NotCompNo1[0], lengthEcmaStrU16NotCompNo1)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqualUtf16(*handleEcmaStrU16NotCompNo1, &arrayU16NotCompNo2[0], lengthEcmaStrU16NotCompNo2)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqualUtf16(*handleEcmaStrU16NotCompNo2, &arrayU16NotCompNo1[0], lengthEcmaStrU16NotCompNo1)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqualUtf16(*handleEcmaStrU16NotCompNo3, &arrayU16NotCompNo1[0], lengthEcmaStrU16NotCompNo1)); EXPECT_FALSE(EcmaStringAccessor::StringsAreEqualUtf16(*handleEcmaStrU16NotCompNo4, &arrayU16NotCompNo1[0], lengthEcmaStrU16NotCompNo1)); } /* * @tc.name: EqualToSplicedString * @tc.desc: Tests whether the source string is equal to the concatenated string. * is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, EqualToSplicedString) { ObjectFactory* factory = ecmaVMPtr->GetFactory(); { JSHandle sourceString = factory->NewFromUtf8("Start开始"); JSHandle firstString = factory->NewFromASCII("Start"); JSHandle secondString = factory->NewFromUtf8("开始"); EXPECT_TRUE(EcmaStringAccessor(sourceString).IsUtf16()); EXPECT_TRUE(EcmaStringAccessor(firstString).IsUtf8()); EXPECT_TRUE(EcmaStringAccessor(secondString).IsUtf16()); bool result = EcmaStringAccessor(sourceString).EqualToSplicedString(*firstString, *secondString); EXPECT_TRUE(result); } { JSHandle sourceString = factory->NewFromUtf8("Start开始"); JSHandle firstString = factory->NewFromASCII("Start"); JSHandle secondString = factory->NewFromASCII("start"); EXPECT_TRUE(EcmaStringAccessor(sourceString).IsUtf16()); EXPECT_TRUE(EcmaStringAccessor(firstString).IsUtf8()); EXPECT_TRUE(EcmaStringAccessor(secondString).IsUtf8()); bool result = EcmaStringAccessor(sourceString).EqualToSplicedString(*firstString, *secondString); EXPECT_TRUE(!result); } { JSHandle sourceString = factory->NewFromUtf8("Start开始"); JSHandle firstString = factory->NewFromUtf8("Start开"); JSHandle secondString = factory->NewFromUtf8("始"); EXPECT_TRUE(EcmaStringAccessor(sourceString).IsUtf16()); EXPECT_TRUE(EcmaStringAccessor(firstString).IsUtf16()); EXPECT_TRUE(EcmaStringAccessor(secondString).IsUtf16()); bool result = EcmaStringAccessor(sourceString).EqualToSplicedString(*firstString, *secondString); EXPECT_TRUE(result); } { JSHandle sourceString = factory->NewFromUtf8("Startstart"); JSHandle firstString = factory->NewFromASCII("Start"); JSHandle secondString = factory->NewFromASCII("start"); EXPECT_TRUE(EcmaStringAccessor(sourceString).IsUtf8()); EXPECT_TRUE(EcmaStringAccessor(firstString).IsUtf8()); EXPECT_TRUE(EcmaStringAccessor(secondString).IsUtf8()); bool result = EcmaStringAccessor(sourceString).EqualToSplicedString(*firstString, *secondString); EXPECT_TRUE(result); } { JSHandle sourceString = factory->NewFromUtf8("Startstart"); JSHandle firstString = factory->NewFromASCII("Start"); JSHandle secondString = factory->NewFromUtf8("开始"); EXPECT_TRUE(EcmaStringAccessor(sourceString).IsUtf8()); EXPECT_TRUE(EcmaStringAccessor(firstString).IsUtf8()); EXPECT_TRUE(EcmaStringAccessor(secondString).IsUtf16()); bool result = EcmaStringAccessor(sourceString).EqualToSplicedString(*firstString, *secondString); EXPECT_TRUE(!result); } { JSHandle sourceString = factory->NewFromUtf8("Startstat"); JSHandle firstString = factory->NewFromASCII("Start"); JSHandle secondString = factory->NewFromASCII("start"); EXPECT_TRUE(EcmaStringAccessor(sourceString).IsUtf8()); EXPECT_TRUE(EcmaStringAccessor(firstString).IsUtf8()); EXPECT_TRUE(EcmaStringAccessor(secondString).IsUtf8()); bool result = EcmaStringAccessor(sourceString).EqualToSplicedString(*firstString, *secondString); EXPECT_TRUE(!result); } { JSHandle sourceString = factory->NewFromUtf8("Start开始"); JSHandle firstString = factory->NewFromUtf8("Stat开"); JSHandle secondString = factory->NewFromUtf8("始"); EXPECT_TRUE(EcmaStringAccessor(sourceString).IsUtf16()); EXPECT_TRUE(EcmaStringAccessor(firstString).IsUtf16()); EXPECT_TRUE(EcmaStringAccessor(secondString).IsUtf16()); bool result = EcmaStringAccessor(sourceString).EqualToSplicedString(*firstString, *secondString); EXPECT_TRUE(!result); } { JSHandle sourceString = factory->NewFromUtf8("Start开始"); JSHandle firstString = factory->NewFromASCII("Stat"); JSHandle secondString = factory->NewFromUtf8("开始"); EXPECT_TRUE(EcmaStringAccessor(sourceString).IsUtf16()); EXPECT_TRUE(EcmaStringAccessor(firstString).IsUtf8()); EXPECT_TRUE(EcmaStringAccessor(secondString).IsUtf16()); bool result = EcmaStringAccessor(sourceString).EqualToSplicedString(*firstString, *secondString); EXPECT_TRUE(!result); } } /* * @tc.name: CanBeCompressed * @tc.desc: Check whether the bool returned through calling CanBeCompressed function is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, CanBeCompressed) { uint8_t arrayU8[] = {12, 34, 77, 127, 99, 1}; uint16_t arrayU16Comp[] = {1, 4, 37, 91, 127, 1}; uint16_t arrayU16NotComp[] = {72, 43, 337, 961, 1317, 65535}; EXPECT_TRUE(EcmaStringAccessor::CanBeCompressed(arrayU8, sizeof(arrayU8) / sizeof(arrayU8[0]))); EXPECT_TRUE(EcmaStringAccessor::CanBeCompressed(arrayU16Comp, sizeof(arrayU16Comp) / sizeof(arrayU16Comp[0]))); EXPECT_FALSE(EcmaStringAccessor::CanBeCompressed(arrayU16NotComp, sizeof(arrayU16Comp) / sizeof(arrayU16Comp[0]))); } /* * @tc.name: TryToLower * @tc.desc: Check whether the EcmaString created through calling TryToLower function is within expectations. * is within expectations. * @tc.type: FUNC * @tc.require: */ HWTEST_F_L0(EcmaStringAccessorTest, TryToLower) { ObjectFactory* factory = ecmaVMPtr->GetFactory(); JSHandle lowerStr = factory->NewFromASCII("aaabbbcccddd"); JSHandle upperStr = factory->NewFromASCII("AAABBBCCCDDD"); JSHandle testStr1 = factory->NewFromASCII("aaaBBBcccDDD"); JSHandle testStr2 = factory->NewFromASCII("AAAbbbcccDDD"); { JSHandle lowerEcmaString(thread, EcmaStringAccessor::TryToLower(ecmaVMPtr, lowerStr)); EXPECT_TRUE(JSTaggedValue::SameValue(lowerStr.GetTaggedValue(), lowerEcmaString.GetTaggedValue())); EXPECT_EQ(EcmaStringAccessor(lowerStr).GetLength(), EcmaStringAccessor(lowerEcmaString).GetLength()); EXPECT_TRUE(EcmaStringAccessor(lowerEcmaString).IsUtf8()); EXPECT_FALSE(EcmaStringAccessor(lowerEcmaString).IsUtf16()); } { JSHandle lowerEcmaString(thread, EcmaStringAccessor::TryToLower(ecmaVMPtr, upperStr)); EXPECT_TRUE(JSTaggedValue::SameValue(lowerStr.GetTaggedValue(), lowerEcmaString.GetTaggedValue())); EXPECT_EQ(EcmaStringAccessor(lowerStr).GetLength(), EcmaStringAccessor(lowerEcmaString).GetLength()); EXPECT_TRUE(EcmaStringAccessor(lowerEcmaString).IsUtf8()); EXPECT_FALSE(EcmaStringAccessor(lowerEcmaString).IsUtf16()); } { JSHandle testEcmaString(thread, EcmaStringAccessor::TryToLower(ecmaVMPtr, testStr1)); EXPECT_TRUE(JSTaggedValue::SameValue(lowerStr.GetTaggedValue(), testEcmaString.GetTaggedValue())); EXPECT_EQ(EcmaStringAccessor(lowerStr).GetLength(), EcmaStringAccessor(testEcmaString).GetLength()); EXPECT_TRUE(EcmaStringAccessor(testEcmaString).IsUtf8()); EXPECT_FALSE(EcmaStringAccessor(testEcmaString).IsUtf16()); } { JSHandle testEcmaString(thread, EcmaStringAccessor::TryToLower(ecmaVMPtr, testStr2)); EXPECT_TRUE(JSTaggedValue::SameValue(lowerStr.GetTaggedValue(), testEcmaString.GetTaggedValue())); EXPECT_EQ(EcmaStringAccessor(lowerStr).GetLength(), EcmaStringAccessor(testEcmaString).GetLength()); EXPECT_TRUE(EcmaStringAccessor(testEcmaString).IsUtf8()); EXPECT_FALSE(EcmaStringAccessor(testEcmaString).IsUtf16()); } } } // namespace panda::test