1484543d1Sopenharmony_ci/*
2484543d1Sopenharmony_ci * Copyright (c) 2023 Huawei Device Co., Ltd.
3484543d1Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4484543d1Sopenharmony_ci * you may not use this file except in compliance with the License.
5484543d1Sopenharmony_ci * You may obtain a copy of the License at
6484543d1Sopenharmony_ci *
7484543d1Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8484543d1Sopenharmony_ci *
9484543d1Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10484543d1Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11484543d1Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12484543d1Sopenharmony_ci * See the License for the specific language governing permissions and
13484543d1Sopenharmony_ci * limitations under the License.
14484543d1Sopenharmony_ci */
15484543d1Sopenharmony_ci
16484543d1Sopenharmony_ci#include <random>
17484543d1Sopenharmony_ci
18484543d1Sopenharmony_ci#include <gtest/gtest.h>
19484543d1Sopenharmony_ci#include "util/graph_check.h"
20484543d1Sopenharmony_ci#include "../common.h"
21484543d1Sopenharmony_ci
22484543d1Sopenharmony_ciusing namespace std;
23484543d1Sopenharmony_ciusing namespace testing;
24484543d1Sopenharmony_ci#ifdef HWTEST_TESTING_EXT_ENABLE
25484543d1Sopenharmony_ciusing namespace testing::ext;
26484543d1Sopenharmony_ci#endif
27484543d1Sopenharmony_ciusing namespace ffrt;
28484543d1Sopenharmony_ci
29484543d1Sopenharmony_ciclass GraphCheckTest : public testing::Test {
30484543d1Sopenharmony_ciprotected:
31484543d1Sopenharmony_ci    static void SetUpTestCase()
32484543d1Sopenharmony_ci    {
33484543d1Sopenharmony_ci    }
34484543d1Sopenharmony_ci
35484543d1Sopenharmony_ci    static void TearDownTestCase()
36484543d1Sopenharmony_ci    {
37484543d1Sopenharmony_ci    }
38484543d1Sopenharmony_ci
39484543d1Sopenharmony_ci    virtual void SetUp()
40484543d1Sopenharmony_ci    {
41484543d1Sopenharmony_ci    }
42484543d1Sopenharmony_ci
43484543d1Sopenharmony_ci    virtual void TearDown()
44484543d1Sopenharmony_ci    {
45484543d1Sopenharmony_ci    }
46484543d1Sopenharmony_ci};
47484543d1Sopenharmony_ci
48484543d1Sopenharmony_ciHWTEST_F(GraphCheckTest, HasCyclic, TestSize.Level1)
49484543d1Sopenharmony_ci{
50484543d1Sopenharmony_ci    GraphCheckCyclic graph;
51484543d1Sopenharmony_ci
52484543d1Sopenharmony_ci    graph.AddVetexByLabel(0x12);
53484543d1Sopenharmony_ci    graph.AddVetexByLabel(0x34);
54484543d1Sopenharmony_ci    graph.AddEdgeByLabel(0x12, 0x34);
55484543d1Sopenharmony_ci    graph.AddEdgeByLabel(0x34, 0x12);
56484543d1Sopenharmony_ci
57484543d1Sopenharmony_ci    EXPECT_EQ(graph.VertexNum(), 2);
58484543d1Sopenharmony_ci    EXPECT_EQ(graph.IsCyclic(), true);
59484543d1Sopenharmony_ci}
60484543d1Sopenharmony_ci
61484543d1Sopenharmony_ciHWTEST_F(GraphCheckTest, HasNoCyclic, TestSize.Level1)
62484543d1Sopenharmony_ci{
63484543d1Sopenharmony_ci    GraphCheckCyclic graph;
64484543d1Sopenharmony_ci
65484543d1Sopenharmony_ci    graph.AddVetexByLabel(0x12);
66484543d1Sopenharmony_ci    graph.AddVetexByLabel(0x34);
67484543d1Sopenharmony_ci    graph.AddEdgeByLabel(0x12, 0x34);
68484543d1Sopenharmony_ci    graph.AddEdgeByLabel(0x34, 0x12);
69484543d1Sopenharmony_ci    graph.RemoveEdgeByLabel(0x12);
70484543d1Sopenharmony_ci
71484543d1Sopenharmony_ci    EXPECT_EQ(graph.EdgeNum(), 1);
72484543d1Sopenharmony_ci    EXPECT_EQ(graph.IsCyclic(), false);
73484543d1Sopenharmony_ci}
74