From ba083c1eccbebfee3b344352fa9e41fe12599b2d Mon Sep 17 00:00:00 2001 From: yunhanw Date: Mon, 14 Sep 2020 12:13:47 -0700 Subject: [PATCH] Enable TestInetEndPoint and TestInetLayerDNS Problem Missing TestInetEndPoint and TestInetLayerDNS for Inet layer Summary of Changes Add TestInetEndPoint and TestInetLayerDNS Add IPv6 support in docker Fix #329 --- .github/workflows/build.yaml | 1 + src/inet/tests/BUILD.gn | 2 ++ src/inet/tests/Makefile.am | 9 ++++-- src/inet/tests/TestInetEndPoint.cpp | 28 +++++++----------- src/inet/tests/TestInetEndPointDriver.cpp | 36 +++++++++++++++++++++++ src/inet/tests/TestInetLayer.h | 3 +- src/inet/tests/TestInetLayerDNS.cpp | 35 +++++----------------- src/inet/tests/TestInetLayerDNSDriver.cpp | 36 +++++++++++++++++++++++ 8 files changed, 101 insertions(+), 49 deletions(-) create mode 100644 src/inet/tests/TestInetEndPointDriver.cpp create mode 100644 src/inet/tests/TestInetLayerDNSDriver.cpp diff --git a/.github/workflows/build.yaml b/.github/workflows/build.yaml index 6834b2e45e16c0..d85f09f3371c31 100644 --- a/.github/workflows/build.yaml +++ b/.github/workflows/build.yaml @@ -37,6 +37,7 @@ jobs: image: connectedhomeip/chip-build:0.4.6 volumes: - "/tmp/log_output:/tmp/test_logs" + options: --privileged --sysctl "net.ipv6.conf.all.disable_ipv6=0 net.ipv4.conf.all.forwarding=1 net.ipv6.conf.all.forwarding=1" steps: - name: Checkout diff --git a/src/inet/tests/BUILD.gn b/src/inet/tests/BUILD.gn index fe968dbea03dde..8bc65af8d97f35 100644 --- a/src/inet/tests/BUILD.gn +++ b/src/inet/tests/BUILD.gn @@ -53,5 +53,7 @@ chip_test_suite("tests") { tests = [ "TestInetAddress", "TestInetErrorStr", + "TestInetEndPoint", + "TestInetLayerDNS", ] } diff --git a/src/inet/tests/Makefile.am b/src/inet/tests/Makefile.am index ccf27f17c2c972..fa89e75e9107ed 100644 --- a/src/inet/tests/Makefile.am +++ b/src/inet/tests/Makefile.am @@ -181,15 +181,20 @@ TestLwIPDNS_LDADD = libTestInetCommon.a $(CO TestInetAddress_SOURCES = TestInetAddressDriver.cpp TestInetAddress_LDADD = $(COMMON_LDADD) -TestInetEndPoint_SOURCES = TestInetEndPoint.cpp \ +TestInetEndPoint_SOURCES = TestInetEndPointDriver.cpp \ + TestInetEndPoint.cpp \ $(NULL) + TestInetEndPoint_LDADD = libTestInetCommon.a $(COMMON_LDADD) TestInetErrorStr_SOURCES = TestInetErrorStrDriver.cpp \ $(NULL) TestInetErrorStr_LDADD = $(COMMON_LDADD) -TestInetLayerDNS_SOURCES = TestInetLayerDNS.cpp +TestInetLayerDNS_SOURCES = TestInetLayerDNSDriver.cpp \ + TestInetLayerDNS.cpp \ + $(NULL) + TestInetLayerDNS_LDADD = libTestInetCommon.a $(COMMON_LDADD) TestInetLayer_SOURCES = TestInetLayer.cpp \ diff --git a/src/inet/tests/TestInetEndPoint.cpp b/src/inet/tests/TestInetEndPoint.cpp index 156561ea7a4bab..4b8dfbba980e65 100644 --- a/src/inet/tests/TestInetEndPoint.cpp +++ b/src/inet/tests/TestInetEndPoint.cpp @@ -28,6 +28,8 @@ #define __STDC_LIMIT_MACROS #endif +#include "TestInetLayer.h" + #include #include #include @@ -55,11 +57,6 @@ using namespace chip::System; #define TOOL_NAME "TestInetEndPoint" -static ArgParser::HelpOptions gHelpOptions(TOOL_NAME, "Usage: " TOOL_NAME " []\n", - CHIP_VERSION_STRING "\n" CHIP_TOOL_COPYRIGHT); - -static ArgParser::OptionSet * gToolOptionSets[] = { &gNetworkOptions, &gFaultInjectionOptions, &gHelpOptions, NULL }; - bool callbackHandlerCalled = false; void HandleDNSResolveComplete(void * appState, INET_ERROR err, uint8_t addrCount, IPAddress * addrArray) @@ -129,7 +126,7 @@ static void TestInetPre(nlTestSuite * inSuite, void * inContext) // Test Inet ResolveHostAddress functionality static void TestResolveHostAddress(nlTestSuite * inSuite, void * inContext) { - char testHostName1[20] = "www.nest.com"; + char testHostName1[20] = "www.google.com"; char testHostName2[20] = "127.0.0.1"; char testHostName3[20] = ""; char testHostName4[260]; @@ -191,7 +188,7 @@ static void TestResolveHostAddress(nlTestSuite * inSuite, void * inContext) static void TestParseHost(nlTestSuite * inSuite, void * inContext) { char correctHostName[7][30] = { - "10.0.0.1", "10.0.0.1:3000", "www.nest.com", "www.nest.com:3000", "[fd00:0:1:1::1]:3000", "[fd00:0:1:1::1]:300%wpan0", + "10.0.0.1", "10.0.0.1:3000", "www.google.com", "www.google.com:3000", "[fd00:0:1:1::1]:3000", "[fd00:0:1:1::1]:300%wpan0", "%wpan0" }; char invalidHostName[4][30] = { "[fd00::1]5", "[fd00:0:1:1::1:3000", "10.0.0.1:1234567", "10.0.0.1:er31" }; @@ -296,7 +293,7 @@ static void TestInetInterface(nlTestSuite * inSuite, void * inContext) NL_TEST_ASSERT(inSuite, !addrIterator.HasBroadcastAddress()); } -static void TestInetEndPoint(nlTestSuite * inSuite, void * inContext) +static void TestInetEndPointInternal(nlTestSuite * inSuite, void * inContext) { INET_ERROR err; IPAddress addr_any = IPAddress::Any; @@ -525,7 +522,7 @@ static const nlTest sTests[] = { NL_TEST_DEF("InetEndPoint::PreTest", TestInetPr NL_TEST_DEF("InetEndPoint::TestParseHost", TestParseHost), NL_TEST_DEF("InetEndPoint::TestInetError", TestInetError), NL_TEST_DEF("InetEndPoint::TestInetInterface", TestInetInterface), - NL_TEST_DEF("InetEndPoint::TestInetEndPoint", TestInetEndPoint), + NL_TEST_DEF("InetEndPoint::TestInetEndPoint", TestInetEndPointInternal), NL_TEST_DEF("InetEndPoint::TestEndPointLimit", TestInetEndPointLimit), NL_TEST_SENTINEL() }; @@ -550,7 +547,7 @@ static int TestTeardown(void * inContext) } #endif // CHIP_SYSTEM_CONFIG_USE_SOCKETS -int TestInetEndPoint(void) +int TestInetEndPointInternal(void) { #if CHIP_SYSTEM_CONFIG_USE_SOCKETS // clang-format off @@ -574,20 +571,15 @@ int TestInetEndPoint(void) static void __attribute__((constructor)) TestCHIPInetEndpointCtor(void) { - VerifyOrDie(RegisterUnitTests(&TestInetEndPoint) == CHIP_NO_ERROR); + VerifyOrDie(RegisterUnitTests(&TestInetEndPointInternal) == CHIP_NO_ERROR); } -int main(int argc, char * argv[]) +int TestInetEndPoint() { SetSIGUSR1Handler(); - if (!ParseArgs(TOOL_NAME, argc, argv, gToolOptionSets, NULL)) - { - exit(EXIT_FAILURE); - } - // Generate machine-readable, comma-separated value (CSV) output. nlTestSetOutputStyle(OUTPUT_CSV); - return (TestInetEndPoint()); + return (TestInetEndPointInternal()); } diff --git a/src/inet/tests/TestInetEndPointDriver.cpp b/src/inet/tests/TestInetEndPointDriver.cpp new file mode 100644 index 00000000000000..b6b84cdf7e0481 --- /dev/null +++ b/src/inet/tests/TestInetEndPointDriver.cpp @@ -0,0 +1,36 @@ +/* + * + * Copyright (c) 2020 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. + */ + +/** + * @file + * This file implements a standalone/native program executable + * test driver for the CHIP Internet (inet) library address unit + * tests. + * + */ + +#include "TestInetLayer.h" + +#include + +int main(void) +{ + // Generate machine-readable, comma-separated value (CSV) output. + nlTestSetOutputStyle(OUTPUT_CSV); + + return (TestInetEndPoint()); +} diff --git a/src/inet/tests/TestInetLayer.h b/src/inet/tests/TestInetLayer.h index 60823ca35835f0..acccd2f4521b23 100644 --- a/src/inet/tests/TestInetLayer.h +++ b/src/inet/tests/TestInetLayer.h @@ -33,7 +33,8 @@ int TestInetAddress(void); int TestInetBuffer(void); int TestInetErrorStr(void); int TestInetTimer(void); - +int TestInetEndPoint(void); +int TestInetLayerDNS(void); #ifdef __cplusplus } #endif diff --git a/src/inet/tests/TestInetLayerDNS.cpp b/src/inet/tests/TestInetLayerDNS.cpp index a7cfa1c35ee1c5..b56bbf24d0a834 100644 --- a/src/inet/tests/TestInetLayerDNS.cpp +++ b/src/inet/tests/TestInetLayerDNS.cpp @@ -27,6 +27,8 @@ #define __STDC_LIMIT_MACROS #endif +#include "TestInetLayer.h" + #include #include #include @@ -82,20 +84,6 @@ static void HandleResolutionComplete(void * appState, INET_ERROR err, uint8_t ad static void ServiceNetworkUntilDone(uint32_t timeoutMS); static void HandleSIGUSR1(int sig); -// clang-format off -static ArgParser::HelpOptions gHelpOptions(TOOL_NAME, - "Usage: " TOOL_NAME " []\n", - CHIP_VERSION_STRING "\n" CHIP_TOOL_COPYRIGHT); - -static ArgParser::OptionSet * gToolOptionSets[] = -{ - &gNetworkOptions, - &gFaultInjectionOptions, - &gHelpOptions, - NULL -}; -// clang-format on - /** * Test basic name resolution functionality. */ @@ -678,7 +666,7 @@ static void HandleSIGUSR1(int sig) exit(0); } -int TestInetLayerDNS(void) +int TestInetLayerDNSInternal(void) { // clang-format off const nlTest DNSTests[] = @@ -719,12 +707,11 @@ int TestInetLayerDNS(void) static void __attribute__((constructor)) TestCHIPInetLayerDNSCtor(void) { - VerifyOrDie(RegisterUnitTests(&TestInetLayerDNS) == CHIP_NO_ERROR); + VerifyOrDie(RegisterUnitTests(&TestInetLayerDNSInternal) == CHIP_NO_ERROR); } - #else // !INET_CONFIG_ENABLE_DNS_RESOLVER -int TestInetLayerDNS(void) +int TestInetLayerDNSInternal(void) { fprintf(stderr, "Please assert INET_CONFIG_ENABLE_DNS_RESOLVER to use this test.\n"); @@ -733,19 +720,11 @@ int TestInetLayerDNS(void) #endif // !INET_CONFIG_ENABLE_DNS_RESOLVER -int main(int argc, char * argv[]) +int TestInetLayerDNS() { - SetupFaultInjectionContext(argc, argv); - SetSignalHandler(HandleSIGUSR1); - if (!ParseArgsFromEnvVar(TOOL_NAME, TOOL_OPTIONS_ENV_VAR_NAME, gToolOptionSets, NULL, true) || - !ParseArgs(TOOL_NAME, argc, argv, gToolOptionSets, NULL)) - { - exit(EXIT_FAILURE); - } - nlTestSetOutputStyle(OUTPUT_CSV); - return (TestInetLayerDNS()); + return (TestInetLayerDNSInternal()); } diff --git a/src/inet/tests/TestInetLayerDNSDriver.cpp b/src/inet/tests/TestInetLayerDNSDriver.cpp new file mode 100644 index 00000000000000..8506e19322d49f --- /dev/null +++ b/src/inet/tests/TestInetLayerDNSDriver.cpp @@ -0,0 +1,36 @@ +/* + * + * Copyright (c) 2020 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. + */ + +/** + * @file + * This file implements a standalone/native program executable + * test driver for the CHIP Internet (inet) library address unit + * tests. + * + */ + +#include "TestInetLayer.h" + +#include + +int main(void) +{ + // Generate machine-readable, comma-separated value (CSV) output. + nlTestSetOutputStyle(OUTPUT_CSV); + + return (TestInetLayerDNS()); +}