1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
|
package middleware
import (
"context"
"testing"
)
func TestStackValues(t *testing.T) {
ctx := context.Background()
// Ensure empty stack values don't return something
if v := GetStackValue(ctx, "some key"); v != nil {
t.Fatalf("expect not-existing key to be nil, got %T, %v", v, v)
}
// Add a stack values, ensure not polluting previous context.
ctx2 := WithStackValue(ctx, "some key", "foo")
ctx2 = WithStackValue(ctx2, "some other key", "bar")
if v := GetStackValue(ctx, "some key"); v != nil {
t.Fatalf("expect not-existing key to be nil, got %T, %v", v, v)
}
if v, ok := GetStackValue(ctx2, "some key").(string); !ok || v != "foo" {
t.Fatalf("expect key to be present")
}
if v, ok := GetStackValue(ctx2, "some other key").(string); !ok || v != "bar" {
t.Fatalf("expect key to be present")
}
// Clear the stack values ensure new context doesn't have any stack values.
ctx3 := ClearStackValues(ctx2)
if v, ok := GetStackValue(ctx2, "some key").(string); !ok || v != "foo" {
t.Fatalf("expect key to be present")
}
if v := GetStackValue(ctx3, "some key"); v != nil {
t.Fatalf("expect not-existing key to be nil, got %T, %v", v, v)
}
if v := GetStackValue(ctx3, "some other key"); v != nil {
t.Fatalf("expect not-existing key to be nil, got %T, %v", v, v)
}
}
|