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 <cstddef>
17 #include "gtest/gtest.h"
18 #include "skia_adapter/skia_vertices.h"
19 #include "utils/vertices.h"
20
21 using namespace testing;
22 using namespace testing::ext;
23
24 namespace OHOS {
25 namespace Rosen {
26 namespace Drawing {
27 class SkiaVerticesTest : public testing::Test {
28 public:
29 static void SetUpTestCase();
30 static void TearDownTestCase();
31 void SetUp() override;
32 void TearDown() override;
33 };
34
SetUpTestCase()35 void SkiaVerticesTest::SetUpTestCase() {}
TearDownTestCase()36 void SkiaVerticesTest::TearDownTestCase() {}
SetUp()37 void SkiaVerticesTest::SetUp() {}
TearDown()38 void SkiaVerticesTest::TearDown() {}
39
40 /**
41 * @tc.name: MakeCopy001
42 * @tc.desc: Test MakeCopy
43 * @tc.type: FUNC
44 * @tc.require:I91EDT
45 */
46 HWTEST_F(SkiaVerticesTest, MakeCopy001, TestSize.Level1)
47 {
48 SkiaVertices::SkiaBuilder skiaBuilder;
49 int vertCounts = 4;
50 int indexCount = 6;
51 skiaBuilder.Init(VertexMode::TRIANGLES_VERTEXMODE, vertCounts, indexCount, 1);
52 ASSERT_TRUE(skiaBuilder.IsValid());
53 SkiaVertices skiaVertices;
54 bool ret = skiaVertices.MakeCopy(VertexMode::TRIANGLES_VERTEXMODE, vertCounts,
55 skiaBuilder.Positions(), skiaBuilder.TexCoords(), skiaBuilder.Colors(),
56 indexCount, skiaBuilder.Indices());
57 ASSERT_TRUE(ret);
58 ColorQuad colors[] = {0xFF000000, 0xFF000000, 0xFF000000, 0xFF000000};
59 ret = skiaVertices.MakeCopy(VertexMode::TRIANGLES_VERTEXMODE, vertCounts,
60 skiaBuilder.Positions(), skiaBuilder.TexCoords(), colors,
61 indexCount, skiaBuilder.Indices());
62 ASSERT_TRUE(ret);
63 }
64
65 /**
66 * @tc.name: MakeCopy002
67 * @tc.desc: Test MakeCopy
68 * @tc.type: FUNC
69 * @tc.require:I91EDT
70 */
71 HWTEST_F(SkiaVerticesTest, MakeCopy002, TestSize.Level1)
72 {
73 SkiaVertices::SkiaBuilder skiaBuilder;
74 int vertCounts = 4;
75 int indexCount = 6;
76 skiaBuilder.Init(VertexMode::TRIANGLES_VERTEXMODE, vertCounts, indexCount, 1);
77 ASSERT_TRUE(skiaBuilder.IsValid());
78 SkiaVertices skiaVertices;
79 bool ret = skiaVertices.MakeCopy(VertexMode::TRIANGLES_VERTEXMODE, vertCounts,
80 skiaBuilder.Positions(), skiaBuilder.TexCoords(), skiaBuilder.Colors());
81 ASSERT_TRUE(ret);
82 ColorQuad colors[] = {0xFF000000, 0xFF000000, 0xFF000000, 0xFF000000};
83 ret = skiaVertices.MakeCopy(VertexMode::TRIANGLES_VERTEXMODE, vertCounts,
84 skiaBuilder.Positions(), skiaBuilder.TexCoords(), colors);
85 ASSERT_TRUE(ret);
86 }
87
88 /**
89 * @tc.name: GetVertices001
90 * @tc.desc: Test GetVertices
91 * @tc.type: FUNC
92 * @tc.require:I91EDT
93 */
94 HWTEST_F(SkiaVerticesTest, GetVertices001, TestSize.Level1)
95 {
96 SkiaVertices skiaVertices;
97 ASSERT_TRUE(skiaVertices.GetVertices() == nullptr);
98 }
99
100 /**
101 * @tc.name: SkiaBuilder001
102 * @tc.desc: Test SkiaBuilder
103 * @tc.type: FUNC
104 * @tc.require:I91EDT
105 */
106 HWTEST_F(SkiaVerticesTest, SkiaBuilder001, TestSize.Level1)
107 {
108 SkiaVertices::SkiaBuilder skiaBuilder;
109 ASSERT_TRUE(!skiaBuilder.IsValid());
110 ASSERT_TRUE(skiaBuilder.Positions() == nullptr);
111 ASSERT_TRUE(skiaBuilder.Indices() == nullptr);
112 ASSERT_TRUE(skiaBuilder.TexCoords() == nullptr);
113 ASSERT_TRUE(skiaBuilder.Colors() == nullptr);
114 ASSERT_TRUE(skiaBuilder.Detach() == nullptr);
115 }
116 } // namespace Drawing
117 } // namespace Rosen
118 } // namespace OHOS