Skip to content

Commit

Permalink
Add files via upload
Browse files Browse the repository at this point in the history
  • Loading branch information
Adarshkumar14 authored Feb 22, 2022
1 parent 1b333e2 commit 8288bde
Show file tree
Hide file tree
Showing 2 changed files with 135 additions and 0 deletions.
124 changes: 124 additions & 0 deletions versions/upgrade-manager.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,124 @@
package versions

import (
"fmt"
"os"

v2_4_0 "github.com/litmuschaos/litmus/litmus-portal/upgrader-agents/control-plane/versions/v2.4.0"

"github.com/litmuschaos/litmus/litmus-portal/upgrader-agents/control-plane/pkg/database"
"go.mongodb.org/mongo-driver/mongo"
"go.uber.org/zap"
)

// UpgradeExecutor holds the details regarding the version and IVersionManager for a particular version
type UpgradeExecutor struct {
NextVersion string
VersionManager IVersionManager
}

// UpgradeManager provides the functionality required to upgrade from the PreviousVersion to the TargetVersion
type UpgradeManager struct {
Logger *zap.Logger
DBClient *mongo.Client
PreviousVersion string
TargetVersion string
}

// NewUpgradeManager creates an instance of a upgrade manager with the proper configurations
func NewUpgradeManager(logger *zap.Logger, dbClient *mongo.Client) (*UpgradeManager, error) {
currentVersion := os.Getenv("VERSION")
if currentVersion == "" {
return nil, fmt.Errorf("current version env data missing")
}
config, err := database.GetVersion(dbClient)
if err != nil {
return nil, fmt.Errorf("failed to get previous version data from db, error=%w", err)
}
if config.Value == nil || config.Value.(string) == "" {
return nil, fmt.Errorf("failed to get previous version data from db, value=%v", config.Value)
}
if config.Value.(string) == currentVersion {
return nil, fmt.Errorf("previous version and current version are same")
}

return &UpgradeManager{
Logger: logger,
DBClient: dbClient,
PreviousVersion: config.Value.(string),
TargetVersion: currentVersion,
}, nil
}

// getUpgradePath returns a map that determines the possible upgrade path for any upgrade
func (m *UpgradeManager) getUpgradePath() map[string]UpgradeExecutor {
// key : previous version,
// value :{ Version Manger that upgrades the system from priv version to next, NextVersion points to next version in the path}
return map[string]UpgradeExecutor{
"2.3.0": {
NextVersion: "2.4.0",
VersionManager: v2_4_0.NewVersionManger(m.Logger, m.DBClient),
},

"2.4.0": {
NextVersion: "2.5.0",
VersionManager: nil,
},

// latest version no more upgrades available
"2.5.0": {
NextVersion: "",
VersionManager: nil,
},
}
}

// verifyPath verifies whether the current upgrade from PreviousVersion to TargetVersion
// is possible given the configured upgrade path
func (m *UpgradeManager) verifyPath(upgradePath map[string]UpgradeExecutor) error {
if m.PreviousVersion == m.TargetVersion {
return fmt.Errorf("previous version and current version are same")
}

_, okP := upgradePath[m.PreviousVersion]
_, okT := upgradePath[m.TargetVersion]

if !okP && !okT {
return fmt.Errorf("previous version=%v or target version=%v not found in upgrade path", m.PreviousVersion, m.TargetVersion)
}
versionIterator := m.PreviousVersion
for versionIterator != "" {
versionIterator = upgradePath[versionIterator].NextVersion
if versionIterator == m.TargetVersion {
return nil
}
}
return fmt.Errorf("upgrade path not found from previous version=%v to target version=%v", m.PreviousVersion, m.TargetVersion)
}

// Run executes all the steps required in the upgrade path from PreviousVersion to TargetVersion
func (m *UpgradeManager) Run() error {
upgradePath := m.getUpgradePath()

// verify if upgrade possible
if err := m.verifyPath(upgradePath); err != nil {
return err
}

// start upgrade from previous version to target version
versionIterator := m.PreviousVersion
// loop till the target version is reached
for versionIterator != m.TargetVersion {
if err := upgradePath[versionIterator].VersionManager.Run(); err != nil {
return fmt.Errorf("failed to upgrade to version %v, error : %w", versionIterator, err)
}
versionIterator = upgradePath[versionIterator].NextVersion
}

err := database.UpdateVersion(m.DBClient, m.TargetVersion)
if err != nil {
return fmt.Errorf("failed to update version in server config collection, error=%w", err)
}

return nil
}
11 changes: 11 additions & 0 deletions versions/version-manger.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
package versions

// IVersionManager is the interface for the Version Manager,
// a version manager is responsible to upgrade all the control plane components
// from the previous version to the current version,
// this includes any version related metadata stored in DB or configmaps
type IVersionManager interface {
// Run executes all the steps required for the Version Manger
// to upgrade from the previous version to `this` version
Run() error
}

0 comments on commit 8288bde

Please sign in to comment.