From 0344947e4988e65b9f4af64eee5a6539ee9bd394 Mon Sep 17 00:00:00 2001 From: kishanps Date: Fri, 1 Dec 2023 10:14:51 -0800 Subject: [PATCH] [Thinkit] Add more ALPM miss counter tests. PiperOrigin-RevId: 587044830 --- pins_infra_deps.bzl | 8 + .../system/alpm_miss_counter_tests.cc | 315 ++++++++++-------- 2 files changed, 191 insertions(+), 132 deletions(-) diff --git a/pins_infra_deps.bzl b/pins_infra_deps.bzl index ec7d5f13..c8d7c81b 100644 --- a/pins_infra_deps.bzl +++ b/pins_infra_deps.bzl @@ -30,6 +30,14 @@ def pins_infra_deps(): "https://github.com/google/boringssl/archive/b8a2bffc598f230484ff48a247526a9820facfc2.tar.gz", ], ) + if not native.existing_rule("com_github_nelhage_rules_boost"): + # This version includes the fix for boost failures due to the xz library issue. + http_archive( + name = "com_github_nelhage_rules_boost", + url = "https://github.com/nelhage/rules_boost/archive/5160325dbdc8c9e499f9d9917d913f35f1785d52.zip", + strip_prefix = "rules_boost-5160325dbdc8c9e499f9d9917d913f35f1785d52", + sha256 = "feb4b1294684c79df7c1e08f1aec5da0da52021e33db59c88edbe86b4d1a017a", + ) if not native.existing_rule("com_github_grpc_grpc"): http_archive( name = "com_github_grpc_grpc", diff --git a/tests/integration/system/alpm_miss_counter_tests.cc b/tests/integration/system/alpm_miss_counter_tests.cc index 3dd087d0..efcd209f 100644 --- a/tests/integration/system/alpm_miss_counter_tests.cc +++ b/tests/integration/system/alpm_miss_counter_tests.cc @@ -266,7 +266,7 @@ absl::StatusOr GetAlpmMissStat(gnmi::gNMI::StubInterface& gnmi_stub) { return GetGnmiStats(gnmi_stub, state_path, resp_parse_str); } -absl::StatusOr IsPlatformTypeBrixia( +absl::StatusOr DoesPlatformSupportAlpm( gnmi::gNMI::StubInterface& gnmi_stub) { std::string state_path = "components/component[name=chassis]/chassis/state/platform"; @@ -275,15 +275,18 @@ absl::StatusOr IsPlatformTypeBrixia( ASSIGN_OR_RETURN( std::string state_response, GetGnmiStatePathInfo(&gnmi_stub, state_path, resp_parse_str)); - - return absl::StrContains(state_response, "BRIXIA"); + if (absl::StrContains(state_response, "SOME_PLATFORM_NOT_ALPM")){ + return false; + } else { + return true; + } } // Control switch sends packets to SUT. void SendPackets(gnmi::gNMI::StubInterface& sut_gnmi_stub, thinkit::ControlDevice& control_device, absl::string_view sut_port, absl::string_view control_port, - IpVersion ip_version, bool l3_miss = false) { + IpVersion ip_version, bool l3_miss) { // Make test packet. packetlib::Packet test_packet; if (ip_version == IpVersion::kIpv4) { @@ -328,6 +331,38 @@ void SendPackets(gnmi::gNMI::StubInterface& sut_gnmi_stub, EXPECT_GE(in_pkts_on_sut_port, kPacketsToSend); } +// Sends the test packets and verifies the test result. +void SendPacketsAndVerifyResult(gnmi::gNMI::StubInterface& sut_gnmi_stub, + thinkit::ControlDevice& control_device, + absl::string_view sut_port, + absl::string_view control_port, + IpVersion ip_version, bool expect_l3_miss) { + ASSERT_OK_AND_ASSIGN(uint64_t initial_miss_count, + GetAlpmMissStat(sut_gnmi_stub)); + LOG(INFO) << "Initial miss count: " << initial_miss_count; + + LOG(INFO) << "Sending test packets on port: " << control_port; + ASSERT_NO_FATAL_FAILURE(SendPackets(sut_gnmi_stub, control_device, sut_port, + control_port, ip_version, + expect_l3_miss)); + + ASSERT_OK_AND_ASSIGN(uint64_t final_miss_count, + GetAlpmMissStat(sut_gnmi_stub)); + LOG(INFO) << "Final miss count: " << final_miss_count; + + // There is a possibility that a few non-test packets flowed on the links + // while test was running and may have miss the L3 route, so give margin on + // l3 miss counter. + if (expect_l3_miss) { + EXPECT_GE(final_miss_count, initial_miss_count + kPacketsToSend); + EXPECT_LE(final_miss_count, + initial_miss_count + kPacketsToSend + kNumberOfPacketsMargin); + } else { + EXPECT_GE(final_miss_count, initial_miss_count); + EXPECT_LE(final_miss_count, initial_miss_count + kNumberOfPacketsMargin); + } +} + absl::Status ValidatePortsUp( thinkit::Switch& sut, thinkit::ControlDevice& control_device, const std::vector& sut_interfaces, @@ -346,16 +381,32 @@ absl::Status ValidatePortsUp( return absl::InternalError("PortsUp validation failed."); } +void InstallTestEntries(thinkit::Switch& sut, + std::optional p4info, + struct AlpmRouteParams& route_params, + IpVersion ip_version) { + ASSERT_OK_AND_ASSIGN(std::unique_ptr p4_session, + pins_test::ConfigureSwitchAndReturnP4RuntimeSession( + sut, /*gnmi_config=*/std::nullopt, p4info)); + + ASSERT_OK_AND_ASSIGN(sai::TableEntries sut_test_entries, + ConstructTestEntries(route_params, ip_version)); + ASSERT_OK(pdpi::ClearTableEntries(p4_session.get())); + + LOG(INFO) << "Installing entries:" << sut_test_entries.ShortDebugString(); + ASSERT_OK(pdpi::InstallPdTableEntries(*p4_session, sut_test_entries)); +} + // Tests that when IPv4 L3 route is added and Ipv4 test packets hit the added // route, ALPM miss counter doesn't go up. TEST_P(AlpmMissCountersTest, Ipv4AlpmRouteHit) { ASSERT_NO_FATAL_FAILURE( InitializeTestEnvironment("d9716769-9ca5-477b-b53b-1b96fce60e13")); - ASSERT_OK_AND_ASSIGN(bool is_sut_brixia, - IsPlatformTypeBrixia(*sut_gnmi_stub_)); - if (!is_sut_brixia) { - GTEST_SKIP() << "Test is not supported on non-Brixia SUT."; + ASSERT_OK_AND_ASSIGN(bool is_sut_alpm, + DoesPlatformSupportAlpm(*sut_gnmi_stub_)); + if (!is_sut_alpm) { + GTEST_SKIP() << "Test is not supported on NON_ALPM SUT."; } if (!generic_testbed_->ControlDevice().SupportsSendPacket()) { GTEST_SKIP() << "Control device does not support SendPacket"; @@ -377,36 +428,13 @@ TEST_P(AlpmMissCountersTest, Ipv4AlpmRouteHit) { GetPortId(*sut_gnmi_stub_, test_sut_interface)); CreateAlpmRouteParams(route_params_, sut_port_id); - ASSERT_OK_AND_ASSIGN(std::unique_ptr p4_session, - pins_test::ConfigureSwitchAndReturnP4RuntimeSession( - sut, - /*gnmi_config=*/std::nullopt, GetParam().p4_info)); - - ASSERT_OK_AND_ASSIGN(sai::TableEntries sut_test_entries, - ConstructTestEntries(route_params_, IpVersion::kIpv4)); - ASSERT_OK(pdpi::ClearTableEntries(p4_session.get())); - - LOG(INFO) << "Installing entries:" << sut_test_entries.ShortDebugString(); - ASSERT_OK(pdpi::InstallPdTableEntries(*p4_session, sut_test_entries)); - - ASSERT_OK_AND_ASSIGN(uint64_t initial_miss_count, - GetAlpmMissStat(*sut_gnmi_stub_)); - LOG(INFO) << "Initial miss count: " << initial_miss_count; + ASSERT_NO_FATAL_FAILURE(InstallTestEntries(sut, GetParam().p4_info, + route_params_, IpVersion::kIpv4)); - LOG(INFO) << "Sending test packets on port " << test_sut_interface; - ASSERT_NO_FATAL_FAILURE(SendPackets( + ASSERT_NO_FATAL_FAILURE(SendPacketsAndVerifyResult( *sut_gnmi_stub_, control_device, test_sut_interface, - sut_to_peer_interface_mapping_[test_sut_interface], IpVersion::kIpv4)); - - ASSERT_OK_AND_ASSIGN(uint64_t final_miss_count, - GetAlpmMissStat(*sut_gnmi_stub_)); - LOG(INFO) << "Final miss count: " << final_miss_count; - - // There is a possibility that a few non-test packets flowed on the links - // while test was running and may have miss the L3 route, so give margin on - // l3 miss counter. - EXPECT_GE(final_miss_count, initial_miss_count); - EXPECT_LE(final_miss_count, initial_miss_count + kNumberOfPacketsMargin); + sut_to_peer_interface_mapping_[test_sut_interface], IpVersion::kIpv4, + /*expect_l3_miss=*/false)); ASSERT_OK( ValidatePortsUp(sut, control_device, sut_interfaces_, peer_interfaces_)); @@ -418,10 +446,10 @@ TEST_P(AlpmMissCountersTest, Ipv4AlpmRouteMiss) { ASSERT_NO_FATAL_FAILURE( InitializeTestEnvironment("07dda215-ad21-4c25-b89e-1128b3806c27")); - ASSERT_OK_AND_ASSIGN(bool is_sut_brixia, - IsPlatformTypeBrixia(*sut_gnmi_stub_)); - if (!is_sut_brixia) { - GTEST_SKIP() << "Test is not supported on non-Brixia SUT."; + ASSERT_OK_AND_ASSIGN(bool is_sut_alpm, + DoesPlatformSupportAlpm(*sut_gnmi_stub_)); + if (!is_sut_alpm) { + GTEST_SKIP() << "Test is not supported on NON_ALPM SUT."; } if (!generic_testbed_->ControlDevice().SupportsSendPacket()) { GTEST_SKIP() << "Control device does not support SendPacket"; @@ -443,38 +471,13 @@ TEST_P(AlpmMissCountersTest, Ipv4AlpmRouteMiss) { GetPortId(*sut_gnmi_stub_, test_sut_interface)); CreateAlpmRouteParams(route_params_, sut_port_id); - ASSERT_OK_AND_ASSIGN(std::unique_ptr p4_session, - pins_test::ConfigureSwitchAndReturnP4RuntimeSession( - sut, - /*gnmi_config=*/std::nullopt, GetParam().p4_info)); + ASSERT_NO_FATAL_FAILURE(InstallTestEntries(sut, GetParam().p4_info, + route_params_, IpVersion::kIpv4)); - ASSERT_OK_AND_ASSIGN(sai::TableEntries sut_test_entries, - ConstructTestEntries(route_params_, IpVersion::kIpv4)); - ASSERT_OK(pdpi::ClearTableEntries(p4_session.get())); - - LOG(INFO) << "Installing entries:" << sut_test_entries.ShortDebugString(); - ASSERT_OK(pdpi::InstallPdTableEntries(*p4_session, sut_test_entries)); - - ASSERT_OK_AND_ASSIGN(uint64_t initial_miss_count, - GetAlpmMissStat(*sut_gnmi_stub_)); - LOG(INFO) << "Initial miss count: " << initial_miss_count; - - LOG(INFO) << "Sending test packets on port " << test_sut_interface; - ASSERT_NO_FATAL_FAILURE( - SendPackets(*sut_gnmi_stub_, control_device, test_sut_interface, - sut_to_peer_interface_mapping_[test_sut_interface], - IpVersion::kIpv4, /*l3_miss=*/true)); - - ASSERT_OK_AND_ASSIGN(uint64_t final_miss_count, - GetAlpmMissStat(*sut_gnmi_stub_)); - LOG(INFO) << "Final miss count: " << final_miss_count; - - // There is a possibility that a few non-test packets flowed on the links - // while test was running and may have miss the L3 route, so give - // margin on l3 miss counter. - EXPECT_GE(final_miss_count, initial_miss_count + kPacketsToSend); - EXPECT_LE(final_miss_count, - initial_miss_count + kPacketsToSend + kNumberOfPacketsMargin); + ASSERT_NO_FATAL_FAILURE(SendPacketsAndVerifyResult( + *sut_gnmi_stub_, control_device, test_sut_interface, + sut_to_peer_interface_mapping_[test_sut_interface], IpVersion::kIpv4, + /*expect_l3_miss=*/true)); ASSERT_OK( ValidatePortsUp(sut, control_device, sut_interfaces_, peer_interfaces_)); @@ -486,10 +489,10 @@ TEST_P(AlpmMissCountersTest, Ipv6AlpmRouteHit) { ASSERT_NO_FATAL_FAILURE( InitializeTestEnvironment("552ebd5d-fa98-4298-b4ef-efab286bcc89")); - ASSERT_OK_AND_ASSIGN(bool is_sut_brixia, - IsPlatformTypeBrixia(*sut_gnmi_stub_)); - if (!is_sut_brixia) { - GTEST_SKIP() << "Test is not supported on non-Brixia SUT."; + ASSERT_OK_AND_ASSIGN(bool is_sut_alpm, + DoesPlatformSupportAlpm(*sut_gnmi_stub_)); + if (!is_sut_alpm) { + GTEST_SKIP() << "Test is not supported on NON_ALPM SUT."; } if (!generic_testbed_->ControlDevice().SupportsSendPacket()) { GTEST_SKIP() << "Control device does not support SendPacket"; @@ -511,36 +514,13 @@ TEST_P(AlpmMissCountersTest, Ipv6AlpmRouteHit) { GetPortId(*sut_gnmi_stub_, test_sut_interface)); CreateAlpmRouteParams(route_params_, sut_port_id); - ASSERT_OK_AND_ASSIGN(std::unique_ptr p4_session, - pins_test::ConfigureSwitchAndReturnP4RuntimeSession( - sut, - /*gnmi_config=*/std::nullopt, GetParam().p4_info)); - - ASSERT_OK_AND_ASSIGN(sai::TableEntries sut_test_entries, - ConstructTestEntries(route_params_, IpVersion::kIpv6)); - ASSERT_OK(pdpi::ClearTableEntries(p4_session.get())); - - LOG(INFO) << "Installing entries:" << sut_test_entries.ShortDebugString(); - ASSERT_OK(pdpi::InstallPdTableEntries(*p4_session, sut_test_entries)); + ASSERT_NO_FATAL_FAILURE(InstallTestEntries(sut, GetParam().p4_info, + route_params_, IpVersion::kIpv6)); - ASSERT_OK_AND_ASSIGN(uint64_t initial_miss_count, - GetAlpmMissStat(*sut_gnmi_stub_)); - LOG(INFO) << "Initial miss count: " << initial_miss_count; - - LOG(INFO) << "Sending test packets on port " << test_sut_interface; - ASSERT_NO_FATAL_FAILURE(SendPackets( + ASSERT_NO_FATAL_FAILURE(SendPacketsAndVerifyResult( *sut_gnmi_stub_, control_device, test_sut_interface, - sut_to_peer_interface_mapping_[test_sut_interface], IpVersion::kIpv6)); - - ASSERT_OK_AND_ASSIGN(uint64_t final_miss_count, - GetAlpmMissStat(*sut_gnmi_stub_)); - LOG(INFO) << "Final miss count: " << final_miss_count; - - // There is a possibility that a few non-test packets flowed on the links - // while test was running and may have miss the L3 route, so give margin on - // l3 miss counter. - EXPECT_GE(final_miss_count, initial_miss_count); - EXPECT_LE(final_miss_count, initial_miss_count + kNumberOfPacketsMargin); + sut_to_peer_interface_mapping_[test_sut_interface], IpVersion::kIpv6, + /*expect_l3_miss=*/false)); ASSERT_OK( ValidatePortsUp(sut, control_device, sut_interfaces_, peer_interfaces_)); @@ -552,10 +532,10 @@ TEST_P(AlpmMissCountersTest, Ipv6AlpmRouteMiss) { ASSERT_NO_FATAL_FAILURE( InitializeTestEnvironment("b8c1ba7f-a8ca-429b-bb8b-9fc479fc7e71")); - ASSERT_OK_AND_ASSIGN(bool is_sut_brixia, - IsPlatformTypeBrixia(*sut_gnmi_stub_)); - if (!is_sut_brixia) { - GTEST_SKIP() << "Test is not supported on non-Brixia SUT."; + ASSERT_OK_AND_ASSIGN(bool is_sut_alpm, + DoesPlatformSupportAlpm(*sut_gnmi_stub_)); + if (!is_sut_alpm) { + GTEST_SKIP() << "Test is not supported on NON_ALPM SUT."; } if (!generic_testbed_->ControlDevice().SupportsSendPacket()) { GTEST_SKIP() << "Control device does not support SendPacket"; @@ -577,38 +557,109 @@ TEST_P(AlpmMissCountersTest, Ipv6AlpmRouteMiss) { GetPortId(*sut_gnmi_stub_, test_sut_interface)); CreateAlpmRouteParams(route_params_, sut_port_id); - ASSERT_OK_AND_ASSIGN(std::unique_ptr p4_session, - pins_test::ConfigureSwitchAndReturnP4RuntimeSession( - sut, - /*gnmi_config=*/std::nullopt, GetParam().p4_info)); + ASSERT_NO_FATAL_FAILURE(InstallTestEntries(sut, GetParam().p4_info, + route_params_, IpVersion::kIpv6)); - ASSERT_OK_AND_ASSIGN(sai::TableEntries sut_test_entries, - ConstructTestEntries(route_params_, IpVersion::kIpv6)); - ASSERT_OK(pdpi::ClearTableEntries(p4_session.get())); + ASSERT_NO_FATAL_FAILURE(SendPacketsAndVerifyResult( + *sut_gnmi_stub_, control_device, test_sut_interface, + sut_to_peer_interface_mapping_[test_sut_interface], IpVersion::kIpv6, + /*expect_l3_miss=*/true)); - LOG(INFO) << "Installing entries:" << sut_test_entries.ShortDebugString(); - ASSERT_OK(pdpi::InstallPdTableEntries(*p4_session, sut_test_entries)); + ASSERT_OK( + ValidatePortsUp(sut, control_device, sut_interfaces_, peer_interfaces_)); +} - ASSERT_OK_AND_ASSIGN(uint64_t initial_miss_count, - GetAlpmMissStat(*sut_gnmi_stub_)); - LOG(INFO) << "Initial miss count: " << initial_miss_count; +// Tests that when IPv4 and IPv6 L3 routes are added and sent IPv4 and IPv6 test +// packets hit the added respective Ipv4/Ipv6 routes, ALPM miss counter does not +// go up. +TEST_P(AlpmMissCountersTest, Ipv4AndIpv6AlpmRoutesHit) { + ASSERT_NO_FATAL_FAILURE( + InitializeTestEnvironment("0fa17c84-fd92-4d79-a617-7b51e7b8c9ab")); + + ASSERT_OK_AND_ASSIGN(bool is_sut_alpm, + DoesPlatformSupportAlpm(*sut_gnmi_stub_)); + if (!is_sut_alpm) { + GTEST_SKIP() << "Test is not supported on NON_ALPM SUT."; + } + if (!generic_testbed_->ControlDevice().SupportsSendPacket()) { + GTEST_SKIP() << "Control device does not support SendPacket"; + } + // Test requires at least 1 SUT interface. + if (sut_interfaces_.empty()) { + GTEST_SKIP() << "Need at least 1 SUT interface to test but got: " + << sut_interfaces_.size(); + } + + thinkit::Switch& sut = generic_testbed_->Sut(); + thinkit::ControlDevice& control_device = generic_testbed_->ControlDevice(); + ASSERT_OK( + ValidatePortsUp(sut, control_device, sut_interfaces_, peer_interfaces_)); + + std::shuffle(sut_interfaces_.begin(), sut_interfaces_.end(), absl::BitGen()); + std::string test_sut_interface = sut_interfaces_[0]; + ASSERT_OK_AND_ASSIGN(std::string sut_port_id, + GetPortId(*sut_gnmi_stub_, test_sut_interface)); + CreateAlpmRouteParams(route_params_, sut_port_id); + + ASSERT_NO_FATAL_FAILURE(InstallTestEntries( + sut, GetParam().p4_info, route_params_, IpVersion::kIpv4And6)); + + for (IpVersion ip_version : {IpVersion::kIpv4, IpVersion::kIpv6}) { + SCOPED_TRACE(absl::StrCat( + "Testing ", ip_version == IpVersion::kIpv4 ? "ipv4" : "ipv6")); + ASSERT_NO_FATAL_FAILURE(SendPacketsAndVerifyResult( + *sut_gnmi_stub_, control_device, test_sut_interface, + sut_to_peer_interface_mapping_[test_sut_interface], ip_version, + /*expect_l3_miss=*/false)); + } + + ASSERT_OK( + ValidatePortsUp(sut, control_device, sut_interfaces_, peer_interfaces_)); +} - LOG(INFO) << "Sending test packets on port " << test_sut_interface; +// Tests that when IPv4 and IPv6 L3 routes are added and sent IPv4 and IPv6 test +// packets miss the added respective Ipv4/Ipv6 routes, ALPM miss counter goes +// up. +TEST_P(AlpmMissCountersTest, Ipv4AndIpv6AlpmRoutesMiss) { ASSERT_NO_FATAL_FAILURE( - SendPackets(*sut_gnmi_stub_, control_device, test_sut_interface, - sut_to_peer_interface_mapping_[test_sut_interface], - IpVersion::kIpv6, /*l3_miss=*/true)); + InitializeTestEnvironment("f2b48a38-bbb3-4ec0-9f91-e596a5d3dac3")); - ASSERT_OK_AND_ASSIGN(uint64_t final_miss_count, - GetAlpmMissStat(*sut_gnmi_stub_)); - LOG(INFO) << "Final miss count: " << final_miss_count; + ASSERT_OK_AND_ASSIGN(bool is_sut_alpm, + DoesPlatformSupportAlpm(*sut_gnmi_stub_)); + if (!is_sut_alpm) { + GTEST_SKIP() << "Test is not supported on NON_ALPM SUT."; + } + if (!generic_testbed_->ControlDevice().SupportsSendPacket()) { + GTEST_SKIP() << "Control device does not support SendPacket"; + } + // Test requires at least 1 SUT interface. + if (sut_interfaces_.empty()) { + GTEST_SKIP() << "Need at least 1 SUT interface to test but got: " + << sut_interfaces_.size(); + } - // There is a possibility that a few non-test packets flowed on the links - // while test was running and may have miss the L3 route, so give margin on - // l3 miss counter. - EXPECT_GE(final_miss_count, initial_miss_count + kPacketsToSend); - EXPECT_LE(final_miss_count, - initial_miss_count + kPacketsToSend + kNumberOfPacketsMargin); + thinkit::Switch& sut = generic_testbed_->Sut(); + thinkit::ControlDevice& control_device = generic_testbed_->ControlDevice(); + ASSERT_OK( + ValidatePortsUp(sut, control_device, sut_interfaces_, peer_interfaces_)); + + std::shuffle(sut_interfaces_.begin(), sut_interfaces_.end(), absl::BitGen()); + std::string test_sut_interface = sut_interfaces_[0]; + ASSERT_OK_AND_ASSIGN(std::string sut_port_id, + GetPortId(*sut_gnmi_stub_, test_sut_interface)); + CreateAlpmRouteParams(route_params_, sut_port_id); + + ASSERT_NO_FATAL_FAILURE(InstallTestEntries( + sut, GetParam().p4_info, route_params_, IpVersion::kIpv4And6)); + + for (IpVersion ip_version : {IpVersion::kIpv4, IpVersion::kIpv6}) { + SCOPED_TRACE(absl::StrCat( + "Testing ", ip_version == IpVersion::kIpv4 ? "ipv4" : "ipv6")); + ASSERT_NO_FATAL_FAILURE(SendPacketsAndVerifyResult( + *sut_gnmi_stub_, control_device, test_sut_interface, + sut_to_peer_interface_mapping_[test_sut_interface], ip_version, + /*expect_l3_miss=*/true)); + } ASSERT_OK( ValidatePortsUp(sut, control_device, sut_interfaces_, peer_interfaces_));