Skip to content

Commit

Permalink
test: cluster getDeployedPackages (#2523)
Browse files Browse the repository at this point in the history
## Description

Adds test for GetDeployedPackage and GetDeployedZarfPackages

## Related Issue

Relates to #2512 

## Checklist before merging

- [ ] Test, docs, adr added or updated as needed
- [ ] [Contributor Guide
Steps](https://github.com/defenseunicorns/zarf/blob/main/.github/CONTRIBUTING.md#developer-workflow)
followed
  • Loading branch information
AustinAbro321 authored May 20, 2024
1 parent 1537260 commit 514e82e
Show file tree
Hide file tree
Showing 4 changed files with 79 additions and 23 deletions.
10 changes: 5 additions & 5 deletions src/cmd/package.go
Original file line number Diff line number Diff line change
Expand Up @@ -133,9 +133,9 @@ var packageListCmd = &cobra.Command{
Short: lang.CmdPackageListShort,
Run: func(cmd *cobra.Command, _ []string) {
ctx := cmd.Context()
deployedZarfPackages, errs := common.NewClusterOrDie(ctx).GetDeployedZarfPackages(ctx)
if len(errs) > 0 && len(deployedZarfPackages) == 0 {
message.Fatalf(errs, lang.CmdPackageListNoPackageWarn)
deployedZarfPackages, err := common.NewClusterOrDie(ctx).GetDeployedZarfPackages(ctx)
if err != nil && len(deployedZarfPackages) == 0 {
message.Fatalf(err, lang.CmdPackageListNoPackageWarn)
}

// Populate a matrix of all the deployed packages
Expand All @@ -157,8 +157,8 @@ var packageListCmd = &cobra.Command{
message.Table(header, packageData)

// Print out any unmarshalling errors
if len(errs) > 0 {
message.Fatalf(errs, lang.CmdPackageListUnmarshalErr)
if err != nil {
message.Fatalf(err, lang.CmdPackageListUnmarshalErr)
}
},
}
Expand Down
4 changes: 2 additions & 2 deletions src/cmd/tools/crane.go
Original file line number Diff line number Diff line change
Expand Up @@ -227,8 +227,8 @@ func pruneImages(cmd *cobra.Command, _ []string) error {
return err
}

zarfPackages, errs := c.GetDeployedZarfPackages(ctx)
if len(errs) > 0 {
zarfPackages, err := c.GetDeployedZarfPackages(ctx)
if err != nil {
return lang.ErrUnableToGetPackages
}

Expand Down
32 changes: 16 additions & 16 deletions src/pkg/cluster/zarf.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ package cluster
import (
"context"
"encoding/json"
"errors"
"fmt"
"strings"
"time"
Expand All @@ -23,31 +24,30 @@ import (
// GetDeployedZarfPackages gets metadata information about packages that have been deployed to the cluster.
// We determine what packages have been deployed to the cluster by looking for specific secrets in the Zarf namespace.
// Returns a list of DeployedPackage structs and a list of errors.
func (c *Cluster) GetDeployedZarfPackages(ctx context.Context) ([]types.DeployedPackage, []error) {
var deployedPackages = []types.DeployedPackage{}
var errorList []error
func (c *Cluster) GetDeployedZarfPackages(ctx context.Context) ([]types.DeployedPackage, error) {
// Get the secrets that describe the deployed packages
secrets, err := c.GetSecretsWithLabel(ctx, ZarfNamespaceName, ZarfPackageInfoLabel)
if err != nil {
return deployedPackages, append(errorList, err)
return nil, err
}

// Process the k8s secret into our internal structs
errs := []error{}
deployedPackages := []types.DeployedPackage{}
for _, secret := range secrets.Items {
if strings.HasPrefix(secret.Name, config.ZarfPackagePrefix) {
var deployedPackage types.DeployedPackage
err := json.Unmarshal(secret.Data["data"], &deployedPackage)
// add the error to the error list
if err != nil {
errorList = append(errorList, fmt.Errorf("unable to unmarshal the secret %s/%s", secret.Namespace, secret.Name))
} else {
deployedPackages = append(deployedPackages, deployedPackage)
}
if !strings.HasPrefix(secret.Name, config.ZarfPackagePrefix) {
continue
}
var deployedPackage types.DeployedPackage
// Process the k8s secret into our internal structs
err := json.Unmarshal(secret.Data["data"], &deployedPackage)
if err != nil {
errs = append(errs, fmt.Errorf("unable to unmarshal the secret %s/%s", secret.Namespace, secret.Name))
continue
}
deployedPackages = append(deployedPackages, deployedPackage)
}

// TODO: If we move this function out of `internal` we should return a more standard singular error.
return deployedPackages, errorList
return deployedPackages, errors.Join(errs...)
}

// GetDeployedPackage gets the metadata information about the package name provided (if it exists in the cluster).
Expand Down
56 changes: 56 additions & 0 deletions src/pkg/cluster/zarf_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,18 @@
package cluster

import (
"context"
"encoding/json"
"strings"
"testing"

"github.com/defenseunicorns/zarf/src/config"
"github.com/defenseunicorns/zarf/src/pkg/k8s"
"github.com/defenseunicorns/zarf/src/types"
"github.com/stretchr/testify/require"
corev1 "k8s.io/api/core/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/client-go/kubernetes/fake"
)

// TestPackageSecretNeedsWait verifies that Zarf waits for webhooks to complete correctly.
Expand Down Expand Up @@ -191,3 +199,51 @@ func TestPackageSecretNeedsWait(t *testing.T) {
})
}
}

func TestGetDeployedPackage(t *testing.T) {
t.Parallel()
ctx := context.Background()
c := &Cluster{&k8s.K8s{Clientset: fake.NewSimpleClientset()}}

packages := []types.DeployedPackage{
{Name: "package1"},
{Name: "package2"},
}

for _, p := range packages {
b, err := json.Marshal(p)
require.NoError(t, err)
data := map[string][]byte{
"data": b,
}
secret := corev1.Secret{
ObjectMeta: metav1.ObjectMeta{
Name: strings.Join([]string{config.ZarfPackagePrefix, p.Name}, ""),
Namespace: "zarf",
Labels: map[string]string{
ZarfPackageInfoLabel: p.Name,
},
},
Data: data,
}
c.Clientset.CoreV1().Secrets("zarf").Create(ctx, &secret, metav1.CreateOptions{})
actual, err := c.GetDeployedPackage(ctx, p.Name)
require.NoError(t, err)
require.Equal(t, p, *actual)
}

nonPackageSecret := corev1.Secret{
ObjectMeta: metav1.ObjectMeta{
Name: "hello-world",
Namespace: "zarf",
Labels: map[string]string{
ZarfPackageInfoLabel: "whatever",
},
},
}
c.Clientset.CoreV1().Secrets("zarf").Create(ctx, &nonPackageSecret, metav1.CreateOptions{})

actualList, err := c.GetDeployedZarfPackages(ctx)
require.NoError(t, err)
require.ElementsMatch(t, packages, actualList)
}

0 comments on commit 514e82e

Please sign in to comment.