Skip to content

Commit

Permalink
end-to-end test for cleaning up apiservices after CSV delete
Browse files Browse the repository at this point in the history
  • Loading branch information
alecmerdler authored and Jeff Peeler committed Mar 19, 2019
1 parent 8e104a1 commit 7b1dd07
Showing 1 changed file with 26 additions and 2 deletions.
28 changes: 26 additions & 2 deletions test/e2e/csv_e2e_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import (
"fmt"
"strings"
"testing"
"time"

"github.com/stretchr/testify/require"
appsv1 "k8s.io/api/apps/v1"
Expand All @@ -18,6 +19,7 @@ import (
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/runtime"
"k8s.io/apimachinery/pkg/util/wait"
"k8s.io/apimachinery/pkg/watch"

"github.com/operator-framework/operator-lifecycle-manager/pkg/api/apis/operators/v1alpha1"
"github.com/operator-framework/operator-lifecycle-manager/pkg/api/apis/operators/v1alpha2"
Expand Down Expand Up @@ -1218,9 +1220,31 @@ func TestCreateCSVWithOwnedAPIService(t *testing.T) {
csv.SetName(depName)

// Create the APIService CSV
cleanupCSV, err := createCSV(t, c, crc, csv, testNamespace, false, true)
cleanupCSV, err := createCSV(t, c, crc, csv, testNamespace, false, false)
require.NoError(t, err)
defer cleanupCSV()
defer func() {
watcher, err := c.ApiregistrationV1Interface().ApiregistrationV1().APIServices().Watch(metav1.ListOptions{FieldSelector: "metadata.name=" + apiServiceName})
require.NoError(t, err)

deleted := make(chan struct{})
go func() {
events := watcher.ResultChan()
for {
select {
case evt := <-events:
if evt.Type == watch.Deleted {
deleted <- struct{}{}
return
}
case <-time.After(pollDuration):
require.FailNow(t, "apiservice not cleaned up after CSV deleted")
}
}
}()

cleanupCSV()
<-deleted
}()

fetchedCSV, err := fetchCSV(t, crc, csv.Name, testNamespace, csvSucceededChecker)
require.NoError(t, err)
Expand Down

0 comments on commit 7b1dd07

Please sign in to comment.