mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-23 11:50:44 +00:00
Merge pull request #38574 from k82cn/k8s_38542
Automatic merge from submit-queue Add default imagePullPolicy for initContainers. fixes #38542
This commit is contained in:
commit
cc0b17eaa1
@ -493,6 +493,12 @@ func Convert_v1_PodTemplateSpec_To_api_PodTemplateSpec(in *PodTemplateSpec, out
|
||||
// taking responsibility to ensure mutation of in is not exposed
|
||||
// back to the caller.
|
||||
in.Spec.InitContainers = values
|
||||
|
||||
// Call defaulters explicitly until annotations are removed
|
||||
for i := range in.Spec.InitContainers {
|
||||
c := &in.Spec.InitContainers[i]
|
||||
SetDefaults_Container(c)
|
||||
}
|
||||
}
|
||||
|
||||
if err := autoConvert_v1_PodTemplateSpec_To_api_PodTemplateSpec(in, out, s); err != nil {
|
||||
|
@ -112,7 +112,6 @@ func SetDefaults_Container(obj *Container) {
|
||||
_, tag, _, _ := parsers.ParseImageName(obj.Image)
|
||||
|
||||
// Check image tag
|
||||
|
||||
if tag == "latest" {
|
||||
obj.ImagePullPolicy = PullAlways
|
||||
} else {
|
||||
|
@ -17,6 +17,7 @@ limitations under the License.
|
||||
package v1_test
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"reflect"
|
||||
"testing"
|
||||
|
||||
@ -230,6 +231,72 @@ func TestSetDefaultReplicationControllerReplicas(t *testing.T) {
|
||||
}
|
||||
}
|
||||
|
||||
func TestSetDefaultReplicationControllerImagePullPolicy(t *testing.T) {
|
||||
containersWithoutPullPolicy, _ := json.Marshal([]map[string]interface{}{
|
||||
{
|
||||
"name": "install",
|
||||
"image": "busybox:latest",
|
||||
},
|
||||
})
|
||||
|
||||
containersWithPullPolicy, _ := json.Marshal([]map[string]interface{}{
|
||||
{
|
||||
"name": "install",
|
||||
"imagePullPolicy": "IfNotPresent",
|
||||
},
|
||||
})
|
||||
|
||||
tests := []struct {
|
||||
rc versioned.ReplicationController
|
||||
expectPullPolicy versioned.PullPolicy
|
||||
}{
|
||||
{
|
||||
rc: versioned.ReplicationController{
|
||||
Spec: versioned.ReplicationControllerSpec{
|
||||
Template: &versioned.PodTemplateSpec{
|
||||
ObjectMeta: versioned.ObjectMeta{
|
||||
Annotations: map[string]string{
|
||||
"pod.beta.kubernetes.io/init-containers": string(containersWithoutPullPolicy),
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
expectPullPolicy: versioned.PullAlways,
|
||||
},
|
||||
{
|
||||
rc: versioned.ReplicationController{
|
||||
Spec: versioned.ReplicationControllerSpec{
|
||||
Template: &versioned.PodTemplateSpec{
|
||||
ObjectMeta: versioned.ObjectMeta{
|
||||
Annotations: map[string]string{
|
||||
"pod.beta.kubernetes.io/init-containers": string(containersWithPullPolicy),
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
expectPullPolicy: versioned.PullIfNotPresent,
|
||||
},
|
||||
}
|
||||
|
||||
for _, test := range tests {
|
||||
rc := &test.rc
|
||||
obj2 := roundTrip(t, runtime.Object(rc))
|
||||
rc2, ok := obj2.(*versioned.ReplicationController)
|
||||
if !ok {
|
||||
t.Errorf("unexpected object: %v", rc2)
|
||||
t.FailNow()
|
||||
}
|
||||
if test.expectPullPolicy != rc2.Spec.Template.Spec.InitContainers[0].ImagePullPolicy {
|
||||
t.Errorf("expected ImagePullPolicy: %s, got: %s",
|
||||
test.expectPullPolicy,
|
||||
rc2.Spec.Template.Spec.InitContainers[0].ImagePullPolicy,
|
||||
)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
func TestSetDefaultService(t *testing.T) {
|
||||
svc := &versioned.Service{}
|
||||
obj2 := roundTrip(t, runtime.Object(svc))
|
||||
|
Loading…
Reference in New Issue
Block a user