diff --git a/feature/platform/tests/breakout_configuration/breakout_base_test.go b/feature/platform/tests/breakout_configuration/breakout_base_test.go new file mode 100644 index 00000000000..c19863b3d59 --- /dev/null +++ b/feature/platform/tests/breakout_configuration/breakout_base_test.go @@ -0,0 +1,232 @@ +package breakoutConfiguration + +import ( + "context" + "encoding/binary" + "fmt" + "io" + "net" + "regexp" + "sort" + "strconv" + "strings" + "testing" + + "github.com/openconfig/featureprofiles/internal/fptest" + spb "github.com/openconfig/gnoi/system" + "github.com/openconfig/ondatra" + "github.com/openconfig/ondatra/gnmi" + "github.com/openconfig/ondatra/gnmi/oc" + "github.com/openconfig/testt" +) + +var componentNameList []string + +func getSpeedValue(speed oc.E_IfEthernet_ETHERNET_SPEED) string { + // Convert SPEED_100GB to 100 + speedStr := speed.String() + re := regexp.MustCompile(`SPEED_(\d+)GB`) + matches := re.FindStringSubmatch(speedStr) + if len(matches) > 1 { + return matches[1] + } + return "" +} + +func isBreakoutSupported(t *testing.T, dut *ondatra.DUTDevice, port string, numBreakouts uint8, speed oc.E_IfEthernet_ETHERNET_SPEED) bool { + t.Logf("check phy for port %s", port) + + cliHandle := dut.RawAPIs().CLI(t) + resp, err := cliHandle.RunCommand(context.Background(), fmt.Sprintf("show controllers phy breakout interface %s", port)) + if err != nil { + t.Errorf("Failed to get breakout info: %v", err) + return false + } + + // Create expected format (e.g., "4x100G") + expectedBreakout := fmt.Sprintf("%dx%sG", numBreakouts, getSpeedValue(speed)) + + // Find pattern like "4x100G" in "OPTICS_BO_TYPE_4x100G" + re := regexp.MustCompile(`TYPE_(\d+x\d+G)`) + matches := re.FindStringSubmatch(resp.Output()) + + var foundBreakout string + if len(matches) > 1 { + foundBreakout = matches[1] + } + + t.Logf("Optic Supports the Following Breakout Mode: %s, "+ + "Target breakout Configuration is: %s", foundBreakout, expectedBreakout) + + return foundBreakout == expectedBreakout +} + +// verifyBreakout checks if the breakout configuration matches the expected values. +// It reports errors to the testing object if there is a mismatch. +func verifyBreakout(index uint8, numBreakoutsWant uint8, numBreakoutsGot uint8, breakoutSpeedWant string, breakoutSpeedGot string, t *testing.T) { + // Ensure that the index is set to the expected value (1 in this case). + if index != uint8(0) { + t.Errorf("Index: got %v, want 1", index) + } + // Check if the number of breakouts configured matches what was expected. + if numBreakoutsGot != numBreakoutsWant { + t.Errorf("Number of breakouts configured: got %v, want %v", numBreakoutsGot, numBreakoutsWant) + } + // Verify that the configured breakout speed is as expected. + if breakoutSpeedGot != breakoutSpeedWant { + t.Errorf("Breakout speed configured: got %v, want %v", breakoutSpeedGot, breakoutSpeedWant) + } + +} + +func verifyDelete(t *testing.T, dut *ondatra.DUTDevice, compname string, schemaValue uint8) { + + if errMsg := testt.CaptureFatal(t, func(t testing.TB) { + gnmi.Get(t, dut, gnmi.OC().Component(compname).Port().BreakoutMode().Group(schemaValue).Index().Config()) //catch the error as it is expected and absorb the panic. + }); errMsg != nil { + t.Log("Expected failure as this verifies the breakout config is removed") + } else { + t.Errorf("This get on empty config should have failed : %s", *errMsg) + } +} + +// IncrementIPNetworkPart generates a slice of IP addresses incremented based on the initial IP address provided. +// The function takes an initial IP address, the number of increments, whether it is IPv4, and what the last octet should be. +func IncrementIPNetwork(ipStr string, numBreakouts uint8, isIPv4 bool, lastOctet uint8) ([]string, error) { + // Parse the initial IP address string into an IP object. + ip := net.ParseIP(ipStr) + if ip == nil { + return nil, fmt.Errorf("invalid IP address format") + } + + // Prepare a slice to hold the generated IP addresses. + ips := make([]string, numBreakouts) + + // Define a variable to hold the IP address as an integer for IPv4. + var ip4 uint32 + + // If it's an IPv4 address, convert the IP to a 32-bit integer and clear the last octet. + if isIPv4 { + ip4 = binary.BigEndian.Uint32(ip.To4()) + ip4 &= 0xFFFFFF00 // Apply a mask to retain only the first three octets. + } + + // Loop to generate the required number of IP addresses. + for i := uint8(0); i < numBreakouts; i++ { + // For IPv4, increment the third octet and set the last octet to the specified value. + newIP4 := (ip4 | uint32(lastOctet)) + (uint32(i) << 8) + incrementedIP := make(net.IP, 4) + binary.BigEndian.PutUint32(incrementedIP, newIP4) + ips[i] = fmt.Sprintf("%s/%d", incrementedIP.String(), 24) // Format as a string with a /24 subnet. + } + + return ips, nil +} + +// findNewPortNames fetches the parent breakout port interface states and the new port convention. +// Example being 4x100 parent port would be FourHundredGigE0/0/0/10 this will find and return +// the newly broken out ports of OneHundredGigE0/0/0/0/10/0-4 +func findNewPortNames(dut *ondatra.DUTDevice, t *testing.T, originalPortName string, numBreakouts uint8) ([]string, error) { + // Fetch the current state of all interfaces from the device using gNMI. + intfs := gnmi.Get(t, dut, gnmi.OC().InterfaceMap().State()) + + // Split the original port name by '/' to extract the correct index (third-last segment in this case). + portSegments := strings.Split(originalPortName, "/") + if len(portSegments) < 4 { + return nil, fmt.Errorf("invalid port name format: %v", originalPortName) + } + portIndex := portSegments[len(portSegments)-2] // Get the third-last segment, which is "30" + + // Define a pattern to match breakout port names that include the original port index. + breakoutPattern := fmt.Sprintf(`\w+/\d+/\d+/%s/\d+`, portIndex) + + // Compile the pattern into a regular expression. + re := regexp.MustCompile(breakoutPattern) + + // Loop through all interfaces and collect those that match the breakout pattern + newPortNames := []string{} + for intfName := range intfs { + if re.MatchString(intfName) { + newPortNames = append(newPortNames, intfName) + } + } + + // Check if the number of new ports found is equal to the number of breakouts expected. + if len(newPortNames) != int(numBreakouts) { + return nil, fmt.Errorf("expected to find %d new ports, found %d", numBreakouts, len(newPortNames)) + } + + return newPortNames, nil +} + +// fetchResponses will fetch the ping response +func fetchResponses(c spb.System_PingClient) ([]*spb.PingResponse, error) { + pingResp := []*spb.PingResponse{} + for { + resp, err := c.Recv() + switch { + case err == io.EOF: + return pingResp, nil + case err != nil: + return nil, err + default: + pingResp = append(pingResp, resp) + } + } +} + +func sortBreakoutPorts(breakOutPorts []string) { + sort.Slice(breakOutPorts, func(i, j int) bool { + // Extract the trailing number after the last "/" + numberI, errI := strconv.Atoi(strings.Split(breakOutPorts[i], "/")[4]) + numberJ, errJ := strconv.Atoi(strings.Split(breakOutPorts[j], "/")[4]) + // Handle potential errors from Atoi conversion + if errI != nil || errJ != nil { + return false + } + return numberI < numberJ + }) +} + +// Function to get compName and set up port name based on provided interface and port prefix +func getCompName(dut *ondatra.DUTDevice, string, portPrefix string, t *testing.T) (string, string, bool) { + + foundExpectedInterfaceFlag = false + portsAll := dut.Ports() + + // Look for the port with the specified prefix (e.g., "TenGigE" or "HundredGigE") + for _, port := range portsAll { + if strings.HasPrefix(port.Name(), portPrefix) { + portID := port.ID() + t.Logf("Found port %s with portIdString %s", port.Name(), portID) + dutPortName = dut.Port(t, portID).Name() + foundExpectedInterfaceFlag = true + break + } + } + + // If the expected interface is not found, skip the test case + if !foundExpectedInterfaceFlag { + t.Skipf("Could not find required ports for %s breakout", portPrefix) + } + + // Extract line card slot and port number from the interface name + var portNumber = string + var lcSlot = string + parts := strings.Split(dutPortName, "/") + if len(parts) >= 4 { + lcSlot = parts[2] + portNumber = parts[3] + t.Logf("Extracted Linecard Slot: %s, Port Number: %s", lcSlot, portNumber) + compName := fmt.Sprintf("Port0/%s/0/%s", lcSlot, portNumber) + t.Logf("compName is: %s", compName) + return compName, dutPortName, true + } else { + t.Logf("Invalid location format: %s", dutPortName) + return "", "", false + } +} + +func TestMain(m *testing.M) { + fptest.RunTests(m) +} diff --git a/feature/platform/tests/breakout_configuration/breakout_test.go b/feature/platform/tests/breakout_configuration/breakout_test.go new file mode 100644 index 00000000000..29143a7c0e8 --- /dev/null +++ b/feature/platform/tests/breakout_configuration/breakout_test.go @@ -0,0 +1,367 @@ +package breakoutConfiguration + +import ( + "context" + "fmt" + "net" + "sort" + "strings" + "testing" + "time" + + "github.com/openconfig/featureprofiles/internal/deviations" + spb "github.com/openconfig/gnoi/system" + tpb "github.com/openconfig/gnoi/types" + "github.com/openconfig/ondatra/gnmi" + "github.com/openconfig/ygot/ygot" + + "github.com/open-traffic-generator/snappi/gosnappi" + "github.com/openconfig/featureprofiles/internal/attrs" + "github.com/openconfig/ondatra" + "github.com/openconfig/ondatra/gnmi/oc" +) + +const ( + maxPingRetries = 3 // Set the number of retry attempts + schemaValue = 0 +) + +var ( + dutPortName string + foundExpectedInterfaceFlag bool = false + breakOutCompName string + fullInterfaceName string + foundComp bool + dutPort1 = attrs.Attributes{ + Desc: "dutPort1", + IPv4: "203.0.113.1", + IPv6: "2001:db8::1", + IPv4Len: 24, + IPv6Len: 64, + } + + atePort1 = attrs.Attributes{ + Name: "atePort1", + MAC: "02:00:01:01:01:01", + IPv4: "203.0.113.2", + IPv6: "2001:db8::2", + IPv4Len: 24, + IPv6Len: 64, + } + + dutPort2 = attrs.Attributes{ + Desc: "dutPort2", + IPv4: "204.0.114.1", + IPv6: "2002:db8::1", + IPv4Len: 24, + IPv6Len: 64, + } + + atePort2 = attrs.Attributes{ + Name: "atePort2", + MAC: "02:00:02:02:02:01", + IPv4: "204.0.114.2", + IPv6: "2002:db8::2", + IPv4Len: 24, + IPv6Len: 64, + } +) + +// configureOTG configures port1 and port2 on the ATE. +func configureOTG(t *testing.T, + ate *ondatra.ATEDevice, + breakoutspeed *oc.E_IfEthernet_ETHERNET_SPEED, + ateIpv4Subnets []string, + Dutipv4Subnets []string, + numbreakouts int) gosnappi.Config { + + top := gosnappi.NewConfig() + ports := ate.Ports() + + // Order the ports from 1 to 8 + sort.Slice(ports, func(i, j int) bool { + return ports[i].ID() < ports[j].ID() + }) + + if *breakoutspeed == oc.IfEthernet_ETHERNET_SPEED_SPEED_100GB { + t.Logf("Speed is %v", *breakoutspeed) + } else if *breakoutspeed == oc.IfEthernet_ETHERNET_SPEED_SPEED_10GB { + t.Logf("Speed is needed to start port assignment on port5 as that is "+ + "where 10G ports are in setup %v", *breakoutspeed) + ports = ports[4:] // Assuming ports 5+ are 10G + } + + for i, port := range ports { + + // Remove the subnet mask from the IPv4 address + ip, _, err := net.ParseCIDR(ateIpv4Subnets[i]) + ateIpAddress := ip.String() + + if err != nil { + t.Fatalf("Invalid IP address: %v", err) + } + + gwIp, _, err := net.ParseCIDR(Dutipv4Subnets[i]) + dutIpAddress := gwIp.String() + + if err != nil { + t.Fatalf("Invalid IP address: %v", err) + } + t.Logf("Port Name: %s", port.Name()) + t.Logf("Port ID: %s", port.ID()) + + t.Logf("ATE IPv4 Add is : %v and port is %v", ateIpAddress, port.ID()) + t.Logf("ATE IPv4 GW is DUT IP of : %v and port is %v", dutIpAddress, port.ID()) + + // Add the port to the topology + topPort := top.Ports().Add().SetName(ate.Port(t, port.ID()).ID()) + + // Add a device for each port and set the Ethernet details + i1 := top.Devices().Add().SetName(ate.Port(t, port.ID()).ID()) + macAddress := fmt.Sprintf("02:00:01:0%v:01:01", i+1) + eth1 := i1.Ethernets().Add().SetName(port.ID() + ".Eth").SetMac(macAddress) + + // Set the Ethernet connection to the appropriate port + eth1.Connection().SetPortName(topPort.Name()) + + // Configure the IPv4 address for this interface + eth1.Ipv4Addresses().Add().SetName(port.ID() + ateIpAddress). + SetAddress(ateIpAddress).SetGateway(dutIpAddress). + SetPrefix(uint32(24)) // Assuming /24 subnet + + // Exit loop when we've reached the number of breakout ports + if i == numbreakouts-1 { + break + } + } + + // Show the OTG Config + t.Log("Complete configuration:", top.String()) + ate.OTG().PushConfig(t, top) + time.Sleep(time.Second * 30) + ate.OTG().StartProtocols(t) + + return top +} + +func TestPlatformBreakoutConfig(t *testing.T) { + dut := ondatra.DUT(t, "dut") + var Dutipv4Subnets []string + var Ateipv4Subnets []string + + cases := []struct { + numbreakouts uint8 + breakoutspeed oc.E_IfEthernet_ETHERNET_SPEED + portPrefix string + dutIntfIP string + ateIntfIp string + }{ + { + numbreakouts: 4, + breakoutspeed: oc.IfEthernet_ETHERNET_SPEED_SPEED_100GB, + portPrefix: "HundredGigE", + dutIntfIP: dutPort1.IPv4, + ateIntfIp: atePort1.IPv4, + }, + { + portPrefix: "HundredGigE", + numbreakouts: 2, + breakoutspeed: oc.IfEthernet_ETHERNET_SPEED_SPEED_100GB, + dutIntfIP: dutPort1.IPv4, + ateIntfIp: atePort1.IPv4, + }, + { + numbreakouts: 4, + breakoutspeed: oc.IfEthernet_ETHERNET_SPEED_SPEED_10GB, + portPrefix: "TenGigE", + dutIntfIP: dutPort2.IPv4, + ateIntfIp: atePort2.IPv4, + }, + } + + gnoiClient := dut.RawAPIs().GNOI(t) + ate := ondatra.ATE(t, "ate") + + for _, tc := range cases { + tc := tc // Capture range variable + t.Run(fmt.Sprintf("Starting case for %d X %v", tc.numbreakouts, tc.breakoutspeed), func(t *testing.T) { + + if dut.Vendor() == ondatra.CISCO { + breakOutCompName, fullInterfaceName, foundComp = getCompName(dut, dutPort1.IPv4, tc.portPrefix, t) + t.Logf("breakOutCompName is: %s fullInterfaceName is %s: "+ + "fullInterfaceName and foundComp is %v", breakOutCompName, fullInterfaceName, foundComp) + componentNameList = []string{breakOutCompName} + } else { + t.Fatalf("Unsupported vendor %s. Need to add breakout component names.", dut.Vendor()) + } + + for _, componentName := range componentNameList { + t.Logf("Starting Test for %s %v", componentName, tc) + configContainer := &oc.Component_Port_BreakoutMode_Group{ + Index: ygot.Uint8(0), + NumBreakouts: ygot.Uint8(tc.numbreakouts), + BreakoutSpeed: oc.E_IfEthernet_ETHERNET_SPEED(tc.breakoutspeed), + } + groupContainer := &oc.Component_Port_BreakoutMode{Group: map[uint8]*oc.Component_Port_BreakoutMode_Group{1: configContainer}} + breakoutContainer := &oc.Component_Port{BreakoutMode: groupContainer} + portContainer := &oc.Component{Port: breakoutContainer, Name: ygot.String(componentName)} + + if deviations.VerifyExpectedBreakoutSupportedConfig(dut) { + // deviation is the output "show controllers phy breakout interface" this command returns the following output + // this will tell us if a given optic supports the attempted breakout config before applying it + // leading to false positive failures + // + // DUT#show controllers optics 0/0/0/30 breakout-details + // Optics Port : Optics0_0_0_30 + // No:of Breakouts : 2 + // Physical Channels per intf : 2 + // Interface Speed : 100G + t.Logf("sending fullInterfaceName to func %s", fullInterfaceName) + if !isBreakoutSupported(t, dut, fullInterfaceName, tc.numbreakouts, tc.breakoutspeed) { + t.Skipf("Skipping test case %dx%s: Configuration not supported", + tc.numbreakouts, getSpeedValue(tc.breakoutspeed)) + return + } + } + + // Apply configuration + gnmi.Update(t, dut, gnmi.OC().Component(componentName).Name().Config(), componentName) + gnmi.Delete(t, dut, gnmi.OC().Component(componentName).Port().BreakoutMode().Group(schemaValue).Config()) + path := gnmi.OC().Component(componentName).Port().BreakoutMode().Group(schemaValue) + gnmi.Replace(t, dut, path.Config(), configContainer) + + t.Run(fmt.Sprintf("Subscribe//component[%v]/config/port/breakout-mode/group[%v]", + componentName, schemaValue), func(t *testing.T) { + state := gnmi.OC().Component(componentName).Port().BreakoutMode().Group(schemaValue) + groupDetails := gnmi.Get(t, dut, state.Config()) + index := *groupDetails.Index + numBreakouts := *groupDetails.NumBreakouts + breakoutSpeed := groupDetails.BreakoutSpeed + verifyBreakout(index, tc.numbreakouts, numBreakouts, tc.breakoutspeed.String(), + breakoutSpeed.String(), t) + }) + + t.Run(fmt.Sprintf("Configure DUT Interfaces with IPv4 For %v %v", + tc.numbreakouts, tc.breakoutspeed), func(t *testing.T) { + t.Logf("Start DUT interface Config.") + + breakOutPorts, err := findNewPortNames(dut, t, dutPortName, tc.numbreakouts) + if err != nil { + t.Fatal(err) + } + + if dut.Vendor() == ondatra.CISCO { + sortBreakoutPorts(breakOutPorts) + } + + Dutipv4Subnets, err = IncrementIPNetwork(tc.dutIntfIP, tc.numbreakouts, true, 1) + if err != nil { + t.Fatalf("Failed to generate IPv4 subnet addresses for DUT: %v", err) + } + + Ateipv4Subnets, err = IncrementIPNetwork(tc.ateIntfIp, tc.numbreakouts, true, 2) + if err != nil { + t.Fatalf("Failed to generate IPv4 subnet addresses for ATE: %v", err) + } + + for idx, portName := range breakOutPorts { + ipv4Address := strings.Split(Dutipv4Subnets[idx], "/")[0] + t.Logf("Configuring port %s with IPv4 address %s", portName, ipv4Address) + + i := &oc.Interface{ + Name: ygot.String(portName), + Description: ygot.String("Configured by GNMI"), + Type: oc.IETFInterfaces_InterfaceType_ethernetCsmacd, + Enabled: ygot.Bool(true), + } + + s := i.GetOrCreateSubinterface(0) + s4 := s.GetOrCreateIpv4() + a := s4.GetOrCreateAddress(ipv4Address) + a.PrefixLength = ygot.Uint8(dutPort1.IPv4Len) + + gnmi.Update(t, dut, gnmi.OC().Interface(portName).Config(), i) + } + + t.Log("Configuring the ATE") + configureOTG(t, ate, &tc.breakoutspeed, Ateipv4Subnets, Dutipv4Subnets, + int(tc.numbreakouts)) + }) + + t.Run(fmt.Sprintf("Ping ATE from DUT via Breakout Interface %v %v", + tc.numbreakouts, tc.breakoutspeed), func(t *testing.T) { + for _, dutAddrs := range Ateipv4Subnets { + ip, _, err := net.ParseCIDR(dutAddrs) + if err != nil { + t.Fatalf("Invalid IP address: %v", err) + } + dutAddrs = ip.String() + + pingRequest := &spb.PingRequest{ + Destination: dutAddrs, + L3Protocol: tpb.L3Protocol_IPV4, + } + + t.Logf("Starting Ping to Destination %v", dutAddrs) + + var responses []*spb.PingResponse + var pingClient spb.System_PingClient + + for attempt := 1; attempt <= maxPingRetries; attempt++ { + t.Logf("Ping attempt %d to %s", attempt, dutAddrs) + pingClient, err = gnoiClient.System().Ping(context.Background(), pingRequest) + if err != nil { + t.Errorf("Failed to query gnoi endpoint on attempt %d: %v", attempt, err) + time.Sleep(2 * time.Second) + continue + } + + responses, err = fetchResponses(pingClient) + if err != nil { + t.Errorf("Failed to handle gnoi ping client stream on attempt %d: %v", + attempt, err) + time.Sleep(2 * time.Second) + continue + } + + if len(responses) > 0 { + t.Logf("Got ping responses on attempt %d: Items: %v, Content: %v", + attempt, len(responses), responses) + break + } + + t.Logf("No responses received on attempt %d, retrying...", attempt) + time.Sleep(2 * time.Second) + } + + if len(responses) == 0 { + t.Fatalf("Failed to get any ping responses to %v after %d attempts", + pingRequest.Destination, maxPingRetries) + } + + if responses[3].Source != dutAddrs { + t.Errorf("Did not get a ping response from ATE source Interface %s", + responses[3].Source) + } else { + t.Logf("Got a successful reply from ATE Source Interface: %s", + responses[3].Source) + } + } + }) + + t.Run(fmt.Sprintf("Replace//component[%v]/config/port/ %v*%v", + componentName, tc.numbreakouts, tc.breakoutspeed), func(t *testing.T) { + path := gnmi.OC().Component(componentName) + gnmi.Replace(t, dut, path.Config(), portContainer) + }) + + t.Run(fmt.Sprintf("Delete//component[%v]/config/port/breakout-mode/group[1]/config", + componentName), func(t *testing.T) { + path := gnmi.OC().Component(componentName).Port().BreakoutMode().Group(schemaValue) + gnmi.Delete(t, dut, path.Config()) + verifyDelete(t, dut, componentName, schemaValue) + }) + } + }) + } +} diff --git a/feature/platform/tests/breakout_configuration/metadata.textproto b/feature/platform/tests/breakout_configuration/metadata.textproto new file mode 100644 index 00000000000..89299f5ae57 --- /dev/null +++ b/feature/platform/tests/breakout_configuration/metadata.textproto @@ -0,0 +1,15 @@ +# proto-file: github.com/openconfig/featureprofiles/proto/metadata.proto +# proto-message: Metadata +plan_id: "PLT-1.1" +uuid: "6ac4eed0-9e04-46f5-85d8-ca88ee5fec7d" +description: "Interface breakout Test" +testbed: TESTBED_DUT_ATE_8LINKS +platform_exceptions: { + platform: { + vendor: CISCO + } + deviations: { + verify_expected_breakout_supported_config: true + + } +} \ No newline at end of file diff --git a/internal/deviations/deviations.go b/internal/deviations/deviations.go index 9b77880799a..960edb8555c 100644 --- a/internal/deviations/deviations.go +++ b/internal/deviations/deviations.go @@ -1292,3 +1292,8 @@ func DefaultBgpInstanceName(dut *ondatra.DUTDevice) string { } return "DEFAULT" } + +// VerifyExpectedBreakoutSupportedConfig is to skip checking for breakout config mode. +func VerifyExpectedBreakoutSupportedConfig(dut *ondatra.DUTDevice) bool { + return lookupDUTDeviations(dut).GetVerifyExpectedBreakoutSupportedConfig() +} diff --git a/proto/metadata.proto b/proto/metadata.proto index 620d7444381..dff5ff81636 100644 --- a/proto/metadata.proto +++ b/proto/metadata.proto @@ -639,7 +639,7 @@ message Metadata { // EnableMultipathUnderAfiSafi returns true for devices that do not support multipath under /global path and instead support under global/afi/safi path // CISCO: b/376241033 // CISCO: b/340859662 - bool enable_multipath_under_afi_safi = 230; + bool enable_multipath_under_afi_safi = 230; // Device have different default value for allow own as. // Juniper : b/373559004 bool bgp_allowownas_diff_default_value = 231; @@ -683,6 +683,9 @@ message Metadata { // default bgp instance name is used to set bgp instance name value other than DEFAULT string default_bgp_instance_name = 246; + // verify_expected_breakout_supported_config is used to verify on Cisco devices if optic supports a given breakout mode + // Cisco: + bool verify_expected_breakout_supported_config = 247; // Reserved field numbers and identifiers. reserved 84, 9, 28, 20, 90, 97, 55, 89, 19, 36, 35, 40, 173; } diff --git a/proto/metadata_go_proto/metadata.pb.go b/proto/metadata_go_proto/metadata.pb.go index a0ad5801fd4..a33efed9cf4 100644 --- a/proto/metadata_go_proto/metadata.pb.go +++ b/proto/metadata_go_proto/metadata.pb.go @@ -14,8 +14,8 @@ // Code generated by protoc-gen-go. DO NOT EDIT. // versions: -// protoc-gen-go v1.31.0 -// protoc v4.25.1 +// protoc-gen-go v1.35.1 +// protoc v5.28.3 // source: metadata.proto package metadata_go_proto @@ -186,11 +186,9 @@ type Metadata struct { func (x *Metadata) Reset() { *x = Metadata{} - if protoimpl.UnsafeEnabled { - mi := &file_metadata_proto_msgTypes[0] - ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) - ms.StoreMessageInfo(mi) - } + mi := &file_metadata_proto_msgTypes[0] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) } func (x *Metadata) String() string { @@ -201,7 +199,7 @@ func (*Metadata) ProtoMessage() {} func (x *Metadata) ProtoReflect() protoreflect.Message { mi := &file_metadata_proto_msgTypes[0] - if protoimpl.UnsafeEnabled && x != nil { + if x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { ms.StoreMessageInfo(mi) @@ -282,11 +280,9 @@ type Metadata_Platform struct { func (x *Metadata_Platform) Reset() { *x = Metadata_Platform{} - if protoimpl.UnsafeEnabled { - mi := &file_metadata_proto_msgTypes[1] - ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) - ms.StoreMessageInfo(mi) - } + mi := &file_metadata_proto_msgTypes[1] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) } func (x *Metadata_Platform) String() string { @@ -297,7 +293,7 @@ func (*Metadata_Platform) ProtoMessage() {} func (x *Metadata_Platform) ProtoReflect() protoreflect.Message { mi := &file_metadata_proto_msgTypes[1] - if protoimpl.UnsafeEnabled && x != nil { + if x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { ms.StoreMessageInfo(mi) @@ -949,25 +945,31 @@ type Metadata_Deviations struct { // Juniper: b/358534837 // Devices that do not support setting med value using union type in OC. BgpSetMedV7Unsupported bool `protobuf:"varint,241,opt,name=bgp_set_med_v7_unsupported,json=bgpSetMedV7Unsupported,proto3" json:"bgp_set_med_v7_unsupported,omitempty"` + // Cisco: b/388980373 // default import policy for table connection unsupported is set to true for devices that do not support default import policy. TcDefaultImportPolicyUnsupported bool `protobuf:"varint,242,opt,name=tc_default_import_policy_unsupported,json=tcDefaultImportPolicyUnsupported,proto3" json:"tc_default_import_policy_unsupported,omitempty"` + // Cisco: b/388955361 // table connection metric propagation unsupported is set to true for devices that do not support metric propagation. TcMetricPropagationUnsupported bool `protobuf:"varint,243,opt,name=tc_metric_propagation_unsupported,json=tcMetricPropagationUnsupported,proto3" json:"tc_metric_propagation_unsupported,omitempty"` + // Cisco: b/388980376 // table connection attribute propagation unsupported is set to true for devices that do not support attribute propagation. TcAttributePropagationUnsupported bool `protobuf:"varint,244,opt,name=tc_attribute_propagation_unsupported,json=tcAttributePropagationUnsupported,proto3" json:"tc_attribute_propagation_unsupported,omitempty"` + // Cisco: b/388955364 // table connection subscription unsupported is set to true for devices that do not support subscription for table connection leaves. TcSubscriptionUnsupported bool `protobuf:"varint,245,opt,name=tc_subscription_unsupported,json=tcSubscriptionUnsupported,proto3" json:"tc_subscription_unsupported,omitempty"` + // Cisco: b/388983709 // default bgp instance name is used to set bgp instance name value other than DEFAULT DefaultBgpInstanceName string `protobuf:"bytes,246,opt,name=default_bgp_instance_name,json=defaultBgpInstanceName,proto3" json:"default_bgp_instance_name,omitempty"` + // verify_expected_breakout_supported_config is used to verify on Cisco devices if optic supports a given breakout mode + // Cisco: + VerifyExpectedBreakoutSupportedConfig bool `protobuf:"varint,247,opt,name=verify_expected_breakout_supported_config,json=verifyExpectedBreakoutSupportedConfig,proto3" json:"verify_expected_breakout_supported_config,omitempty"` } func (x *Metadata_Deviations) Reset() { *x = Metadata_Deviations{} - if protoimpl.UnsafeEnabled { - mi := &file_metadata_proto_msgTypes[2] - ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) - ms.StoreMessageInfo(mi) - } + mi := &file_metadata_proto_msgTypes[2] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) } func (x *Metadata_Deviations) String() string { @@ -978,7 +980,7 @@ func (*Metadata_Deviations) ProtoMessage() {} func (x *Metadata_Deviations) ProtoReflect() protoreflect.Message { mi := &file_metadata_proto_msgTypes[2] - if protoimpl.UnsafeEnabled && x != nil { + if x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { ms.StoreMessageInfo(mi) @@ -2568,6 +2570,13 @@ func (x *Metadata_Deviations) GetDefaultBgpInstanceName() string { return "" } +func (x *Metadata_Deviations) GetVerifyExpectedBreakoutSupportedConfig() bool { + if x != nil { + return x.VerifyExpectedBreakoutSupportedConfig + } + return false +} + type Metadata_PlatformExceptions struct { state protoimpl.MessageState sizeCache protoimpl.SizeCache @@ -2579,11 +2588,9 @@ type Metadata_PlatformExceptions struct { func (x *Metadata_PlatformExceptions) Reset() { *x = Metadata_PlatformExceptions{} - if protoimpl.UnsafeEnabled { - mi := &file_metadata_proto_msgTypes[3] - ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) - ms.StoreMessageInfo(mi) - } + mi := &file_metadata_proto_msgTypes[3] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) } func (x *Metadata_PlatformExceptions) String() string { @@ -2594,7 +2601,7 @@ func (*Metadata_PlatformExceptions) ProtoMessage() {} func (x *Metadata_PlatformExceptions) ProtoReflect() protoreflect.Message { mi := &file_metadata_proto_msgTypes[3] - if protoimpl.UnsafeEnabled && x != nil { + if x != nil { ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) if ms.LoadMessageInfo() == nil { ms.StoreMessageInfo(mi) @@ -2631,7 +2638,7 @@ var file_metadata_proto_rawDesc = []byte{ 0x74, 0x69, 0x6e, 0x67, 0x1a, 0x31, 0x67, 0x69, 0x74, 0x68, 0x75, 0x62, 0x2e, 0x63, 0x6f, 0x6d, 0x2f, 0x6f, 0x70, 0x65, 0x6e, 0x63, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x2f, 0x6f, 0x6e, 0x64, 0x61, 0x74, 0x72, 0x61, 0x2f, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2f, 0x74, 0x65, 0x73, 0x74, 0x62, 0x65, - 0x64, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x22, 0x87, 0x8b, 0x01, 0x0a, 0x08, 0x4d, 0x65, 0x74, + 0x64, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x22, 0xe2, 0x8b, 0x01, 0x0a, 0x08, 0x4d, 0x65, 0x74, 0x61, 0x64, 0x61, 0x74, 0x61, 0x12, 0x12, 0x0a, 0x04, 0x75, 0x75, 0x69, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x04, 0x75, 0x75, 0x69, 0x64, 0x12, 0x17, 0x0a, 0x07, 0x70, 0x6c, 0x61, 0x6e, 0x5f, 0x69, 0x64, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x06, 0x70, 0x6c, 0x61, 0x6e, @@ -2665,7 +2672,7 @@ var file_metadata_proto_rawDesc = []byte{ 0x65, 0x67, 0x65, 0x78, 0x18, 0x04, 0x20, 0x01, 0x28, 0x09, 0x52, 0x14, 0x73, 0x6f, 0x66, 0x74, 0x77, 0x61, 0x72, 0x65, 0x56, 0x65, 0x72, 0x73, 0x69, 0x6f, 0x6e, 0x52, 0x65, 0x67, 0x65, 0x78, 0x4a, 0x04, 0x08, 0x02, 0x10, 0x03, 0x52, 0x0e, 0x68, 0x61, 0x72, 0x64, 0x77, 0x61, 0x72, 0x65, - 0x5f, 0x6d, 0x6f, 0x64, 0x65, 0x6c, 0x1a, 0xd9, 0x82, 0x01, 0x0a, 0x0a, 0x44, 0x65, 0x76, 0x69, + 0x5f, 0x6d, 0x6f, 0x64, 0x65, 0x6c, 0x1a, 0xb4, 0x83, 0x01, 0x0a, 0x0a, 0x44, 0x65, 0x76, 0x69, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x73, 0x12, 0x30, 0x0a, 0x14, 0x69, 0x70, 0x76, 0x34, 0x5f, 0x6d, 0x69, 0x73, 0x73, 0x69, 0x6e, 0x67, 0x5f, 0x65, 0x6e, 0x61, 0x62, 0x6c, 0x65, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x08, 0x52, 0x12, 0x69, 0x70, 0x76, 0x34, 0x4d, 0x69, 0x73, 0x73, 0x69, 0x6e, @@ -3706,45 +3713,51 @@ var file_metadata_proto_rawDesc = []byte{ 0x6c, 0x74, 0x5f, 0x62, 0x67, 0x70, 0x5f, 0x69, 0x6e, 0x73, 0x74, 0x61, 0x6e, 0x63, 0x65, 0x5f, 0x6e, 0x61, 0x6d, 0x65, 0x18, 0xf6, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x16, 0x64, 0x65, 0x66, 0x61, 0x75, 0x6c, 0x74, 0x42, 0x67, 0x70, 0x49, 0x6e, 0x73, 0x74, 0x61, 0x6e, 0x63, 0x65, 0x4e, - 0x61, 0x6d, 0x65, 0x4a, 0x04, 0x08, 0x54, 0x10, 0x55, 0x4a, 0x04, 0x08, 0x09, 0x10, 0x0a, 0x4a, - 0x04, 0x08, 0x1c, 0x10, 0x1d, 0x4a, 0x04, 0x08, 0x14, 0x10, 0x15, 0x4a, 0x04, 0x08, 0x5a, 0x10, - 0x5b, 0x4a, 0x04, 0x08, 0x61, 0x10, 0x62, 0x4a, 0x04, 0x08, 0x37, 0x10, 0x38, 0x4a, 0x04, 0x08, - 0x59, 0x10, 0x5a, 0x4a, 0x04, 0x08, 0x13, 0x10, 0x14, 0x4a, 0x04, 0x08, 0x24, 0x10, 0x25, 0x4a, - 0x04, 0x08, 0x23, 0x10, 0x24, 0x4a, 0x04, 0x08, 0x28, 0x10, 0x29, 0x4a, 0x06, 0x08, 0xad, 0x01, - 0x10, 0xae, 0x01, 0x1a, 0xa0, 0x01, 0x0a, 0x12, 0x50, 0x6c, 0x61, 0x74, 0x66, 0x6f, 0x72, 0x6d, - 0x45, 0x78, 0x63, 0x65, 0x70, 0x74, 0x69, 0x6f, 0x6e, 0x73, 0x12, 0x41, 0x0a, 0x08, 0x70, 0x6c, - 0x61, 0x74, 0x66, 0x6f, 0x72, 0x6d, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x25, 0x2e, 0x6f, + 0x61, 0x6d, 0x65, 0x12, 0x59, 0x0a, 0x29, 0x76, 0x65, 0x72, 0x69, 0x66, 0x79, 0x5f, 0x65, 0x78, + 0x70, 0x65, 0x63, 0x74, 0x65, 0x64, 0x5f, 0x62, 0x72, 0x65, 0x61, 0x6b, 0x6f, 0x75, 0x74, 0x5f, + 0x73, 0x75, 0x70, 0x70, 0x6f, 0x72, 0x74, 0x65, 0x64, 0x5f, 0x63, 0x6f, 0x6e, 0x66, 0x69, 0x67, + 0x18, 0xf7, 0x01, 0x20, 0x01, 0x28, 0x08, 0x52, 0x25, 0x76, 0x65, 0x72, 0x69, 0x66, 0x79, 0x45, + 0x78, 0x70, 0x65, 0x63, 0x74, 0x65, 0x64, 0x42, 0x72, 0x65, 0x61, 0x6b, 0x6f, 0x75, 0x74, 0x53, + 0x75, 0x70, 0x70, 0x6f, 0x72, 0x74, 0x65, 0x64, 0x43, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x4a, 0x04, + 0x08, 0x54, 0x10, 0x55, 0x4a, 0x04, 0x08, 0x09, 0x10, 0x0a, 0x4a, 0x04, 0x08, 0x1c, 0x10, 0x1d, + 0x4a, 0x04, 0x08, 0x14, 0x10, 0x15, 0x4a, 0x04, 0x08, 0x5a, 0x10, 0x5b, 0x4a, 0x04, 0x08, 0x61, + 0x10, 0x62, 0x4a, 0x04, 0x08, 0x37, 0x10, 0x38, 0x4a, 0x04, 0x08, 0x59, 0x10, 0x5a, 0x4a, 0x04, + 0x08, 0x13, 0x10, 0x14, 0x4a, 0x04, 0x08, 0x24, 0x10, 0x25, 0x4a, 0x04, 0x08, 0x23, 0x10, 0x24, + 0x4a, 0x04, 0x08, 0x28, 0x10, 0x29, 0x4a, 0x06, 0x08, 0xad, 0x01, 0x10, 0xae, 0x01, 0x1a, 0xa0, + 0x01, 0x0a, 0x12, 0x50, 0x6c, 0x61, 0x74, 0x66, 0x6f, 0x72, 0x6d, 0x45, 0x78, 0x63, 0x65, 0x70, + 0x74, 0x69, 0x6f, 0x6e, 0x73, 0x12, 0x41, 0x0a, 0x08, 0x70, 0x6c, 0x61, 0x74, 0x66, 0x6f, 0x72, + 0x6d, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x25, 0x2e, 0x6f, 0x70, 0x65, 0x6e, 0x63, 0x6f, + 0x6e, 0x66, 0x69, 0x67, 0x2e, 0x74, 0x65, 0x73, 0x74, 0x69, 0x6e, 0x67, 0x2e, 0x4d, 0x65, 0x74, + 0x61, 0x64, 0x61, 0x74, 0x61, 0x2e, 0x50, 0x6c, 0x61, 0x74, 0x66, 0x6f, 0x72, 0x6d, 0x52, 0x08, + 0x70, 0x6c, 0x61, 0x74, 0x66, 0x6f, 0x72, 0x6d, 0x12, 0x47, 0x0a, 0x0a, 0x64, 0x65, 0x76, 0x69, + 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x73, 0x18, 0x02, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x27, 0x2e, 0x6f, 0x70, 0x65, 0x6e, 0x63, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x2e, 0x74, 0x65, 0x73, 0x74, 0x69, 0x6e, - 0x67, 0x2e, 0x4d, 0x65, 0x74, 0x61, 0x64, 0x61, 0x74, 0x61, 0x2e, 0x50, 0x6c, 0x61, 0x74, 0x66, - 0x6f, 0x72, 0x6d, 0x52, 0x08, 0x70, 0x6c, 0x61, 0x74, 0x66, 0x6f, 0x72, 0x6d, 0x12, 0x47, 0x0a, - 0x0a, 0x64, 0x65, 0x76, 0x69, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x73, 0x18, 0x02, 0x20, 0x01, 0x28, - 0x0b, 0x32, 0x27, 0x2e, 0x6f, 0x70, 0x65, 0x6e, 0x63, 0x6f, 0x6e, 0x66, 0x69, 0x67, 0x2e, 0x74, - 0x65, 0x73, 0x74, 0x69, 0x6e, 0x67, 0x2e, 0x4d, 0x65, 0x74, 0x61, 0x64, 0x61, 0x74, 0x61, 0x2e, - 0x44, 0x65, 0x76, 0x69, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x73, 0x52, 0x0a, 0x64, 0x65, 0x76, 0x69, - 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x73, 0x22, 0xfa, 0x01, 0x0a, 0x07, 0x54, 0x65, 0x73, 0x74, 0x62, - 0x65, 0x64, 0x12, 0x17, 0x0a, 0x13, 0x54, 0x45, 0x53, 0x54, 0x42, 0x45, 0x44, 0x5f, 0x55, 0x4e, - 0x53, 0x50, 0x45, 0x43, 0x49, 0x46, 0x49, 0x45, 0x44, 0x10, 0x00, 0x12, 0x0f, 0x0a, 0x0b, 0x54, - 0x45, 0x53, 0x54, 0x42, 0x45, 0x44, 0x5f, 0x44, 0x55, 0x54, 0x10, 0x01, 0x12, 0x1a, 0x0a, 0x16, - 0x54, 0x45, 0x53, 0x54, 0x42, 0x45, 0x44, 0x5f, 0x44, 0x55, 0x54, 0x5f, 0x44, 0x55, 0x54, 0x5f, - 0x34, 0x4c, 0x49, 0x4e, 0x4b, 0x53, 0x10, 0x02, 0x12, 0x1a, 0x0a, 0x16, 0x54, 0x45, 0x53, 0x54, - 0x42, 0x45, 0x44, 0x5f, 0x44, 0x55, 0x54, 0x5f, 0x41, 0x54, 0x45, 0x5f, 0x32, 0x4c, 0x49, 0x4e, - 0x4b, 0x53, 0x10, 0x03, 0x12, 0x1a, 0x0a, 0x16, 0x54, 0x45, 0x53, 0x54, 0x42, 0x45, 0x44, 0x5f, - 0x44, 0x55, 0x54, 0x5f, 0x41, 0x54, 0x45, 0x5f, 0x34, 0x4c, 0x49, 0x4e, 0x4b, 0x53, 0x10, 0x04, - 0x12, 0x1e, 0x0a, 0x1a, 0x54, 0x45, 0x53, 0x54, 0x42, 0x45, 0x44, 0x5f, 0x44, 0x55, 0x54, 0x5f, - 0x41, 0x54, 0x45, 0x5f, 0x39, 0x4c, 0x49, 0x4e, 0x4b, 0x53, 0x5f, 0x4c, 0x41, 0x47, 0x10, 0x05, - 0x12, 0x1e, 0x0a, 0x1a, 0x54, 0x45, 0x53, 0x54, 0x42, 0x45, 0x44, 0x5f, 0x44, 0x55, 0x54, 0x5f, - 0x44, 0x55, 0x54, 0x5f, 0x41, 0x54, 0x45, 0x5f, 0x32, 0x4c, 0x49, 0x4e, 0x4b, 0x53, 0x10, 0x06, - 0x12, 0x1a, 0x0a, 0x16, 0x54, 0x45, 0x53, 0x54, 0x42, 0x45, 0x44, 0x5f, 0x44, 0x55, 0x54, 0x5f, - 0x41, 0x54, 0x45, 0x5f, 0x38, 0x4c, 0x49, 0x4e, 0x4b, 0x53, 0x10, 0x07, 0x12, 0x15, 0x0a, 0x11, - 0x54, 0x45, 0x53, 0x54, 0x42, 0x45, 0x44, 0x5f, 0x44, 0x55, 0x54, 0x5f, 0x34, 0x30, 0x30, 0x5a, - 0x52, 0x10, 0x08, 0x22, 0x6d, 0x0a, 0x04, 0x54, 0x61, 0x67, 0x73, 0x12, 0x14, 0x0a, 0x10, 0x54, - 0x41, 0x47, 0x53, 0x5f, 0x55, 0x4e, 0x53, 0x50, 0x45, 0x43, 0x49, 0x46, 0x49, 0x45, 0x44, 0x10, - 0x00, 0x12, 0x14, 0x0a, 0x10, 0x54, 0x41, 0x47, 0x53, 0x5f, 0x41, 0x47, 0x47, 0x52, 0x45, 0x47, - 0x41, 0x54, 0x49, 0x4f, 0x4e, 0x10, 0x01, 0x12, 0x18, 0x0a, 0x14, 0x54, 0x41, 0x47, 0x53, 0x5f, - 0x44, 0x41, 0x54, 0x41, 0x43, 0x45, 0x4e, 0x54, 0x45, 0x52, 0x5f, 0x45, 0x44, 0x47, 0x45, 0x10, - 0x02, 0x12, 0x0d, 0x0a, 0x09, 0x54, 0x41, 0x47, 0x53, 0x5f, 0x45, 0x44, 0x47, 0x45, 0x10, 0x03, - 0x12, 0x10, 0x0a, 0x0c, 0x54, 0x41, 0x47, 0x53, 0x5f, 0x54, 0x52, 0x41, 0x4e, 0x53, 0x49, 0x54, - 0x10, 0x04, 0x62, 0x06, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x33, + 0x67, 0x2e, 0x4d, 0x65, 0x74, 0x61, 0x64, 0x61, 0x74, 0x61, 0x2e, 0x44, 0x65, 0x76, 0x69, 0x61, + 0x74, 0x69, 0x6f, 0x6e, 0x73, 0x52, 0x0a, 0x64, 0x65, 0x76, 0x69, 0x61, 0x74, 0x69, 0x6f, 0x6e, + 0x73, 0x22, 0xfa, 0x01, 0x0a, 0x07, 0x54, 0x65, 0x73, 0x74, 0x62, 0x65, 0x64, 0x12, 0x17, 0x0a, + 0x13, 0x54, 0x45, 0x53, 0x54, 0x42, 0x45, 0x44, 0x5f, 0x55, 0x4e, 0x53, 0x50, 0x45, 0x43, 0x49, + 0x46, 0x49, 0x45, 0x44, 0x10, 0x00, 0x12, 0x0f, 0x0a, 0x0b, 0x54, 0x45, 0x53, 0x54, 0x42, 0x45, + 0x44, 0x5f, 0x44, 0x55, 0x54, 0x10, 0x01, 0x12, 0x1a, 0x0a, 0x16, 0x54, 0x45, 0x53, 0x54, 0x42, + 0x45, 0x44, 0x5f, 0x44, 0x55, 0x54, 0x5f, 0x44, 0x55, 0x54, 0x5f, 0x34, 0x4c, 0x49, 0x4e, 0x4b, + 0x53, 0x10, 0x02, 0x12, 0x1a, 0x0a, 0x16, 0x54, 0x45, 0x53, 0x54, 0x42, 0x45, 0x44, 0x5f, 0x44, + 0x55, 0x54, 0x5f, 0x41, 0x54, 0x45, 0x5f, 0x32, 0x4c, 0x49, 0x4e, 0x4b, 0x53, 0x10, 0x03, 0x12, + 0x1a, 0x0a, 0x16, 0x54, 0x45, 0x53, 0x54, 0x42, 0x45, 0x44, 0x5f, 0x44, 0x55, 0x54, 0x5f, 0x41, + 0x54, 0x45, 0x5f, 0x34, 0x4c, 0x49, 0x4e, 0x4b, 0x53, 0x10, 0x04, 0x12, 0x1e, 0x0a, 0x1a, 0x54, + 0x45, 0x53, 0x54, 0x42, 0x45, 0x44, 0x5f, 0x44, 0x55, 0x54, 0x5f, 0x41, 0x54, 0x45, 0x5f, 0x39, + 0x4c, 0x49, 0x4e, 0x4b, 0x53, 0x5f, 0x4c, 0x41, 0x47, 0x10, 0x05, 0x12, 0x1e, 0x0a, 0x1a, 0x54, + 0x45, 0x53, 0x54, 0x42, 0x45, 0x44, 0x5f, 0x44, 0x55, 0x54, 0x5f, 0x44, 0x55, 0x54, 0x5f, 0x41, + 0x54, 0x45, 0x5f, 0x32, 0x4c, 0x49, 0x4e, 0x4b, 0x53, 0x10, 0x06, 0x12, 0x1a, 0x0a, 0x16, 0x54, + 0x45, 0x53, 0x54, 0x42, 0x45, 0x44, 0x5f, 0x44, 0x55, 0x54, 0x5f, 0x41, 0x54, 0x45, 0x5f, 0x38, + 0x4c, 0x49, 0x4e, 0x4b, 0x53, 0x10, 0x07, 0x12, 0x15, 0x0a, 0x11, 0x54, 0x45, 0x53, 0x54, 0x42, + 0x45, 0x44, 0x5f, 0x44, 0x55, 0x54, 0x5f, 0x34, 0x30, 0x30, 0x5a, 0x52, 0x10, 0x08, 0x22, 0x6d, + 0x0a, 0x04, 0x54, 0x61, 0x67, 0x73, 0x12, 0x14, 0x0a, 0x10, 0x54, 0x41, 0x47, 0x53, 0x5f, 0x55, + 0x4e, 0x53, 0x50, 0x45, 0x43, 0x49, 0x46, 0x49, 0x45, 0x44, 0x10, 0x00, 0x12, 0x14, 0x0a, 0x10, + 0x54, 0x41, 0x47, 0x53, 0x5f, 0x41, 0x47, 0x47, 0x52, 0x45, 0x47, 0x41, 0x54, 0x49, 0x4f, 0x4e, + 0x10, 0x01, 0x12, 0x18, 0x0a, 0x14, 0x54, 0x41, 0x47, 0x53, 0x5f, 0x44, 0x41, 0x54, 0x41, 0x43, + 0x45, 0x4e, 0x54, 0x45, 0x52, 0x5f, 0x45, 0x44, 0x47, 0x45, 0x10, 0x02, 0x12, 0x0d, 0x0a, 0x09, + 0x54, 0x41, 0x47, 0x53, 0x5f, 0x45, 0x44, 0x47, 0x45, 0x10, 0x03, 0x12, 0x10, 0x0a, 0x0c, 0x54, + 0x41, 0x47, 0x53, 0x5f, 0x54, 0x52, 0x41, 0x4e, 0x53, 0x49, 0x54, 0x10, 0x04, 0x62, 0x06, 0x70, + 0x72, 0x6f, 0x74, 0x6f, 0x33, } var ( @@ -3761,7 +3774,7 @@ func file_metadata_proto_rawDescGZIP() []byte { var file_metadata_proto_enumTypes = make([]protoimpl.EnumInfo, 2) var file_metadata_proto_msgTypes = make([]protoimpl.MessageInfo, 4) -var file_metadata_proto_goTypes = []interface{}{ +var file_metadata_proto_goTypes = []any{ (Metadata_Testbed)(0), // 0: openconfig.testing.Metadata.Testbed (Metadata_Tags)(0), // 1: openconfig.testing.Metadata.Tags (*Metadata)(nil), // 2: openconfig.testing.Metadata @@ -3789,56 +3802,6 @@ func file_metadata_proto_init() { if File_metadata_proto != nil { return } - if !protoimpl.UnsafeEnabled { - file_metadata_proto_msgTypes[0].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*Metadata); i { - case 0: - return &v.state - case 1: - return &v.sizeCache - case 2: - return &v.unknownFields - default: - return nil - } - } - file_metadata_proto_msgTypes[1].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*Metadata_Platform); i { - case 0: - return &v.state - case 1: - return &v.sizeCache - case 2: - return &v.unknownFields - default: - return nil - } - } - file_metadata_proto_msgTypes[2].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*Metadata_Deviations); i { - case 0: - return &v.state - case 1: - return &v.sizeCache - case 2: - return &v.unknownFields - default: - return nil - } - } - file_metadata_proto_msgTypes[3].Exporter = func(v interface{}, i int) interface{} { - switch v := v.(*Metadata_PlatformExceptions); i { - case 0: - return &v.state - case 1: - return &v.sizeCache - case 2: - return &v.unknownFields - default: - return nil - } - } - } type x struct{} out := protoimpl.TypeBuilder{ File: protoimpl.DescBuilder{