From 1088220bbefec1ec42f15baac7c853d448632177 Mon Sep 17 00:00:00 2001 From: Jiacheng Guo Date: Thu, 9 Sep 2021 11:43:57 +0800 Subject: [PATCH] [controller] reset Device state for usage in accessories (#9386) * [controller] reset Device state for usage in accessories * add unit test --- src/controller/CHIPDevice.cpp | 1 + src/controller/tests/BUILD.gn | 8 ++ src/controller/tests/TestDevice.cpp | 109 ++++++++++++++++++++++++++++ 3 files changed, 118 insertions(+) create mode 100644 src/controller/tests/TestDevice.cpp diff --git a/src/controller/CHIPDevice.cpp b/src/controller/CHIPDevice.cpp index 9d318b0ad7d1af..c64686444c2f57 100644 --- a/src/controller/CHIPDevice.cpp +++ b/src/controller/CHIPDevice.cpp @@ -552,6 +552,7 @@ void Device::OperationalCertProvisioned() Persist(); CloseSession(); + mState = ConnectionState::NotConnected; } CHIP_ERROR Device::WarmupCASESession() diff --git a/src/controller/tests/BUILD.gn b/src/controller/tests/BUILD.gn index e001bca0190bea..45c14fcab444d6 100644 --- a/src/controller/tests/BUILD.gn +++ b/src/controller/tests/BUILD.gn @@ -23,10 +23,18 @@ chip_test_suite("tests") { test_sources = [ "TestCommissionableNodeController.cpp" ] + if (chip_device_platform == "linux" || chip_device_platform == "Darwin") { + test_sources += [ "TestDevice.cpp" ] + } + cflags = [ "-Wconversion" ] public_deps = [ "${chip_root}/src/controller", "${nlunit_test_root}:nlunit-test", ] + + if (chip_device_platform == "linux" || chip_device_platform == "Darwin") { + public_deps += [ "${chip_root}/src/controller/data_model" ] + } } diff --git a/src/controller/tests/TestDevice.cpp b/src/controller/tests/TestDevice.cpp new file mode 100644 index 00000000000000..c1a5ab6d0d3112 --- /dev/null +++ b/src/controller/tests/TestDevice.cpp @@ -0,0 +1,109 @@ +/* + * + * Copyright (c) 2021 Project CHIP Authors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +using namespace chip; +using namespace chip::Transport; +using namespace chip::Controller; +using namespace chip::Messaging; + +namespace { + +using TestTransportMgr = TransportMgr; + +void TestDevice_EstablishSessionDirectly(nlTestSuite * inSuite, void * inContext) +{ + Platform::MemoryInit(); + DeviceTransportMgr transportMgr; + SecureSessionMgr sessionMgr; + ExchangeManager exchangeMgr; + Inet::InetLayer inetLayer; + System::Layer systemLayer; + Ble::BleLayer blelayer; + FabricTable fabrics; + secure_channel::MessageCounterManager messageCounterManager; + SessionIDAllocator idAllocator; + + systemLayer.Init(); + inetLayer.Init(systemLayer, nullptr); + transportMgr.Init( + UdpListenParameters(&inetLayer).SetAddressType(Inet::IPAddressType::kIPAddressType_IPv4).SetListenPort(CHIP_PORT) +#if INET_CONFIG_ENABLE_IPV4 + , + UdpListenParameters(&inetLayer).SetAddressType(Inet::kIPAddressType_IPv4).SetListenPort(CHIP_PORT) +#endif +#if CONFIG_NETWORK_LAYER_BLE + , + BleListenParameters(&blelayer) +#endif + ); + sessionMgr.Init(&systemLayer, &transportMgr, &fabrics, &messageCounterManager); + exchangeMgr.Init(&sessionMgr); + messageCounterManager.Init(&exchangeMgr); + + ControllerDeviceInitParams params = { + .transportMgr = &transportMgr, + .sessionMgr = &sessionMgr, + .exchangeMgr = &exchangeMgr, + .inetLayer = &inetLayer, + .storageDelegate = nullptr, + .idAllocator = &idAllocator, + .fabricsTable = &fabrics, + }; + Device device; + NodeId mockNodeId = 1; + FabricIndex mockFabricIndex = 1; + Inet::IPAddress mockAddr; + Inet::IPAddress::FromString("127.0.0.1", mockAddr); + PeerAddress addr = PeerAddress::UDP(mockAddr, CHIP_PORT); + device.Init(params, CHIP_PORT, mockNodeId, addr, mockFabricIndex); + + device.OperationalCertProvisioned(); + NL_TEST_ASSERT(inSuite, device.EstablishConnectivity(nullptr, nullptr) == CHIP_NO_ERROR); +} + +// clang-format off +const nlTest sTests[] = +{ + NL_TEST_DEF("TestDevice_EstablishSessionDirectly", TestDevice_EstablishSessionDirectly), + NL_TEST_SENTINEL() +}; +// clang-format on + +} // namespace + +int TestDevice() +{ + nlTestSuite theSuite = { "Device", &sTests[0], NULL, NULL }; + nlTestRunner(&theSuite, nullptr); + return nlTestRunnerStats(&theSuite); +} + +CHIP_REGISTER_TEST_SUITE(TestDevice)