From 2a5a1145ae0d08b0ec47669184b6a66a0647bb93 Mon Sep 17 00:00:00 2001 From: divyagayathri-hcl <159437886+divyagayathri-hcl@users.noreply.github.com> Date: Fri, 10 Jan 2025 02:01:34 +0000 Subject: [PATCH] [Thinkit] Punt only ECN marked packets, Replace TestGnmiCheckSpecificInterfaceStateOperation with CheckInterfaceOperStateOverGnmi, Add tolerance to flaky tests, Port status check was called twice in `TestMirroredGnmiCheckAllInterfaceState` test, Enable verification of bert_operation_id in StartBert response, Configure switches sequentially with ConfigureSwitchPairAndReturnP4RuntimeSessionPair & gNMI port mtu tests. (#945) * [Thinkit] Fix the gnoi factory reset test error message matching error, Allow some tolerance for protocol packets, Change neighbor entries to ipv6, Skip ACL modify during bcm-sai 7.1 upgrade, Rate limit punt traffic to control switch & Default to qos_queue 0x7 instead of 0x1. * [Thinkit] Punt only ECN marked packets, Replace TestGnmiCheckSpecificInterfaceStateOperation with CheckInterfaceOperStateOverGnmi, Add tolerance to flaky tests, Port status check was called twice in `TestMirroredGnmiCheckAllInterfaceState` test, Enable verification of bert_operation_id in StartBert response, Configure switches sequentially with ConfigureSwitchPairAndReturnP4RuntimeSessionPair & gNMI port mtu tests. --------- Co-authored-by: kishanps --- tests/forwarding/l3_admit_test.cc | 10 ++- tests/forwarding/watch_port_test.cc | 18 +++++ tests/gnoi/bert_tests.cc | 4 +- tests/lib/switch_test_setup_helpers.cc | 36 +++------ tests/mtu_tests/BUILD.bazel | 1 + tests/mtu_tests/mtu_tests.cc | 104 +++++++++++++++++++++++-- tests/mtu_tests/mtu_tests.h | 32 ++++++-- tests/qos/frontpanel_qos_test.cc | 50 ++++-------- tests/thinkit_sanity_tests.cc | 25 ------ tests/thinkit_sanity_tests.h | 16 +--- 10 files changed, 182 insertions(+), 114 deletions(-) diff --git a/tests/forwarding/l3_admit_test.cc b/tests/forwarding/l3_admit_test.cc index 9b50e4cd2..c3f65470c 100644 --- a/tests/forwarding/l3_admit_test.cc +++ b/tests/forwarding/l3_admit_test.cc @@ -526,7 +526,15 @@ TEST_P(L3AdmitTestFixture, DISABLED_L3AdmitCanUseInPortToRestrictMacAddresses) { } LOG(INFO) << "Done collecting packets."; - EXPECT_EQ(good_packet_count, kNumberOfTestPacket); + if (GetMirrorTestbed().Environment().MaskKnownFailures()) { + // TODO: Reduce expected count by tolerance level. + const int kDropTolerance = 1; + int adjusted_good_packets = kNumberOfTestPacket - kDropTolerance; + EXPECT_GE(good_packet_count, adjusted_good_packets); + EXPECT_LE(good_packet_count, kNumberOfTestPacket); + } else { + EXPECT_EQ(good_packet_count, kNumberOfTestPacket); + } EXPECT_EQ(bad_packet_count, 0); } diff --git a/tests/forwarding/watch_port_test.cc b/tests/forwarding/watch_port_test.cc index 336e290d6..2ee61692f 100644 --- a/tests/forwarding/watch_port_test.cc +++ b/tests/forwarding/watch_port_test.cc @@ -100,6 +100,9 @@ constexpr absl::string_view kGroupId = "group-1"; // Vrf used in the test. constexpr absl::string_view kVrfId = "vrf-1"; +// Time to wait for membership updates after link event triggers. +constexpr absl::Duration kDurationToWaitForMembershipUpdates = absl::Seconds(2); + // Time to wait after which received packets are processed. constexpr absl::Duration kDurationToWaitForPackets = absl::Seconds(5); @@ -737,6 +740,9 @@ TEST_P(WatchPortTestFixture, VerifyBasicWatchPortAction) { ASSERT_OK(VerifyInterfaceState(*sut_gnmi_stub_, port_name, kOperStatusPathMatch, operation)); + // Wait for the membership changes to be processed. + absl::SleepFor(kDurationToWaitForMembershipUpdates); + // Clear the counters before the test. test_data_.ClearReceivedPackets(); @@ -863,6 +869,9 @@ TEST_P(WatchPortTestFixture, VerifyWatchPortActionInCriticalState) { ASSERT_OK(VerifyInterfaceState(*sut_gnmi_stub_, port_name, kOperStatusPathMatch, InterfaceState::kDown)); + // Wait for the membership changes to be processed. + absl::SleepFor(kDurationToWaitForMembershipUpdates); + // Clear the counters before the test. test_data_.ClearReceivedPackets(); @@ -979,6 +988,9 @@ TEST_P(WatchPortTestFixture, VerifyWatchPortActionForSingleMember) { ASSERT_OK(VerifyInterfaceState(*sut_gnmi_stub_, port_name, kOperStatusPathMatch, operation)); + // Wait for the membership changes to be processed. + absl::SleepFor(kDurationToWaitForMembershipUpdates); + // Clear the counters before the test. test_data_.ClearReceivedPackets(); @@ -1108,6 +1120,9 @@ TEST_P(WatchPortTestFixture, VerifyWatchPortActionForMemberModify) { ASSERT_OK(VerifyInterfaceState(*sut_gnmi_stub_, selected_port_name, kOperStatusPathMatch, InterfaceState::kUp)); + // Wait for the membership changes to be processed. + absl::SleepFor(kDurationToWaitForMembershipUpdates); + // Send 5000 packets and check for packet distribution. ASSERT_OK(SendNPacketsToSut(kNumTestPackets, test_config, members, controller_port_ids, ir_p4info, @@ -1228,6 +1243,9 @@ TEST_P(WatchPortTestFixture, VerifyWatchPortActionForDownPortMemberInsert) { ASSERT_OK(VerifyInterfaceState(*sut_gnmi_stub_, selected_port_name, kOperStatusPathMatch, operation)); + // Wait for the membership changes to be processed. + absl::SleepFor(kDurationToWaitForMembershipUpdates); + // Clear the counters before the test. test_data_.ClearReceivedPackets(); diff --git a/tests/gnoi/bert_tests.cc b/tests/gnoi/bert_tests.cc index 48aaf4f62..41d335c66 100644 --- a/tests/gnoi/bert_tests.cc +++ b/tests/gnoi/bert_tests.cc @@ -145,9 +145,7 @@ void SendStartBertRequestSuccessfullyOnControlSwitch( ASSERT_THAT(response.per_port_responses(), SizeIs(request.per_port_requests_size())); - // TODO: Sandcastle does not populate bert_request_id in - // response, remove check for now. - // EXPECT_EQ(response.bert_operation_id(), request.bert_operation_id()); + EXPECT_EQ(response.bert_operation_id(), request.bert_operation_id()); for (int idx = 0; idx < response.per_port_responses_size(); ++idx) { auto per_port_response = response.per_port_responses(idx); diff --git a/tests/lib/switch_test_setup_helpers.cc b/tests/lib/switch_test_setup_helpers.cc index d8382fee4..fe5bb02b6 100644 --- a/tests/lib/switch_test_setup_helpers.cc +++ b/tests/lib/switch_test_setup_helpers.cc @@ -2,7 +2,6 @@ #include #include -#include // NOLINT: third_party library. #include #include #include @@ -178,29 +177,18 @@ ConfigureSwitchPairAndReturnP4RuntimeSessionPair( std::optional gnmi_config, std::optional p4info, const pdpi::P4RuntimeSessionOptionalArgs& metadata) { - // We configure both switches in parallel, since it may require rebooting the - // switch which is costly. - using T = absl::StatusOr>; - T session1, session2; - { - std::future future1 = std::async(std::launch::async, [&] { - return ConfigureSwitchAndReturnP4RuntimeSession( - thinkit_switch1, gnmi_config, p4info, metadata); - }); - std::future future2 = std::async(std::launch::async, [&] { - return ConfigureSwitchAndReturnP4RuntimeSession( - thinkit_switch2, gnmi_config, p4info, metadata); - }); - session1 = future1.get(); - session2 = future2.get(); - } - RETURN_IF_ERROR(session1.status()).SetPrepend() - << "failed to configure switch '" << thinkit_switch1.ChassisName() - << "': "; - RETURN_IF_ERROR(session2.status()).SetPrepend() - << "failed to configure switch '" << thinkit_switch2.ChassisName() - << "': "; - return std::make_pair(std::move(*session1), std::move(*session2)); + // TODO: Ideally, we would configure these in parallel instead. + ASSIGN_OR_RETURN(std::unique_ptr session1, + ConfigureSwitchAndReturnP4RuntimeSession( + thinkit_switch1, gnmi_config, p4info, metadata), + _.SetPrepend() << "failed to configure switch '" + << thinkit_switch1.ChassisName() << "': "); + ASSIGN_OR_RETURN(std::unique_ptr session2, + ConfigureSwitchAndReturnP4RuntimeSession( + thinkit_switch2, gnmi_config, p4info, metadata), + _.SetPrepend() << "failed to configure switch '" + << thinkit_switch2.ChassisName() << "': "); + return std::make_pair(std::move(session1), std::move(session2)); } absl::Status MirrorSutP4rtPortIdConfigToControlSwitch( diff --git a/tests/mtu_tests/BUILD.bazel b/tests/mtu_tests/BUILD.bazel index dfaa5f714..ee463e76c 100644 --- a/tests/mtu_tests/BUILD.bazel +++ b/tests/mtu_tests/BUILD.bazel @@ -47,6 +47,7 @@ cc_library( "//p4_pdpi/packetlib", "//p4_pdpi/packetlib:packetlib_cc_proto", "//sai_p4/instantiations/google:sai_pd_cc_proto", + "//tests/forwarding:util", "//thinkit:control_device", "//thinkit:generic_testbed", "//thinkit:generic_testbed_fixture", diff --git a/tests/mtu_tests/mtu_tests.cc b/tests/mtu_tests/mtu_tests.cc index 1e4af7e32..58f6b912f 100644 --- a/tests/mtu_tests/mtu_tests.cc +++ b/tests/mtu_tests/mtu_tests.cc @@ -1,6 +1,7 @@ #include "tests/mtu_tests/mtu_tests.h" #include +#include #include #include #include @@ -15,8 +16,6 @@ #include "absl/time/clock.h" #include "absl/time/time.h" #include "glog/logging.h" -#include "gmock/gmock.h" -#include "gtest/gtest.h" #include "gutil/collections.h" #include "gutil/proto.h" #include "gutil/status.h" @@ -38,10 +37,13 @@ #include "p4_pdpi/pd.h" #include "sai_p4/instantiations/google/instantiations.h" #include "sai_p4/instantiations/google/sai_pd.pb.h" +#include "tests/forwarding/util.h" #include "thinkit/control_device.h" #include "thinkit/generic_testbed.h" #include "thinkit/proto/generic_testbed.pb.h" #include "thinkit/switch.h" +#include "gmock/gmock.h" +#include "gtest/gtest.h" namespace pins_test { @@ -133,14 +135,15 @@ void MtuRoutingTestFixture::SetUp() { absl::StatusOr MtuRoutingTestFixture::SendTraffic( const int num_pkts, absl::string_view egress_port, - absl::string_view ingress_port, absl::string_view test_packet_str) { + absl::string_view ingress_port, absl::string_view test_packet_str, + std::optional packet_delay) { auto test_packet = gutil::ParseProtoOrDie(test_packet_str); ASSIGN_OR_RETURN(std::string test_packet_data, packetlib::SerializePacket(test_packet)); absl::Mutex mutex; std::vector received_packets; - int i; + int i = 0; { ASSIGN_OR_RETURN(auto finalizer, testbed_->ControlDevice().CollectPackets()); @@ -149,11 +152,12 @@ absl::StatusOr MtuRoutingTestFixture::SendTraffic( << egress_port; LOG(INFO) << "Test packet data: " << test_packet_str; - for (i = 0; i < num_pkts; i++) { - RETURN_IF_ERROR( - testbed_->ControlDevice().SendPacket(egress_port, test_packet_data)) + while (i < num_pkts || unlimited_pkts_) { + RETURN_IF_ERROR(testbed_->ControlDevice().SendPacket( + egress_port, test_packet_data, packet_delay)) << "failed to inject the packet."; LOG(INFO) << "SendPacket completed"; + i++; } RETURN_IF_ERROR(finalizer->HandlePacketsFor( absl::Seconds(30), @@ -169,12 +173,41 @@ absl::StatusOr MtuRoutingTestFixture::SendTraffic( return NumPkts{i, static_cast(received_packets.size())}; } +void MtuRoutingTestFixture::StartUnlimitedTraffic( + const std::string &egress_port, const std::string &ingress_port, + const std::string &test_packet, + std::optional packet_delay) { + // Send unlimited packets packets to SUT. + // Set flag to allow sending unlimited packets to true. + unlimited_pkts_ = true; + LOG(INFO) << "Starting unlimited traffic."; + absl::Duration packet_delay_val; + if (packet_delay.has_value()) { + packet_delay_val = packet_delay.value(); + } + traffic_thread_ = std::thread{[test_packet, this, &egress_port, &ingress_port, + packet_delay_val] { + ASSERT_OK_AND_ASSIGN(num_pkts_, SendTraffic(0, egress_port, ingress_port, + test_packet, packet_delay_val)); + }}; +} + +absl::StatusOr MtuRoutingTestFixture::StopUnlimitedTraffic() { + unlimited_pkts_ = false; + traffic_thread_.join(); + LOG(INFO) << "Stopped unlimited traffic."; + LOG(INFO) << "Sent " << num_pkts_.sent << " packets, received " + << num_pkts_.received << " packets."; + return num_pkts_; +} + namespace { using ::testing::HasSubstr; constexpr absl::string_view kMtuRespParseStr = "openconfig-interfaces:mtu"; constexpr int kDefaultMtu = 9194; +constexpr int kMtu4500 = 4500; // Map of mtu to payload length for packets that are expected to be // successfully egressed out of port under test. @@ -268,5 +301,62 @@ TEST_P(MtuRoutingTestFixture, MtuTest) { SetPortMtu(stub_.get(), destination_link_.sut_interface, std::to_string(orig_mtu)); } + +TEST_P(MtuRoutingTestFixture, VerifyTrafficWithMtuChangeTest) { + testbed_->Environment().SetTestCaseID("ae14bc06-be75-4e9b-8ff8-7defac538982"); + // Get original mtu on port under test on SUT. + std::string if_state_path = absl::StrCat( + "interfaces/interface[name=", destination_link_.sut_interface, + "]/state/mtu"); + ASSERT_OK_AND_ASSIGN( + std::string state_path_response, + GetGnmiStatePathInfo(stub_.get(), if_state_path, kMtuRespParseStr)); + int orig_mtu; + ASSERT_TRUE(absl::SimpleAtoi(state_path_response, &orig_mtu)); + + // Set mtu to 4500 on port under test. + SetPortMtu(stub_.get(), destination_link_.sut_interface, + std::to_string(kMtu4500)); + + // Set up a route between the source and destination interfaces. + ASSERT_OK_AND_ASSIGN( + std::unique_ptr p4_session, + pdpi::P4RuntimeSession::CreateWithP4InfoAndClearTables( + testbed_->Sut(), MtuRoutingTestFixture::GetParam().p4_info)); + P4rtProgrammingContext p4rt_context(p4_session.get(), + pdpi::SetMetadataAndSendPiWriteRequest); + ASSERT_OK(SetupRoute(&p4rt_context)); + + // Send 4k size packet from peer switch to SUT to be routed out of port + // under test and set mtu to 9194 for port under test while traffic is + // being routed from it. + auto test_packet = + GenerateTestPacket(basic_traffic::PortIdToIP(sut_destination_port_id_), + /*payload_len*/ 4000); + StartUnlimitedTraffic( + /*egress_port*/ source_link_.peer_interface, + /*ingress_port*/ destination_link_.peer_interface, + /*test_packet*/ test_packet, + /*packet_delay*/ absl::Duration(absl::Milliseconds(100))); + + // Allow time for traffic to start in order to verify mtu change while + // traffic is running. + absl::SleepFor(absl::Seconds(5)); + SetPortMtu(stub_.get(), destination_link_.sut_interface, + std::to_string(kDefaultMtu)); + + // Allow time to ensure there is no packet loss due to mtu change before + // stopping traffic. + absl::SleepFor(absl::Seconds(5)); + ASSERT_OK_AND_ASSIGN(auto pkts, StopUnlimitedTraffic()); + + // Verify that all the packets are routed out of port under test indicating + // mtu change does not impact traffic. + EXPECT_EQ(pkts.sent, pkts.received); + + // Restore original mtu values on port under test on SUT. + SetPortMtu(stub_.get(), destination_link_.sut_interface, + std::to_string(orig_mtu)); +} } // namespace } // namespace pins_test diff --git a/tests/mtu_tests/mtu_tests.h b/tests/mtu_tests/mtu_tests.h index 9495da4dd..d62a0cb6c 100644 --- a/tests/mtu_tests/mtu_tests.h +++ b/tests/mtu_tests/mtu_tests.h @@ -1,12 +1,16 @@ #ifndef PINS_TESTS_MTU_TESTS_MTU_TESTS_H_ #define PINS_TESTS_MTU_TESTS_MTU_TESTS_H_ +#include +#include // NOLINT: Need threads (instead of fiber) for upstream code. + #include "absl/base/config.h" #include "absl/strings/string_view.h" #include "lib/p4rt/p4rt_programming_context.h" #include "lib/utils/generic_testbed_utils.h" #include "p4_pdpi/packetlib/packetlib.pb.h" #include "thinkit/generic_testbed_fixture.h" + namespace pins_test { struct NumPkts { @@ -24,20 +28,36 @@ class MtuRoutingTestFixture : public thinkit::GenericTestbedFixture<> { std::string GenerateTestPacket(absl::string_view destination_ip, int payload_len); - // Sends num_pkts/unlimited packets from egress_port. Collects packets on + // Sends num_pkts packets from egress_port. Collects packets on // ingress_port and returns number of packets sent and received. - absl::StatusOr SendTraffic(int num_pkts, - absl::string_view egress_port, - absl::string_view ingress_port, - absl::string_view test_packet_str); + absl::StatusOr + SendTraffic(int num_pkts, absl::string_view egress_port, + absl::string_view ingress_port, absl::string_view test_packet_str, + std::optional packet_delay = std::nullopt); - // Set up route from source port to destination port on SUT. + // Sets up route from source port to destination port on SUT. absl::Status SetupRoute(P4rtProgrammingContext *p4rt_context); + // Sends unlimited packets from egress_port. Collects packets on ingress_port + // and returns number of packets sent and received. + void StartUnlimitedTraffic( + const std::string &egress_port, const std::string &ingress_port, + const std::string &test_packet, + std::optional packet_delay = std::nullopt); + + // Stops packet sending thread. + absl::StatusOr StopUnlimitedTraffic(); + InterfaceLink source_link_, destination_link_; int sut_source_port_id_, sut_destination_port_id_; std::unique_ptr testbed_; std::unique_ptr stub_; + +private: + std::thread traffic_thread_; + NumPkts num_pkts_{0, 0}; + // Flag used to allow sending packets as long as the value is true. + bool unlimited_pkts_ = false; }; } // namespace pins_test diff --git a/tests/qos/frontpanel_qos_test.cc b/tests/qos/frontpanel_qos_test.cc index bf21b3f61..2e2d4e684 100644 --- a/tests/qos/frontpanel_qos_test.cc +++ b/tests/qos/frontpanel_qos_test.cc @@ -1424,13 +1424,14 @@ absl::Status SetUpForwardingAndCopyEgressToCpu( )pb", source_mac, kVrfId))); - ASSIGN_OR_RETURN( - pd_entries.emplace_back(), - gutil::ParseTextProto( - R"pb( + ASSIGN_OR_RETURN(pd_entries.emplace_back(), + gutil::ParseTextProto( + R"pb( acl_ingress_table_entry { match { dst_mac { value: "02:02:02:02:02:02" mask: "ff:ff:ff:ff:ff:ff" } + is_ip { value: "0x1" } + ecn { value: "0x3" mask: "0x3" } } action { acl_copy { qos_queue: "2" } } priority: 1 @@ -1703,11 +1704,11 @@ TEST_P(FrontpanelQosTest, TestWredEcnMarking) { const std::string kDefaultQueueName = "BE1"; // Set up the switch to forward inbound packets to the egress port - EXPECT_OK(SetUpForwardingAndCopyEgressToCpu( + ASSERT_OK(SetUpForwardingAndCopyEgressToCpu( kSutOutPortId, kSourceMac.ToString(), kDestMac.ToString(), GetParam().p4info, *sut_p4_session)); - // Test ECN marking for IPv4 then IPv6 traffic. + // Test ECN marking for IPv4 then IPv6 traffic. for (bool is_ipv4 : {false, true}) { // Test for ECT and non-ECT traffic for (bool is_ect : {false, true}) { @@ -1768,15 +1769,15 @@ TEST_P(FrontpanelQosTest, TestWredEcnMarking) { // to ensure threshold is crossed. ASSERT_OK(pins_test::ixia::SetFrameCount( traffic_ref2, - (kWredMaxThresholdInBytes * 2 / kDefaultFrameSizeinBytes), + (kWredMaxThresholdInBytes * 1.5 / kDefaultFrameSizeinBytes), *testbed)); } else { - // Set traffic to 80 percent of line rate. + // Set traffic to 70 percent of line rate. ASSERT_OK(pins_test::ixia::SetFrameRate( - traffic_ref1, frame_rate_at_line_speed_of_in_port1 * 80 / 100, + traffic_ref1, frame_rate_at_line_speed_of_in_port1 * 70 / 100, *testbed)); - // Do not send traffic-2 as we do not want congestion. + // Do not send traffic-2 as we do not want congestion. ASSERT_OK(pins_test::ixia::SetFrameCount(traffic_ref2, 0, *testbed)); } @@ -1795,21 +1796,16 @@ TEST_P(FrontpanelQosTest, TestWredEcnMarking) { GetGnmiQueueCounters(/*port=*/kSutOutPort, /*queue=*/target_queue, *gnmi_stub)); ASSERT_OK(pins::TryUpToNTimes(3, /*delay=*/absl::Seconds(1), [&] { + ResetEcnTestPacketCounters(packet_receive_info); + return pins_test::ixia::StartTraffic(ixia_setup_result.traffic_refs, ixia_setup_result.topology_ref, *testbed); })); - // Time to allow initial burst and to reach steady state queue usage. - constexpr absl::Duration kCongestionTime = absl::Seconds(2); - // Time period to examine egress packets for ECN marking. - constexpr absl::Duration kStatsCollectionTime = absl::Seconds(5); + constexpr absl::Duration kStatsCollectionTime = absl::Seconds(10); - // Wait for traffic to buffer. - absl::SleepFor(kCongestionTime); - - ResetEcnTestPacketCounters(packet_receive_info); absl::SleepFor(kStatsCollectionTime); { @@ -1819,27 +1815,11 @@ TEST_P(FrontpanelQosTest, TestWredEcnMarking) { LOG(INFO) << "Congestion : " << (is_congestion ? "true" : "false"); LOG(INFO) << "IPv4 : " << (is_ipv4 ? "true" : "false"); LOG(INFO) << "ECT : " << (is_ect ? "true" : "false"); - LOG(INFO) << "Packets received: " - << packet_receive_info.num_packets_punted; LOG(INFO) << "ECN marked Packets: " << packet_receive_info.num_packets_ecn_marked; if (is_congestion && is_ect) { - // TODO: Currently we are unable to keep queue usage - // constantly above threshold. The queue usage starts going down in - // a few seconds. Till we understand this, we will allow for - // tolerance in packets marked for ECN. - constexpr float kTolerancePercent = 20.0; - if (testbed->Environment().MaskKnownFailures()) { - // Egress packets must be ECN marked. Tolerance of 20%. - ASSERT_GE(packet_receive_info.num_packets_ecn_marked, - packet_receive_info.num_packets_punted * - (1 - kTolerancePercent / 100)); - } else { - // All egress packets must be ECN marked. - ASSERT_EQ(packet_receive_info.num_packets_punted, - packet_receive_info.num_packets_ecn_marked); - } + ASSERT_GT(packet_receive_info.num_packets_ecn_marked, 0); } else { // No egress packets must be ECN marked. ASSERT_EQ(packet_receive_info.num_packets_ecn_marked, 0); diff --git a/tests/thinkit_sanity_tests.cc b/tests/thinkit_sanity_tests.cc index 7087bdde9..62f88b788 100644 --- a/tests/thinkit_sanity_tests.cc +++ b/tests/thinkit_sanity_tests.cc @@ -157,11 +157,6 @@ void TestGnmiGetAllOperation(thinkit::Switch& sut) { LOG(INFO) << "Received GET response: " << resp.ShortDebugString(); } -void TestGnmiCheckInterfaceStateOperation( - thinkit::MirrorTestbed& testbed, absl::Span interfaces) { - EXPECT_OK(PortsUp(testbed.Sut(), interfaces)); -} - void TestGnmiCheckAlarms(thinkit::MirrorTestbed& testbed) { EXPECT_OK(NoAlarms(testbed.Sut())); } @@ -279,26 +274,6 @@ void TestGnmiConfigBlobSet(thinkit::Switch& sut) { } } -void TestGnmiCheckSpecificInterfaceStateOperation(thinkit::Switch& sut, - absl::string_view if_name) { - ASSERT_OK_AND_ASSIGN(auto sut_gnmi_stub, sut.CreateGnmiStub()); - std::string if_req = absl::StrCat("interfaces/interface[name=", if_name, - "]/state/oper-status"); - ASSERT_OK_AND_ASSIGN(gnmi::GetRequest req, - BuildGnmiGetRequest(if_req, gnmi::GetRequest::STATE)); - LOG(INFO) << "Sending GET request: " << req.ShortDebugString(); - - gnmi::GetResponse resp; - grpc::ClientContext context; - ASSERT_OK(sut_gnmi_stub->Get(&context, req, &resp)); - LOG(INFO) << "Received GET response: " << resp.ShortDebugString(); - ASSERT_OK_AND_ASSIGN( - std::string oper_response, - ParseGnmiGetResponse(resp, "openconfig-interfaces:oper-status")); - LOG(INFO) << "oper_respose: " << oper_response; - EXPECT_THAT(oper_response, HasSubstr(kStateUp)); -} - // Returns last boot time of SUT. absl::StatusOr GetGnmiSystemBootTime( thinkit::Switch& sut, gnmi::gNMI::StubInterface* sut_gnmi_stub) { diff --git a/tests/thinkit_sanity_tests.h b/tests/thinkit_sanity_tests.h index 2085e9761..e0ba6475e 100644 --- a/tests/thinkit_sanity_tests.h +++ b/tests/thinkit_sanity_tests.h @@ -12,8 +12,8 @@ // See the License for the specific language governing permissions and // limitations under the License. -#ifndef GOOGLE_TESTS_THINKIT_SANITY_TESTS_H_ -#define GOOGLE_TESTS_THINKIT_SANITY_TESTS_H_ +#ifndef PINS_TESTS_THINKIT_SANITY_TESTS_H_ +#define PINS_TESTS_THINKIT_SANITY_TESTS_H_ #include "absl/strings/string_view.h" #include "thinkit/mirror_testbed.h" @@ -34,19 +34,9 @@ void TestGnmiGetInterfaceOperation(thinkit::Switch &sut); // Tests that gNMI get all works fine with SUT. void TestGnmiGetAllOperation(thinkit::Switch &sut); -// Tests that all ports state are UP. Uses the interfaces if provided to -// check the port states. -void TestGnmiCheckInterfaceStateOperation( - thinkit::MirrorTestbed &testbed, - absl::Span interfaces = {}); - // Tests that no gNMI alarms are set. void TestGnmiCheckAlarms(thinkit::MirrorTestbed &testbed); -// Tests that SUT specific port state is UP. -void TestGnmiCheckSpecificInterfaceStateOperation(thinkit::Switch &sut, - absl::string_view if_name); - // Tests that SUT is updated with a config Blob. void TestGnmiConfigBlobSet(thinkit::Switch &sut); @@ -54,4 +44,4 @@ void TestGnmiConfigBlobSet(thinkit::Switch &sut); void TestGnoiSystemColdReboot(thinkit::Switch &sut); } // namespace pins_test -#endif // GOOGLE_TESTS_THINKIT_SANITY_TESTS_H_ +#endif // PINS_TESTS_THINKIT_SANITY_TESTS_H_