1 /*
2 * Copyright (c) 2022 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 "window_helper.h"
19
20 using namespace testing;
21 using namespace testing::ext;
22
23 namespace OHOS {
24 namespace Rosen {
25 class WindowHelperTest : public testing::Test {
26 public:
27 static void SetUpTestCase();
28 static void TearDownTestCase();
29 virtual void SetUp() override;
30 virtual void TearDown() override;
31 };
32
SetUpTestCase()33 void WindowHelperTest::SetUpTestCase()
34 {
35 }
36
TearDownTestCase()37 void WindowHelperTest::TearDownTestCase()
38 {
39 }
40
SetUp()41 void WindowHelperTest::SetUp()
42 {
43 }
44
TearDown()45 void WindowHelperTest::TearDown()
46 {
47 }
48
49 namespace {
50 /**
51 * @tc.name: WindowTypeWindowMode
52 * @tc.desc: window type/mode test
53 * @tc.type: FUNC
54 */
55 HWTEST_F(WindowHelperTest, WindowTypeWindowMode, Function | SmallTest | Level1)
56 {
57 ASSERT_EQ(true, WindowHelper::IsMainFullScreenWindow(WindowType::WINDOW_TYPE_APP_MAIN_WINDOW,
58 WindowMode::WINDOW_MODE_FULLSCREEN));
59 ASSERT_EQ(false, WindowHelper::IsMainFullScreenWindow(WindowType::WINDOW_TYPE_APP_SUB_WINDOW,
60 WindowMode::WINDOW_MODE_FULLSCREEN));
61 ASSERT_EQ(false, WindowHelper::IsMainFullScreenWindow(WindowType::WINDOW_TYPE_APP_MAIN_WINDOW,
62 WindowMode::WINDOW_MODE_SPLIT_PRIMARY));
63
64 ASSERT_EQ(true, WindowHelper::IsFloatingWindow(WindowMode::WINDOW_MODE_FLOATING));
65 ASSERT_EQ(false, WindowHelper::IsFloatingWindow(WindowMode::WINDOW_MODE_FULLSCREEN));
66
67 ASSERT_EQ(true, WindowHelper::IsFullScreenWindow(WindowMode::WINDOW_MODE_FULLSCREEN));
68 ASSERT_EQ(false, WindowHelper::IsFullScreenWindow(WindowMode::WINDOW_MODE_FLOATING));
69
70 ASSERT_EQ(true, WindowHelper::IsDialogWindow(WindowType::WINDOW_TYPE_DIALOG));
71 ASSERT_EQ(false, WindowHelper::IsDialogWindow(WindowType::WINDOW_TYPE_APP_SUB_WINDOW));
72 }
73
74 /**
75 * @tc.name: WindowModeSupport
76 * @tc.desc: window mode supported test
77 * @tc.type: FUNC
78 */
79 HWTEST_F(WindowHelperTest, WindowModeSupport, Function | SmallTest | Level1)
80 {
81 ASSERT_EQ(true, WindowHelper::IsWindowModeSupported(WindowModeSupport::WINDOW_MODE_SUPPORT_ALL,
82 WindowMode::WINDOW_MODE_FULLSCREEN));
83 ASSERT_EQ(true, WindowHelper::IsWindowModeSupported(WindowModeSupport::WINDOW_MODE_SUPPORT_ALL,
84 WindowMode::WINDOW_MODE_FLOATING));
85 ASSERT_EQ(true, WindowHelper::IsWindowModeSupported(WindowModeSupport::WINDOW_MODE_SUPPORT_ALL,
86 WindowMode::WINDOW_MODE_SPLIT_PRIMARY));
87 ASSERT_EQ(true, WindowHelper::IsWindowModeSupported(WindowModeSupport::WINDOW_MODE_SUPPORT_ALL,
88 WindowMode::WINDOW_MODE_SPLIT_SECONDARY));
89 ASSERT_EQ(true, WindowHelper::IsWindowModeSupported(WindowModeSupport::WINDOW_MODE_SUPPORT_ALL,
90 WindowMode::WINDOW_MODE_PIP));
91 ASSERT_EQ(false, WindowHelper::IsWindowModeSupported(WindowModeSupport::WINDOW_MODE_SUPPORT_ALL,
92 WindowMode::WINDOW_MODE_UNDEFINED));
93 }
94
95 /**
96 * @tc.name: WindowRect
97 * @tc.desc: rect test
98 * @tc.type: FUNC
99 */
100 HWTEST_F(WindowHelperTest, WindowRect, Function | SmallTest | Level1)
101 {
102 Rect rect0 = {0, 0, 0, 0};
103 ASSERT_EQ(true, WindowHelper::IsEmptyRect(rect0));
104
105 Rect rect1 = {0, 0, 1, 1};
106 ASSERT_EQ(false, WindowHelper::IsEmptyRect(rect1));
107 }
108
109 /**
110 * @tc.name: WindowStringUtil
111 * @tc.desc: string test
112 * @tc.type: FUNC
113 */
114 HWTEST_F(WindowHelperTest, WindowStringUtil, Function | SmallTest | Level1)
115 {
116 ASSERT_EQ(true, WindowHelper::IsNumber("123"));
117 ASSERT_EQ(false, WindowHelper::IsNumber("1a3"));
118 ASSERT_EQ(false, WindowHelper::IsNumber(""));
119
120 ASSERT_EQ(true, WindowHelper::IsFloatingNumber("1.23"));
121 ASSERT_EQ(true, WindowHelper::IsFloatingNumber(".123"));
122 ASSERT_EQ(false, WindowHelper::IsFloatingNumber("1a3"));
123 ASSERT_EQ(false, WindowHelper::IsFloatingNumber("123.."));
124
125 std::vector<std::string> vec = WindowHelper::Split("123a123a123", "a");
126 for (size_t i = 0; i < vec.size(); i++) {
127 if (vec[i].compare("123")) {
128 ASSERT_TRUE(false);
129 }
130 }
131 ASSERT_TRUE(true);
132 }
133
134 /**
135 * @tc.name: CalculateOriginPosition
136 * @tc.desc: CalculateOriginPosition test
137 * @tc.type: FUNC
138 */
139 HWTEST_F(WindowHelperTest, CalculateOriginPosition, Function | SmallTest | Level1)
140 {
141 Rect rect1 { 0, 0, 10, 10 }, rect2 { 100, 100, 200, 200 };
142 PointInfo point = WindowHelper::CalculateOriginPosition(rect1, rect2, PointInfo { 200, 200 });
143 PointInfo expectPoint { 5, 5 };
144 ASSERT_EQ(true, point.x == expectPoint.x);
145 ASSERT_EQ(true, point.y == expectPoint.y);
146
147 Transform transform;
148 transform.scaleX_ = 0.66f;
149 transform.scaleY_ = 1.5f;
150 transform.rotationY_ = 30;
151 transform.translateX_ = 100;
152 transform.translateY_ = 200;
153 transform.translateZ_ = 50;
154 Rect rect { 50, 50, 240, 320 };
155 TransformHelper::Vector3 pivotPos = { rect.posX_ + transform.pivotX_ * rect.width_,
156 rect.posY_ + transform.pivotY_ * rect.height_, 0 };
157 TransformHelper::Matrix4 mat = TransformHelper::CreateTranslation(-pivotPos);
158 mat *= WindowHelper::ComputeWorldTransformMat4(transform);
159 mat *= TransformHelper::CreateTranslation(pivotPos);
160
161 TransformHelper::Vector3 expectOriginPoint(0, 0, 0);
162 TransformHelper::Vector3 tranformedPoint = TransformHelper::Transform(expectOriginPoint, mat);
163 PointInfo actialOriginPoint = WindowHelper::CalculateOriginPosition(mat,
164 { static_cast<int32_t>(tranformedPoint.x_), static_cast<int32_t>(tranformedPoint.y_) });
165 const float errorRange = 2.f;
166 ASSERT_LT(std::abs(expectOriginPoint.x_ - actialOriginPoint.x), errorRange);
167 ASSERT_LT(std::abs(expectOriginPoint.y_ - actialOriginPoint.y), errorRange);
168 }
169
170 /**
171 * @tc.name: TransformRect
172 * @tc.desc: TransformRect test
173 * @tc.type: FUNC
174 */
175 HWTEST_F(WindowHelperTest, TransformRect, Function | SmallTest | Level1)
176 {
177 Transform transform;
178 Rect rect { 0, 0, 10, 20 };
179 transform.scaleX_ = transform.scaleY_ = 2.0f;
180 TransformHelper::Vector3 pivotPos = { rect.posX_ + transform.pivotX_ * rect.width_,
181 rect.posY_ + transform.pivotY_ * rect.height_, 0 };
182 TransformHelper::Matrix4 mat = TransformHelper::CreateTranslation(-pivotPos);
183 mat *= WindowHelper::ComputeWorldTransformMat4(transform);
184 mat *= TransformHelper::CreateTranslation(pivotPos);
185 Rect transformRect = WindowHelper::TransformRect(mat, rect);
186 ASSERT_EQ(rect.width_ * transform.scaleX_, transformRect.width_);
187 ASSERT_EQ(rect.height_ * transform.scaleY_, transformRect.height_);
188 }
189
190 /**
191 * @tc.name: CalculateHotZoneScale
192 * @tc.desc: CalculateHotZoneScale test
193 * @tc.type: FUNC
194 */
195 HWTEST_F(WindowHelperTest, CalculateHotZoneScale, Function | SmallTest | Level1)
196 {
197 Transform transform;
198 transform.scaleX_ = 0.66f;
199 transform.scaleY_ = 1.5f;
200 transform.pivotX_ = transform.pivotY_ = 0.5f;
201 Rect rect { -1, -2, 2, 4 };
202 TransformHelper::Vector3 pivotPos = { rect.posX_ + transform.pivotX_ * rect.width_,
203 rect.posY_ + transform.pivotY_ * rect.height_, 0 };
204 TransformHelper::Matrix4 mat = TransformHelper::CreateTranslation(-pivotPos);
205 mat *= WindowHelper::ComputeWorldTransformMat4(transform);
206 mat *= TransformHelper::CreateTranslation(pivotPos);
207
208 const float errorRange = 0.01f;
209 TransformHelper::Vector2 hotZoneScale = WindowHelper::CalculateHotZoneScale(mat);
210 ASSERT_LT(std::abs(transform.scaleX_ - hotZoneScale.x_), errorRange);
211 ASSERT_LT(std::abs(transform.scaleY_ - hotZoneScale.y_), errorRange);
212 }
213
214 /**
215 * @tc.name: WindowType
216 * @tc.desc: Window Type test
217 * @tc.type: FUNC
218 */
219 HWTEST_F(WindowHelperTest, WindowType, Function | SmallTest | Level1)
220 {
221 ASSERT_EQ(true, WindowHelper::IsSystemWindow(WindowType::WINDOW_TYPE_SYSTEM_SUB_WINDOW));
222 ASSERT_EQ(true, WindowHelper::IsSystemSubWindow(WindowType::WINDOW_TYPE_SYSTEM_SUB_WINDOW));
223 ASSERT_EQ(false, WindowHelper::IsSystemSubWindow(WindowType::WINDOW_TYPE_APP_SUB_WINDOW));
224 ASSERT_EQ(false, WindowHelper::IsSystemSubWindow(WindowType::WINDOW_TYPE_FLOAT));
225 }
226
227 /**
228 * @tc.name: GetTransformFromWorldMat4
229 * @tc.desc: GetTransformFromWorldMat4 test
230 * @tc.type: FUNC
231 */
232 HWTEST_F(WindowHelperTest, GetTransformFromWorldMat4, Function | SmallTest | Level1)
233 {
234 Transform transform1;
235 transform1.scaleX_ = 0.66f;
236 transform1.scaleY_ = 1.5f;
237 transform1.translateX_ = 12.f;
238 transform1.translateY_ = 45.f;
239 Rect rect1 { 0, 0, 300, 400 };
240 TransformHelper::Vector3 pivotPos1 = { rect1.posX_ + transform1.pivotX_ * rect1.width_,
241 rect1.posY_ + transform1.pivotY_ * rect1.height_, 0 };
242 TransformHelper::Matrix4 mat1 = TransformHelper::CreateTranslation(-pivotPos1);
243 mat1 *= WindowHelper::ComputeWorldTransformMat4(transform1);
244 mat1 *= TransformHelper::CreateTranslation(pivotPos1);
245
246 Rect rect2 = WindowHelper::TransformRect(mat1, rect1);
247 Transform transform2;
248 WindowHelper::GetTransformFromWorldMat4(mat1, rect2, transform2);
249 TransformHelper::Vector3 pivotPos2 = { rect2.posX_ + transform2.pivotX_ * rect2.width_,
250 rect2.posY_ + transform2.pivotY_ * rect2.height_, 0 };
251 TransformHelper::Matrix4 mat2 = TransformHelper::CreateTranslation(-pivotPos2);
252 mat2 *= WindowHelper::ComputeWorldTransformMat4(transform2);
253 mat2 *= TransformHelper::CreateTranslation(pivotPos2);
254 for (int i = 0; i < TransformHelper::Matrix4::MAT_SIZE; i++) {
255 for (int j = 0; j < TransformHelper::Matrix4::MAT_SIZE; j++) {
256 ASSERT_EQ(true, MathHelper::NearZero(mat1.mat_[i][j] - mat2.mat_[i][j]));
257 }
258 }
259 }
260 }
261 } // namespace Rosen
262 } // namespace OHOS