158 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			158 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Go
		
	
	
	
package e2e
 | 
						|
 | 
						|
import (
 | 
						|
	"context"
 | 
						|
	"encoding/json"
 | 
						|
	"fmt"
 | 
						|
	"io/ioutil"
 | 
						|
	"os"
 | 
						|
	"testing"
 | 
						|
 | 
						|
	virtuslabv1alpha1 "github.com/VirtusLab/jenkins-operator/pkg/apis/virtuslab/v1alpha1"
 | 
						|
	"github.com/VirtusLab/jenkins-operator/pkg/controller/jenkins/configuration/base/resources"
 | 
						|
	"github.com/VirtusLab/jenkins-operator/pkg/controller/jenkins/constants"
 | 
						|
 | 
						|
	"github.com/aws/aws-sdk-go/aws"
 | 
						|
	"github.com/aws/aws-sdk-go/aws/credentials"
 | 
						|
	"github.com/aws/aws-sdk-go/aws/session"
 | 
						|
	"github.com/aws/aws-sdk-go/service/s3"
 | 
						|
	"github.com/bndr/gojenkins"
 | 
						|
	framework "github.com/operator-framework/operator-sdk/pkg/test"
 | 
						|
	assert "github.com/stretchr/testify/require"
 | 
						|
	corev1 "k8s.io/api/core/v1"
 | 
						|
	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
 | 
						|
)
 | 
						|
 | 
						|
type amazonS3BackupConfiguration struct {
 | 
						|
	BucketName string `json:"bucketName,omitempty"`
 | 
						|
	BucketPath string `json:"bucketPath,omitempty"`
 | 
						|
	Region     string `json:"region,omitempty"`
 | 
						|
	AccessKey  string `json:"accessKey,omitempty"`
 | 
						|
	SecretKey  string `json:"secretKey,omitempty"`
 | 
						|
}
 | 
						|
 | 
						|
func TestAmazonS3Backup(t *testing.T) {
 | 
						|
	t.Parallel()
 | 
						|
	if amazonS3BackupConfigurationFile == nil || len(*amazonS3BackupConfigurationFile) == 0 {
 | 
						|
		t.Skipf("Skipping testing because flag '%s' is not set", amazonS3BackupConfigurationParameterName)
 | 
						|
	}
 | 
						|
	backupConfig := loadAmazonS3BackupConfig(t)
 | 
						|
 | 
						|
	s3Client := createS3Client(t, backupConfig)
 | 
						|
	deleteAllBackupsInS3(t, backupConfig, s3Client)
 | 
						|
	namespace, ctx := setupTest(t)
 | 
						|
	defer ctx.Cleanup() // Deletes test namespace
 | 
						|
 | 
						|
	jenkins := createJenkinsCRWithAmazonS3Backup(t, namespace, backupConfig)
 | 
						|
	waitForJenkinsBaseConfigurationToComplete(t, jenkins)
 | 
						|
	waitForJenkinsUserConfigurationToComplete(t, jenkins)
 | 
						|
 | 
						|
	restartJenkinsMasterPod(t, jenkins)
 | 
						|
	waitForRecreateJenkinsMasterPod(t, jenkins)
 | 
						|
 | 
						|
	waitForJenkinsBaseConfigurationToComplete(t, jenkins)
 | 
						|
	waitForJenkinsUserConfigurationToComplete(t, jenkins)
 | 
						|
	jenkinsClient := verifyJenkinsAPIConnection(t, jenkins)
 | 
						|
	verifyIfBackupAndRestoreWasSuccessfull(t, jenkinsClient, backupConfig, s3Client)
 | 
						|
}
 | 
						|
 | 
						|
func createS3Client(t *testing.T, backupConfig amazonS3BackupConfiguration) *s3.S3 {
 | 
						|
	sess, err := session.NewSession(&aws.Config{
 | 
						|
		Region:      aws.String(backupConfig.Region),
 | 
						|
		Credentials: credentials.NewStaticCredentials(backupConfig.AccessKey, backupConfig.SecretKey, ""),
 | 
						|
	})
 | 
						|
	assert.NoError(t, err)
 | 
						|
 | 
						|
	return s3.New(sess)
 | 
						|
}
 | 
						|
 | 
						|
func deleteAllBackupsInS3(t *testing.T, backupConfig amazonS3BackupConfiguration, s3Client *s3.S3) {
 | 
						|
	input := &s3.DeleteObjectInput{
 | 
						|
		Bucket: aws.String(backupConfig.BucketName),
 | 
						|
		Key:    aws.String(backupConfig.BucketPath),
 | 
						|
	}
 | 
						|
 | 
						|
	_, err := s3Client.DeleteObject(input)
 | 
						|
	assert.NoError(t, err)
 | 
						|
}
 | 
						|
 | 
						|
func verifyIfBackupAndRestoreWasSuccessfull(t *testing.T, jenkinsClient *gojenkins.Jenkins, backupConfig amazonS3BackupConfiguration, s3Client *s3.S3) {
 | 
						|
	job, err := jenkinsClient.GetJob(constants.UserConfigurationJobName)
 | 
						|
	assert.NoError(t, err)
 | 
						|
	// jenkins runs twice(2) + 1 as next build number
 | 
						|
	assert.Equal(t, int64(3), job.Raw.NextBuildNumber)
 | 
						|
 | 
						|
	listObjects, err := s3Client.ListObjects(&s3.ListObjectsInput{
 | 
						|
		Bucket: aws.String(backupConfig.BucketName),
 | 
						|
		Marker: aws.String(backupConfig.BucketPath),
 | 
						|
	})
 | 
						|
	assert.NoError(t, err)
 | 
						|
	t.Logf("Backups in S3:%+v", listObjects.Contents)
 | 
						|
	assert.Equal(t, len(listObjects.Contents), 2)
 | 
						|
	latestBackupFound := false
 | 
						|
	for _, backup := range listObjects.Contents {
 | 
						|
		if *backup.Key == fmt.Sprintf("%s/%s", backupConfig.BucketPath, constants.BackupLatestFileName) {
 | 
						|
			latestBackupFound = true
 | 
						|
		}
 | 
						|
	}
 | 
						|
	assert.True(t, latestBackupFound)
 | 
						|
}
 | 
						|
 | 
						|
func createJenkinsCRWithAmazonS3Backup(t *testing.T, namespace string, backupConfig amazonS3BackupConfiguration) *virtuslabv1alpha1.Jenkins {
 | 
						|
	jenkins := &virtuslabv1alpha1.Jenkins{
 | 
						|
		ObjectMeta: metav1.ObjectMeta{
 | 
						|
			Name:      "e2e",
 | 
						|
			Namespace: namespace,
 | 
						|
		},
 | 
						|
		Spec: virtuslabv1alpha1.JenkinsSpec{
 | 
						|
			Backup: virtuslabv1alpha1.JenkinsBackupTypeAmazonS3,
 | 
						|
			BackupAmazonS3: virtuslabv1alpha1.JenkinsBackupAmazonS3{
 | 
						|
				Region:     backupConfig.Region,
 | 
						|
				BucketPath: backupConfig.BucketPath,
 | 
						|
				BucketName: backupConfig.BucketName,
 | 
						|
			},
 | 
						|
			Master: virtuslabv1alpha1.JenkinsMaster{
 | 
						|
				Image: "jenkins/jenkins",
 | 
						|
			},
 | 
						|
		},
 | 
						|
	}
 | 
						|
 | 
						|
	t.Logf("Jenkins CR %+v", *jenkins)
 | 
						|
	err := framework.Global.Client.Create(context.TODO(), jenkins, nil)
 | 
						|
	assert.NoError(t, err)
 | 
						|
 | 
						|
	backupCredentialsSecret := &corev1.Secret{
 | 
						|
		ObjectMeta: metav1.ObjectMeta{
 | 
						|
			Name:      resources.GetBackupCredentialsSecretName(jenkins),
 | 
						|
			Namespace: namespace,
 | 
						|
		},
 | 
						|
		Data: map[string][]byte{
 | 
						|
			constants.BackupAmazonS3SecretAccessKey: []byte(backupConfig.AccessKey),
 | 
						|
			constants.BackupAmazonS3SecretSecretKey: []byte(backupConfig.SecretKey),
 | 
						|
		},
 | 
						|
	}
 | 
						|
	err = framework.Global.Client.Create(context.TODO(), backupCredentialsSecret, nil)
 | 
						|
	assert.NoError(t, err)
 | 
						|
 | 
						|
	return jenkins
 | 
						|
}
 | 
						|
 | 
						|
func loadAmazonS3BackupConfig(t *testing.T) amazonS3BackupConfiguration {
 | 
						|
	jsonFile, err := os.Open(*amazonS3BackupConfigurationFile)
 | 
						|
	assert.NoError(t, err)
 | 
						|
	defer func() { _ = jsonFile.Close() }()
 | 
						|
 | 
						|
	byteValue, err := ioutil.ReadAll(jsonFile)
 | 
						|
	assert.NoError(t, err)
 | 
						|
 | 
						|
	var result amazonS3BackupConfiguration
 | 
						|
	err = json.Unmarshal([]byte(byteValue), &result)
 | 
						|
	assert.NoError(t, err)
 | 
						|
	assert.NotEmpty(t, result.AccessKey)
 | 
						|
	assert.NotEmpty(t, result.BucketName)
 | 
						|
	assert.NotEmpty(t, result.Region)
 | 
						|
	assert.NotEmpty(t, result.SecretKey)
 | 
						|
	result.BucketPath = t.Name()
 | 
						|
	return result
 | 
						|
}
 |