Skip to content

Commit

Permalink
connectivity: Add checks for drops due to missed tail calls
Browse files Browse the repository at this point in the history
The test case is protected with --include-upgrade-test, as it's only
relevant in the context of Cilium upgrades.

Signed-off-by: Martynas Pumputis <[email protected]>
  • Loading branch information
brb authored and michi-covalent committed Jun 21, 2023
1 parent 5fd9092 commit 4a6cb76
Show file tree
Hide file tree
Showing 2 changed files with 46 additions and 0 deletions.
2 changes: 2 additions & 0 deletions connectivity/suite.go
Original file line number Diff line number Diff line change
Expand Up @@ -217,6 +217,8 @@ func Run(ctx context.Context, ct *check.ConnectivityTest, addExtraTests func(*ch
// include --include-upgrade-tests"
return ct.Run(ctx)
}

ct.NewTest("no-missed-tail-calls").WithScenarios(tests.NoMissedTailCalls())
}

// Run all tests without any policies in place.
Expand Down
44 changes: 44 additions & 0 deletions connectivity/tests/errors.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,12 @@ package tests

import (
"context"
"strconv"
"strings"
"time"

"github.com/cilium/cilium-cli/connectivity/check"
"github.com/cilium/cilium-cli/defaults"
)

// NoErrorsInLogs checks whether there are no error messages in cilium-agent
Expand Down Expand Up @@ -39,6 +41,48 @@ func (n *noErrorsInLogs) Run(ctx context.Context, t *check.Test) {

}

// NoMissedTailCalls checks whether there were no drops due to missed (BPF)
// tail calls.
func NoMissedTailCalls() check.Scenario {
return &noMissedTailCalls{}
}

type noMissedTailCalls struct{}

func (n *noMissedTailCalls) Name() string {
return "no-missed-tail-calls"
}

func (n *noMissedTailCalls) Run(ctx context.Context, t *check.Test) {
ct := t.Context()
cmd := []string{
"/bin/sh", "-c",
"cilium metrics list -o json | jq '.[] | select( .name == \"cilium_drop_count_total\" and .labels.reason == \"Missed tail call\" ).value'",
}

for _, pod := range ct.CiliumPods() {
pod := pod
stdout, err := pod.K8sClient.ExecInPod(ctx, pod.Pod.Namespace, pod.Pod.Name, defaults.AgentContainerName, cmd)
if err != nil {
t.Fatalf("Error fetching missed tail call drop counts: %s", err)
}
countStr := stdout.String()
if countStr == "" {
return
}

count, err := strconv.Atoi(countStr)
if err != nil {
t.Fatalf("Failed to convert missed tail call drops %q to int: %s", countStr, err)
}

if count != 0 {
t.Fatalf("Detected drops due to missed tail calls: %d", count)
}
}

}

func checkErrorsInLogs(logs string, t *check.Test) {
uniqueFailures := make(map[string]int)
for _, msg := range strings.Split(logs, "\n") {
Expand Down

0 comments on commit 4a6cb76

Please sign in to comment.