mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-28 14:07:14 +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
|
// taking responsibility to ensure mutation of in is not exposed
|
||||||
// back to the caller.
|
// back to the caller.
|
||||||
in.Spec.InitContainers = values
|
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 {
|
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)
|
_, tag, _, _ := parsers.ParseImageName(obj.Image)
|
||||||
|
|
||||||
// Check image tag
|
// Check image tag
|
||||||
|
|
||||||
if tag == "latest" {
|
if tag == "latest" {
|
||||||
obj.ImagePullPolicy = PullAlways
|
obj.ImagePullPolicy = PullAlways
|
||||||
} else {
|
} else {
|
||||||
|
@ -17,6 +17,7 @@ limitations under the License.
|
|||||||
package v1_test
|
package v1_test
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"encoding/json"
|
||||||
"reflect"
|
"reflect"
|
||||||
"testing"
|
"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) {
|
func TestSetDefaultService(t *testing.T) {
|
||||||
svc := &versioned.Service{}
|
svc := &versioned.Service{}
|
||||||
obj2 := roundTrip(t, runtime.Object(svc))
|
obj2 := roundTrip(t, runtime.Object(svc))
|
||||||
|
Loading…
Reference in New Issue
Block a user