• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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