forked from knative/serving
-
Notifications
You must be signed in to change notification settings - Fork 0
/
configuration.go
81 lines (68 loc) · 3.21 KB
/
configuration.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
/*
Copyright 2018 The Knative Authors
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
// configuration.go provides methods to perform actions on the configuration object.
package test
import (
"testing"
"github.com/knative/serving/pkg/apis/serving/v1alpha1"
corev1 "k8s.io/api/core/v1"
"k8s.io/apimachinery/pkg/types"
rtesting "github.com/knative/serving/pkg/reconciler/v1alpha1/testing"
)
// Options are test setup parameters.
type Options struct {
EnvVars []corev1.EnvVar
ContainerPorts []corev1.ContainerPort
ContainerConcurrency int
RevisionTimeoutSeconds int64
ContainerResources corev1.ResourceRequirements
ReadinessProbe *corev1.Probe
SecurityContext *corev1.SecurityContext
}
// CreateConfiguration create a configuration resource in namespace with the name names.Config
// that uses the image specified by names.Image.
func CreateConfiguration(t *testing.T, clients *Clients, names ResourceNames, options *Options, fopt ...rtesting.ConfigOption) (*v1alpha1.Configuration, error) {
config := Configuration(ServingNamespace, names, options, fopt...)
LogResourceObject(t, ResourceObjects{Config: config})
return clients.ServingClient.Configs.Create(config)
}
// PatchConfigImage patches the existing config passed in with a new imagePath. Returns the latest Configuration object
func PatchConfigImage(clients *Clients, cfg *v1alpha1.Configuration, imagePath string) (*v1alpha1.Configuration, error) {
newCfg := cfg.DeepCopy()
newCfg.Spec.RevisionTemplate.Spec.Container.Image = imagePath
patchBytes, err := createPatch(cfg, newCfg)
if err != nil {
return nil, err
}
return clients.ServingClient.Configs.Patch(cfg.ObjectMeta.Name, types.JSONPatchType, patchBytes, "")
}
// WaitForConfigLatestRevision takes a revision in through names and compares it to the current state of LatestCreatedRevisionName in Configuration.
// Once an update is detected in the LatestCreatedRevisionName, the function waits for the created revision to be set in LatestReadyRevisionName
// before returning the name of the revision.
func WaitForConfigLatestRevision(clients *Clients, names ResourceNames) (string, error) {
var revisionName string
err := WaitForConfigurationState(clients.ServingClient, names.Config, func(c *v1alpha1.Configuration) (bool, error) {
if c.Status.LatestCreatedRevisionName != names.Revision {
revisionName = c.Status.LatestCreatedRevisionName
return true, nil
}
return false, nil
}, "ConfigurationUpdatedWithRevision")
if err != nil {
return "", err
}
err = WaitForConfigurationState(clients.ServingClient, names.Config, func(c *v1alpha1.Configuration) (bool, error) {
return (c.Status.LatestReadyRevisionName == revisionName), nil
}, "ConfigurationReadyWithRevision")
return revisionName, err
}