diff --git a/pkg/apiserver/certificate/selfsignedcert_provider.go b/pkg/apiserver/certificate/selfsignedcert_provider.go index 2ed9ccb53f9..4a42e58a10c 100644 --- a/pkg/apiserver/certificate/selfsignedcert_provider.go +++ b/pkg/apiserver/certificate/selfsignedcert_provider.go @@ -317,9 +317,11 @@ func (p *selfSignedCertProvider) saveCertKeyToSecret(secret *corev1.Secret, cert if bytes.Equal(cert, secret.Data[corev1.TLSCertKey]) && bytes.Equal(key, secret.Data[corev1.TLSPrivateKeyKey]) { return nil } - secret.Type = corev1.SecretTypeTLS + // Do not update the existing Secret's type. Otherwise, the update would fail if it's not of type + // "kubernetes.io/tls" as the type field is immutable. secret.Data[corev1.TLSCertKey] = cert secret.Data[corev1.TLSPrivateKeyKey] = key + klog.InfoS("Updating Secret to persist self-signed cert", "secret", klog.KObj(secret)) _, err := p.client.CoreV1().Secrets(p.secretNamespace).Update(context.TODO(), secret, metav1.UpdateOptions{}) return err } @@ -331,6 +333,7 @@ func (p *selfSignedCertProvider) saveCertKeyToSecret(secret *corev1.Secret, cert corev1.TLSPrivateKeyKey: key, }, } + klog.InfoS("Creating Secret to persist self-signed cert", "secret", klog.KObj(secret)) _, err := p.client.CoreV1().Secrets(p.secretNamespace).Create(context.TODO(), caSecret, metav1.CreateOptions{}) return err } diff --git a/pkg/apiserver/certificate/selfsignedcert_provider_test.go b/pkg/apiserver/certificate/selfsignedcert_provider_test.go index ea72911ff3b..916f31dd82a 100644 --- a/pkg/apiserver/certificate/selfsignedcert_provider_test.go +++ b/pkg/apiserver/certificate/selfsignedcert_provider_test.go @@ -168,6 +168,12 @@ func TestSelfSignedCertProviderRotate(t *testing.T) { }, 5*time.Second, 100*time.Millisecond) } +func copyAndMutateSecret(secret *corev1.Secret, mutator func(_ *corev1.Secret)) *corev1.Secret { + s := secret.DeepCopy() + mutator(s) + return s +} + func TestSelfSignedCertProviderRun(t *testing.T) { t.Setenv(env.PodNamespaceEnvKey, testSecretNamespace) testSecret := &corev1.Secret{ @@ -224,6 +230,19 @@ func TestSelfSignedCertProviderRun(t *testing.T) { expectedCert: testOneYearCert2, expectedKey: testOneYearKey2, }, + { + name: "should not update secret type when secret is opaque", + tlsSecretName: testSecretName, + existingSecret: copyAndMutateSecret(testSecret, func(s *corev1.Secret) { + s.Type = corev1.SecretTypeOpaque + }), + expectedSecret: copyAndMutateSecret(testSecret2, func(s *corev1.Secret) { + s.Type = corev1.SecretTypeOpaque + }), + minValidDuration: time.Hour * 24 * 370, + expectedCert: testOneYearCert2, + expectedKey: testOneYearKey2, + }, { name: "should generate TLS and update secret when secret is empty", tlsSecretName: testSecretName,