1 /**
2 * Copyright (c) 2024 Huawei Device Co., Ltd.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at
6 *
7 * http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15
16 #include <gtest/gtest.h>
17
18 #include "ets_coroutine.h"
19
20 #include "types/ets_class.h"
21 #include "types/ets_arraybuffer.h"
22 #include "tests/runtime/types/ets_test_mirror_classes.h"
23
24 namespace ark::ets::test {
25
26 template <class ElementType>
27 class EtsArrayObjectMembers : public testing::Test {
28 public:
EtsArrayObjectMembers()29 EtsArrayObjectMembers()
30 {
31 RuntimeOptions options;
32 options.SetShouldLoadBootPandaFiles(true);
33 options.SetShouldInitializeIntrinsics(false);
34 options.SetCompilerEnableJit(false);
35 options.SetGcType("epsilon");
36 options.SetLoadRuntimes({"ets"});
37
38 auto stdlib = std::getenv("PANDA_STD_LIB");
39 if (stdlib == nullptr) {
40 std::cerr << "PANDA_STD_LIB env variable should be set and point to mock_stdlib.abc" << std::endl;
41 std::abort();
42 }
43 options.SetBootPandaFiles({stdlib});
44
45 Runtime::Create(options);
46 EtsCoroutine *coroutine = EtsCoroutine::GetCurrent();
47 vm_ = coroutine->GetPandaVM();
48 }
49
~EtsArrayObjectMembers()50 ~EtsArrayObjectMembers() override
51 {
52 Runtime::Destroy();
53 }
54
55 NO_COPY_SEMANTIC(EtsArrayObjectMembers);
56 NO_MOVE_SEMANTIC(EtsArrayObjectMembers);
57
GetMembers()58 static std::vector<MirrorFieldInfo> GetMembers()
59 {
60 return std::vector<MirrorFieldInfo> {
61 MIRROR_FIELD_INFO(EtsArrayObject<ElementType>, actualLength_, "actualLength"),
62 MIRROR_FIELD_INFO(EtsArrayObject<ElementType>, buffer_, "buffer")};
63 }
64
65 protected:
66 PandaEtsVM *vm_ = nullptr; // NOLINT(misc-non-private-member-variables-in-classes)
67 };
68
69 using EtsArrayBoxedBooleanTest = EtsArrayObjectMembers<EtsBoxPrimitive<EtsBoolean>>;
70 using EtsArrayBoxedByteTest = EtsArrayObjectMembers<EtsBoxPrimitive<EtsByte>>;
71 using EtsArrayBoxedCharTest = EtsArrayObjectMembers<EtsBoxPrimitive<EtsChar>>;
72 using EtsArrayBoxedShortTest = EtsArrayObjectMembers<EtsBoxPrimitive<EtsShort>>;
73 using EtsArrayBoxedIntTest = EtsArrayObjectMembers<EtsBoxPrimitive<EtsInt>>;
74 using EtsArrayBoxedLongTest = EtsArrayObjectMembers<EtsBoxPrimitive<EtsLong>>;
75 using EtsArrayBoxedFloatTest = EtsArrayObjectMembers<EtsBoxPrimitive<EtsFloat>>;
76 using EtsArrayBoxedDoubleTest = EtsArrayObjectMembers<EtsBoxPrimitive<EtsDouble>>;
77
TEST_F(EtsArrayBoxedBooleanTest,MemoryLayout)78 TEST_F(EtsArrayBoxedBooleanTest, MemoryLayout)
79 {
80 EtsClass *klass = vm_->GetClassLinker()->GetArrayClass();
81 MirrorFieldInfo::CompareMemberOffsets(klass, GetMembers());
82 }
83
TEST_F(EtsArrayBoxedByteTest,MemoryLayout)84 TEST_F(EtsArrayBoxedByteTest, MemoryLayout)
85 {
86 EtsClass *klass = vm_->GetClassLinker()->GetArrayClass();
87 MirrorFieldInfo::CompareMemberOffsets(klass, GetMembers());
88 }
89
TEST_F(EtsArrayBoxedCharTest,MemoryLayout)90 TEST_F(EtsArrayBoxedCharTest, MemoryLayout)
91 {
92 EtsClass *klass = vm_->GetClassLinker()->GetArrayClass();
93 MirrorFieldInfo::CompareMemberOffsets(klass, GetMembers());
94 }
95
TEST_F(EtsArrayBoxedShortTest,MemoryLayout)96 TEST_F(EtsArrayBoxedShortTest, MemoryLayout)
97 {
98 EtsClass *klass = vm_->GetClassLinker()->GetArrayClass();
99 MirrorFieldInfo::CompareMemberOffsets(klass, GetMembers());
100 }
101
TEST_F(EtsArrayBoxedIntTest,MemoryLayout)102 TEST_F(EtsArrayBoxedIntTest, MemoryLayout)
103 {
104 EtsClass *klass = vm_->GetClassLinker()->GetArrayClass();
105 MirrorFieldInfo::CompareMemberOffsets(klass, GetMembers());
106 }
107
TEST_F(EtsArrayBoxedLongTest,MemoryLayout)108 TEST_F(EtsArrayBoxedLongTest, MemoryLayout)
109 {
110 EtsClass *klass = vm_->GetClassLinker()->GetArrayClass();
111 MirrorFieldInfo::CompareMemberOffsets(klass, GetMembers());
112 }
113
TEST_F(EtsArrayBoxedFloatTest,MemoryLayout)114 TEST_F(EtsArrayBoxedFloatTest, MemoryLayout)
115 {
116 EtsClass *klass = vm_->GetClassLinker()->GetArrayClass();
117 MirrorFieldInfo::CompareMemberOffsets(klass, GetMembers());
118 }
119
TEST_F(EtsArrayBoxedDoubleTest,MemoryLayout)120 TEST_F(EtsArrayBoxedDoubleTest, MemoryLayout)
121 {
122 EtsClass *klass = vm_->GetClassLinker()->GetArrayClass();
123 MirrorFieldInfo::CompareMemberOffsets(klass, GetMembers());
124 }
125
126 } // namespace ark::ets::test
127