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