mirror of
https://github.com/kubevirt/containerized-data-importer.git
synced 2025-06-03 06:30:22 +00:00

* Adapt DataImportCron and DataSource to DV GC Signed-off-by: Arnon Gilboa <agilboa@redhat.com> * Add DIC test for GC Signed-off-by: Arnon Gilboa <agilboa@redhat.com> * CR fixes Signed-off-by: Arnon Gilboa <agilboa@redhat.com> Signed-off-by: Arnon Gilboa <agilboa@redhat.com>
129 lines
4.2 KiB
Go
129 lines
4.2 KiB
Go
/*
|
|
Copyright 2022 The CDI 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.
|
|
*/
|
|
|
|
package controller
|
|
|
|
import (
|
|
"context"
|
|
|
|
. "github.com/onsi/ginkgo"
|
|
. "github.com/onsi/gomega"
|
|
|
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
|
"k8s.io/apimachinery/pkg/runtime"
|
|
"k8s.io/apimachinery/pkg/types"
|
|
"k8s.io/client-go/kubernetes/scheme"
|
|
cdiv1 "kubevirt.io/containerized-data-importer-api/pkg/apis/core/v1beta1"
|
|
"sigs.k8s.io/controller-runtime/pkg/client/fake"
|
|
"sigs.k8s.io/controller-runtime/pkg/reconcile"
|
|
)
|
|
|
|
const (
|
|
dsName = "test-datasource"
|
|
pvcName = "test-pvc"
|
|
)
|
|
|
|
var _ = Describe("All DataSource Tests", func() {
|
|
var _ = Describe("DataSource controller reconcile loop", func() {
|
|
var (
|
|
reconciler *DataSourceReconciler
|
|
ds *cdiv1.DataSource
|
|
dsKey = types.NamespacedName{Name: dsName, Namespace: metav1.NamespaceDefault}
|
|
dsReq = reconcile.Request{NamespacedName: dsKey}
|
|
)
|
|
|
|
// verifyConditions reconciles, gets DataSource, and verifies its status conditions
|
|
var verifyConditions = func(step string, isReady bool, reasonReady string) {
|
|
By(step)
|
|
_, err := reconciler.Reconcile(context.TODO(), dsReq)
|
|
Expect(err).ToNot(HaveOccurred())
|
|
err = reconciler.client.Get(context.TODO(), dsKey, ds)
|
|
Expect(err).ToNot(HaveOccurred())
|
|
dsCond := FindDataSourceConditionByType(ds, cdiv1.DataSourceReady)
|
|
Expect(dsCond).ToNot(BeNil())
|
|
verifyConditionState(string(cdiv1.DataSourceReady), dsCond.ConditionState, isReady, reasonReady)
|
|
}
|
|
|
|
It("Should do nothing and return nil when no DataSource exists", func() {
|
|
reconciler = createDataSourceReconciler()
|
|
_, err := reconciler.Reconcile(context.TODO(), dsReq)
|
|
Expect(err).ToNot(HaveOccurred())
|
|
})
|
|
|
|
It("Should update Ready condition when DataSource has no source pvc", func() {
|
|
ds = createDataSource()
|
|
reconciler = createDataSourceReconciler(ds)
|
|
verifyConditions("No source pvc", false, noPvc)
|
|
})
|
|
|
|
It("Should update Ready condition when DataSource has source pvc", func() {
|
|
ds = createDataSource()
|
|
ds.Spec.Source.PVC = &cdiv1.DataVolumeSourcePVC{Namespace: metav1.NamespaceDefault, Name: pvcName}
|
|
reconciler = createDataSourceReconciler(ds)
|
|
verifyConditions("Source DV does not exist", false, notFound)
|
|
|
|
dv := newImportDataVolume(pvcName)
|
|
err := reconciler.client.Create(context.TODO(), dv)
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
dv.Status.Phase = cdiv1.ImportInProgress
|
|
err = reconciler.client.Update(context.TODO(), dv)
|
|
Expect(err).ToNot(HaveOccurred())
|
|
verifyConditions("Source DV ImportInProgress", false, string(dv.Status.Phase))
|
|
|
|
dv.Status.Phase = cdiv1.Succeeded
|
|
err = reconciler.client.Update(context.TODO(), dv)
|
|
Expect(err).ToNot(HaveOccurred())
|
|
verifyConditions("Source DV Succeeded", true, ready)
|
|
|
|
err = reconciler.client.Delete(context.TODO(), dv)
|
|
Expect(err).ToNot(HaveOccurred())
|
|
verifyConditions("Source DV Deleted", false, notFound)
|
|
|
|
pvc := createPvc(pvcName, metav1.NamespaceDefault, nil, nil)
|
|
err = reconciler.client.Create(context.TODO(), pvc)
|
|
Expect(err).ToNot(HaveOccurred())
|
|
verifyConditions("Source PVC exists, but no DV", true, ready)
|
|
|
|
err = reconciler.client.Delete(context.TODO(), pvc)
|
|
Expect(err).ToNot(HaveOccurred())
|
|
verifyConditions("Source PVC Deleted", false, notFound)
|
|
})
|
|
})
|
|
})
|
|
|
|
func createDataSourceReconciler(objects ...runtime.Object) *DataSourceReconciler {
|
|
s := scheme.Scheme
|
|
cdiv1.AddToScheme(s)
|
|
cl := fake.NewFakeClientWithScheme(s, objects...)
|
|
r := &DataSourceReconciler{
|
|
client: cl,
|
|
scheme: s,
|
|
log: cronLog,
|
|
}
|
|
return r
|
|
}
|
|
|
|
func createDataSource() *cdiv1.DataSource {
|
|
return &cdiv1.DataSource{
|
|
TypeMeta: metav1.TypeMeta{APIVersion: cdiv1.SchemeGroupVersion.String()},
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
Name: dsName,
|
|
Namespace: metav1.NamespaceDefault,
|
|
},
|
|
}
|
|
}
|