mirror of
https://github.com/woodpecker-ci/woodpecker.git
synced 2024-11-26 11:51:02 +00:00
fix: backend auto-detection should be consistent (#1618)
Closes https://github.com/woodpecker-ci/woodpecker/issues/1617 The `woodpecker exec` auto-detects the backend by iterating over a map of backends. However, since Go 1 the runtime randomizes map iteration order, so a random backend might be chosen during each execution. PR changes to auto-detection to iterate over the backends list with predefined priority: `docker`, `local`, `ssh`, `kubernetes`. --------- Signed-off-by: Alexander Matyushentsev <AMatyushentsev@gmail.com>
This commit is contained in:
parent
5e1171d7a7
commit
ee969979c6
1 changed files with 9 additions and 6 deletions
|
@ -11,19 +11,22 @@ import (
|
|||
"github.com/woodpecker-ci/woodpecker/pipeline/backend/types"
|
||||
)
|
||||
|
||||
var engines map[string]types.Engine
|
||||
var (
|
||||
enginesByName map[string]types.Engine
|
||||
engines []types.Engine
|
||||
)
|
||||
|
||||
func Init(ctx context.Context) {
|
||||
loadedEngines := []types.Engine{
|
||||
engines = []types.Engine{
|
||||
docker.New(),
|
||||
local.New(),
|
||||
ssh.New(),
|
||||
kubernetes.New(ctx),
|
||||
}
|
||||
|
||||
engines = make(map[string]types.Engine)
|
||||
for _, engine := range loadedEngines {
|
||||
engines[engine.Name()] = engine
|
||||
enginesByName = make(map[string]types.Engine)
|
||||
for _, engine := range engines {
|
||||
enginesByName[engine.Name()] = engine
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -38,7 +41,7 @@ func FindEngine(engineName string) (types.Engine, error) {
|
|||
return nil, fmt.Errorf("Can't detect an available backend engine")
|
||||
}
|
||||
|
||||
engine, ok := engines[engineName]
|
||||
engine, ok := enginesByName[engineName]
|
||||
if !ok {
|
||||
return nil, fmt.Errorf("Backend engine '%s' not found", engineName)
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue