mirror of https://github.com/hashicorp/consul
mesh: prevent writing a ComputedRoutes with no ported configs (#18833)
parent
edf56ee970
commit
5cde50dee7
|
@ -314,6 +314,14 @@ func compile(
|
|||
computedRoutes.PortedConfigs[port] = mc
|
||||
}
|
||||
|
||||
if len(computedRoutes.PortedConfigs) == 0 {
|
||||
// This service only exposes a "mesh" port, so it cannot be another service's upstream.
|
||||
return &ComputedRoutesResult{
|
||||
ID: computedRoutesID,
|
||||
Data: nil, // returning nil signals a delete is requested
|
||||
}
|
||||
}
|
||||
|
||||
return &ComputedRoutesResult{
|
||||
ID: computedRoutesID,
|
||||
OwnerID: parentServiceID,
|
||||
|
|
|
@ -160,6 +160,24 @@ func TestGenerateComputedRoutes(t *testing.T) {
|
|||
run(t, related, expect, nil)
|
||||
})
|
||||
|
||||
t.Run("aligned service in mesh but no actual ports", func(t *testing.T) {
|
||||
related := loader.NewRelatedResources().
|
||||
AddComputedRoutesIDs(apiComputedRoutesID).
|
||||
AddResources(newService("api", &pbcatalog.Service{
|
||||
Workloads: &pbcatalog.WorkloadSelector{
|
||||
Prefixes: []string{"api-"},
|
||||
},
|
||||
Ports: []*pbcatalog.ServicePort{
|
||||
{TargetPort: "mesh", Protocol: pbcatalog.Protocol_PROTOCOL_MESH},
|
||||
},
|
||||
}))
|
||||
expect := []*ComputedRoutesResult{{
|
||||
ID: apiComputedRoutesID,
|
||||
Data: nil,
|
||||
}}
|
||||
run(t, related, expect, nil)
|
||||
})
|
||||
|
||||
t.Run("tcp service with default route", func(t *testing.T) {
|
||||
apiServiceData := &pbcatalog.Service{
|
||||
Workloads: &pbcatalog.WorkloadSelector{
|
||||
|
|
Loading…
Reference in New Issue