aboutsummaryrefslogtreecommitdiffstats
path: root/vendor/github.com/aws/smithy-go/middleware/stack_values_test.go
blob: 81b7a66289811a4d75988f1ef398e9927369835f (plain) (blame)
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)
	}
}