forked from crossplane-contrib/function-auto-ready
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfn_test.go
117 lines (108 loc) · 3.1 KB
/
fn_test.go
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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
package main
import (
"context"
"testing"
"github.com/google/go-cmp/cmp"
"github.com/google/go-cmp/cmp/cmpopts"
"google.golang.org/protobuf/testing/protocmp"
"google.golang.org/protobuf/types/known/durationpb"
"github.com/crossplane/function-sdk-go/logging"
fnv1 "github.com/crossplane/function-sdk-go/proto/v1"
"github.com/crossplane/function-sdk-go/resource"
"github.com/crossplane/function-sdk-go/response"
)
func TestRunFunction(t *testing.T) {
type args struct {
ctx context.Context
req *fnv1.RunFunctionRequest
}
type want struct {
rsp *fnv1.RunFunctionResponse
err error
}
cases := map[string]struct {
reason string
args args
want want
}{
"AutoDetectReadiness": {
reason: "An existing composed resource with unspecified readiness and a Ready: True status condition should be detected as ready",
args: args{
req: &fnv1.RunFunctionRequest{
Meta: &fnv1.RequestMeta{Tag: "hello"},
Observed: &fnv1.State{
Composite: &fnv1.Resource{
Resource: resource.MustStructJSON(`{
"apiVersion": "test.crossplane.io/v1",
"kind": "TestXR",
"metadata": {
"name": "my-test-xr"
}
}`),
},
Resources: map[string]*fnv1.Resource{
"ready-composed-resource": {
Resource: resource.MustStructJSON(`{
"apiVersion": "test.crossplane.io/v1",
"kind": "TestComposed",
"metadata": {
"name": "my-test-composed"
},
"spec": {},
"status": {
"conditions": [
{
"type": "Ready",
"status": "True"
}
]
}
}`),
},
},
},
Desired: &fnv1.State{
Resources: map[string]*fnv1.Resource{
// This function doesn't care about the desired
// resource schema. In practice it would match
// observed (without status), but for this test it
// doesn't matter.
"ready-composed-resource": {
Resource: resource.MustStructJSON(`{}`),
},
},
},
},
},
want: want{
rsp: &fnv1.RunFunctionResponse{
Meta: &fnv1.ResponseMeta{Tag: "hello", Ttl: durationpb.New(response.DefaultTTL)},
Desired: &fnv1.State{
Resources: map[string]*fnv1.Resource{
// This function doesn't care about the desired
// resource schema. In practice it would match
// observed (without status), but for this test it
// doesn't matter.
"ready-composed-resource": {
Resource: resource.MustStructJSON(`{}`),
Ready: fnv1.Ready_READY_TRUE,
},
},
},
},
},
},
}
for name, tc := range cases {
t.Run(name, func(t *testing.T) {
f := &Function{log: logging.NewNopLogger()}
rsp, err := f.RunFunction(tc.args.ctx, tc.args.req)
if diff := cmp.Diff(tc.want.rsp, rsp, protocmp.Transform()); diff != "" {
t.Errorf("%s\nf.RunFunction(...): -want rsp, +got rsp:\n%s", tc.reason, diff)
}
if diff := cmp.Diff(tc.want.err, err, cmpopts.EquateErrors()); diff != "" {
t.Errorf("%s\nf.RunFunction(...): -want err, +got err:\n%s", tc.reason, diff)
}
})
}
}