mirror of
https://github.com/SAP/jenkins-library.git
synced 2025-01-18 05:18:24 +02:00
dea96a3ba0
* Automates first parts of newmanExecute.groovy Signed-off-by: Fabian Reh <fabian.reh@sap.com> * Adds newman installation Signed-off-by: Fabian Reh <fabian.reh@sap.com> * Removes warning Signed-off-by: Fabian Reh <fabian.reh@sap.com> * makes tests robust for later shell calls Signed-off-by: Fabian Reh <fabian.reh@sap.com> * Adds version logging Signed-off-by: Fabian Reh <fabian.reh@sap.com> * Adds tests for version logging Signed-off-by: Fabian Reh <fabian.reh@sap.com> * Adds newman shell execution Signed-off-by: Fabian Reh <fabian.reh@sap.com> * Prepare cloud foundry apps with secrets handling Signed-off-by: Fabian Reh <fabian.reh@sap.com> * Adds further process to CF Utils Signed-off-by: Fabian Reh <fabian.reh@sap.com> * Fixes unit test Signed-off-by: Fabian Reh <fabian.reh@sap.com> * Adds error category Signed-off-by: Fabian Reh <fabian.reh@sap.com> * Add fix to execute step locally Currently only tested on windows machine locally in powershell. Signed-off-by: Fabian Reh <fabian.reh@sap.com> * Adapt unit test to fix of runCommand Signed-off-by: Fabian Reh <fabian.reh@sap.com> * refactored golang step to newmanExecute * wip * added test config * refactored newmanExecute groovy wrapper step * exclude newmanExecute from common step test * cleaups * add credential support * fix groovy credential providing * add import * add stageName * define script * remove unused vars * add import * fix iterator ref * golang secret handling and cleanups * wip * wip * wip * update go step * implement cf credential proposal * testRepository functionality implemented * register secrets to logger * add missing dependecies * test xsuaa credential handling * wip * wip * cleanups * add import * remove mandatory params * add container definition * test runCommand * test runCommand * fix npm path * fix npm path * wip * wip * wip * wip * wip * wip * wip * wip * wip * wip * wip * wip * added newmanEnvironment to templating * wip * use env and globals params in runCommand when no templating * fix condition * wip * reverted config edit * updated documentation * install with shell * wip * wip * fix tests * refactor tests * wip * remove old test * wip * escape go tmpl * escape go tmpl * fix defaults * add doc comment * remove test case * refactored newman commands * add cli reporter * refactor options * mock os getenv and fix all tests * refactoring and doc update * go generate * small refactor * spelling * fix newman doc * remove MaskPasswords wrapper; fix stash bug; * docu fix Co-authored-by: Fabian Reh <fabian.reh@sap.com>
325 lines
11 KiB
Go
325 lines
11 KiB
Go
package cmd
|
|
|
|
import (
|
|
"path/filepath"
|
|
"strings"
|
|
"testing"
|
|
|
|
sliceUtils "github.com/SAP/jenkins-library/pkg/piperutils"
|
|
"github.com/pkg/errors"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
type executedExecutables struct {
|
|
executable string
|
|
params []string
|
|
}
|
|
|
|
type newmanExecuteMockUtils struct {
|
|
// *mock.ExecMockRunner
|
|
// *mock.FilesMock
|
|
errorOnGlob bool
|
|
errorOnNewmanInstall bool
|
|
errorOnRunShell bool
|
|
errorOnNewmanExecution bool
|
|
errorOnLoggingNode bool
|
|
errorOnLoggingNpm bool
|
|
executedExecutables []executedExecutables
|
|
filesToFind []string
|
|
commandIndex int
|
|
}
|
|
|
|
func newNewmanExecuteMockUtils() newmanExecuteMockUtils {
|
|
return newmanExecuteMockUtils{
|
|
filesToFind: []string{"localFile.json", "localFile2.json"},
|
|
}
|
|
}
|
|
|
|
func TestRunNewmanExecute(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
allFineConfig := newmanExecuteOptions{
|
|
NewmanCollection: "**.json",
|
|
NewmanEnvironment: "env.json",
|
|
NewmanGlobals: "globals.json",
|
|
NewmanInstallCommand: "npm install newman --global --quiet",
|
|
NewmanRunCommand: "run {{.NewmanCollection}} --environment {{.Config.NewmanEnvironment}} --globals {{.Config.NewmanGlobals}} --reporters junit,html --reporter-junit-export target/newman/TEST-{{.CollectionDisplayName}}.xml --reporter-html-export target/newman/TEST-{{.CollectionDisplayName}}.html",
|
|
}
|
|
|
|
t.Run("happy path", func(t *testing.T) {
|
|
t.Parallel()
|
|
// init
|
|
|
|
utils := newNewmanExecuteMockUtils()
|
|
|
|
// test
|
|
err := runNewmanExecute(&allFineConfig, &utils)
|
|
|
|
// assert
|
|
assert.NoError(t, err)
|
|
assert.Contains(t, utils.executedExecutables, executedExecutables{executable: "node", params: []string{"--version"}})
|
|
assert.Contains(t, utils.executedExecutables, executedExecutables{executable: "npm", params: []string{"--version"}})
|
|
assert.Contains(t, utils.executedExecutables, executedExecutables{executable: "npm", params: []string{"install", "newman", "--global", "--quiet", "--prefix=~/.npm-global"}})
|
|
assert.Contains(t, utils.executedExecutables, executedExecutables{executable: "/home/node/.npm-global/bin/newman", params: []string{"run", "localFile.json", "--environment", "env.json", "--globals", "globals.json", "--reporters", "junit,html", "--reporter-junit-export", "target/newman/TEST-localFile.xml", "--reporter-html-export", "target/newman/TEST-localFile.html", "--suppress-exit-code"}})
|
|
assert.Contains(t, utils.executedExecutables, executedExecutables{executable: "/home/node/.npm-global/bin/newman", params: []string{"run", "localFile2.json", "--environment", "env.json", "--globals", "globals.json", "--reporters", "junit,html", "--reporter-junit-export", "target/newman/TEST-localFile2.xml", "--reporter-html-export", "target/newman/TEST-localFile2.html", "--suppress-exit-code"}})
|
|
})
|
|
|
|
t.Run("happy path with fail on error", func(t *testing.T) {
|
|
t.Parallel()
|
|
// init
|
|
|
|
utils := newNewmanExecuteMockUtils()
|
|
fineConfig := allFineConfig
|
|
fineConfig.FailOnError = true
|
|
|
|
// test
|
|
err := runNewmanExecute(&fineConfig, &utils)
|
|
|
|
// assert
|
|
assert.NoError(t, err)
|
|
assert.Contains(t, utils.executedExecutables, executedExecutables{executable: "node", params: []string{"--version"}})
|
|
assert.Contains(t, utils.executedExecutables, executedExecutables{executable: "npm", params: []string{"--version"}})
|
|
assert.Contains(t, utils.executedExecutables, executedExecutables{executable: "npm", params: []string{"install", "newman", "--global", "--quiet", "--prefix=~/.npm-global"}})
|
|
assert.Contains(t, utils.executedExecutables, executedExecutables{executable: "/home/node/.npm-global/bin/newman", params: []string{"run", "localFile.json", "--environment", "env.json", "--globals", "globals.json", "--reporters", "junit,html", "--reporter-junit-export", "target/newman/TEST-localFile.xml", "--reporter-html-export", "target/newman/TEST-localFile.html"}})
|
|
assert.Contains(t, utils.executedExecutables, executedExecutables{executable: "/home/node/.npm-global/bin/newman", params: []string{"run", "localFile2.json", "--environment", "env.json", "--globals", "globals.json", "--reporters", "junit,html", "--reporter-junit-export", "target/newman/TEST-localFile2.xml", "--reporter-html-export", "target/newman/TEST-localFile2.html"}})
|
|
})
|
|
|
|
t.Run("error on newman execution", func(t *testing.T) {
|
|
t.Parallel()
|
|
// init
|
|
|
|
utils := newNewmanExecuteMockUtils()
|
|
utils.errorOnNewmanExecution = true
|
|
|
|
// test
|
|
err := runNewmanExecute(&allFineConfig, &utils)
|
|
|
|
// assert
|
|
assert.EqualError(t, err, "The execution of the newman tests failed, see the log for details.: error on newman execution")
|
|
})
|
|
|
|
t.Run("error on newman installation", func(t *testing.T) {
|
|
t.Parallel()
|
|
// init
|
|
|
|
utils := newNewmanExecuteMockUtils()
|
|
utils.errorOnNewmanInstall = true
|
|
|
|
// test
|
|
err := runNewmanExecute(&allFineConfig, &utils)
|
|
|
|
// assert
|
|
assert.EqualError(t, err, "error installing newman: error on newman install")
|
|
})
|
|
|
|
t.Run("error on npm version logging", func(t *testing.T) {
|
|
t.Parallel()
|
|
// init
|
|
|
|
utils := newNewmanExecuteMockUtils()
|
|
utils.errorOnLoggingNpm = true
|
|
|
|
// test
|
|
err := runNewmanExecute(&allFineConfig, &utils)
|
|
|
|
// assert
|
|
assert.EqualError(t, err, "error logging npm version: error on RunExecutable")
|
|
})
|
|
|
|
t.Run("error on template resolution", func(t *testing.T) {
|
|
t.Parallel()
|
|
// init
|
|
|
|
utils := newNewmanExecuteMockUtils()
|
|
config := allFineConfig
|
|
config.NewmanRunCommand = "this is my erroneous command {{.collectionDisplayName}"
|
|
|
|
// test
|
|
err := runNewmanExecute(&config, &utils)
|
|
|
|
// assert
|
|
assert.EqualError(t, err, "could not parse newman command template: template: template:1: unexpected \"}\" in operand")
|
|
})
|
|
|
|
t.Run("error on file search", func(t *testing.T) {
|
|
t.Parallel()
|
|
// init
|
|
|
|
utils := newNewmanExecuteMockUtils()
|
|
utils.filesToFind = nil
|
|
|
|
// test
|
|
err := runNewmanExecute(&allFineConfig, &utils)
|
|
|
|
// assert
|
|
assert.EqualError(t, err, "no collection found with pattern '**.json'")
|
|
})
|
|
|
|
t.Run("no newman file", func(t *testing.T) {
|
|
t.Parallel()
|
|
// init
|
|
|
|
utils := newNewmanExecuteMockUtils()
|
|
utils.errorOnGlob = true
|
|
|
|
// test
|
|
err := runNewmanExecute(&allFineConfig, &utils)
|
|
|
|
// assert
|
|
assert.EqualError(t, err, "Could not execute global search for '**.json': error on Glob")
|
|
})
|
|
}
|
|
|
|
func TestDefineCollectionDisplayName(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
t.Run("normal path", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
path := filepath.Join("dir1", "dir2", "fancyFile.txt")
|
|
result := defineCollectionDisplayName(path)
|
|
assert.Equal(t, "dir1_dir2_fancyFile", result)
|
|
})
|
|
|
|
t.Run("directory", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
path := filepath.Join("dir1", "dir2", "dir3")
|
|
result := defineCollectionDisplayName(path)
|
|
assert.Equal(t, "dir1_dir2_dir3", result)
|
|
})
|
|
|
|
t.Run("directory with dot prefix", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
path := filepath.Join(".dir1", "dir2", "dir3", "file.json")
|
|
result := defineCollectionDisplayName(path)
|
|
assert.Equal(t, "dir1_dir2_dir3_file", result)
|
|
})
|
|
|
|
t.Run("empty path", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
path := filepath.Join(".")
|
|
result := defineCollectionDisplayName(path)
|
|
assert.Equal(t, "", result)
|
|
})
|
|
}
|
|
|
|
func TestResolveTemplate(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
t.Run("nothing to replace", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
// config := newmanExecuteOptions{NewmanRunCommand: "this is my fancy command"}
|
|
config := newmanExecuteOptions{RunOptions: []string{"this", "is", "my", "fancy", "command"}}
|
|
|
|
cmd, err := resolveTemplate(&config, "collectionsDisplayName")
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, []string{"this", "is", "my", "fancy", "command"}, cmd)
|
|
})
|
|
|
|
t.Run("replace display name", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
config := newmanExecuteOptions{RunOptions: []string{"this", "is", "my", "fancy", "command", "{{.CollectionDisplayName}}"}}
|
|
|
|
cmd, err := resolveTemplate(&config, "theDisplayName")
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, []string{"this", "is", "my", "fancy", "command", "theDisplayName"}, cmd)
|
|
})
|
|
|
|
t.Run("error when parameter cannot be resolved", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
config := newmanExecuteOptions{RunOptions: []string{"this", "is", "my", "fancy", "command", "{{.collectionDisplayName}}"}}
|
|
|
|
_, err := resolveTemplate(&config, "theDisplayName")
|
|
assert.EqualError(t, err, "error on executing template: template: template:1:2: executing \"template\" at <.collectionDisplayName>: can't evaluate field collectionDisplayName in type cmd.TemplateConfig")
|
|
})
|
|
|
|
t.Run("error when template cannot be parsed", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
config := newmanExecuteOptions{RunOptions: []string{"this", "is", "my", "fancy", "command", "{{.collectionDisplayName}"}}
|
|
|
|
_, err := resolveTemplate(&config, "theDisplayName")
|
|
assert.EqualError(t, err, "could not parse newman command template: template: template:1: unexpected \"}\" in operand")
|
|
})
|
|
}
|
|
|
|
func TestLogVersions(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
t.Run("happy path", func(t *testing.T) {
|
|
utils := newNewmanExecuteMockUtils()
|
|
|
|
err := logVersions(&utils)
|
|
assert.NoError(t, err)
|
|
assert.Contains(t, utils.executedExecutables, executedExecutables{executable: "npm", params: []string{"--version"}})
|
|
})
|
|
|
|
t.Run("error in node execution", func(t *testing.T) {
|
|
utils := newNewmanExecuteMockUtils()
|
|
utils.errorOnLoggingNode = true
|
|
|
|
err := logVersions(&utils)
|
|
assert.EqualError(t, err, "error logging node version: error on RunExecutable")
|
|
})
|
|
|
|
t.Run("error in npm execution", func(t *testing.T) {
|
|
utils := newNewmanExecuteMockUtils()
|
|
utils.errorOnLoggingNpm = true
|
|
|
|
err := logVersions(&utils)
|
|
assert.EqualError(t, err, "error logging npm version: error on RunExecutable")
|
|
assert.Contains(t, utils.executedExecutables, executedExecutables{executable: "node", params: []string{"--version"}})
|
|
})
|
|
}
|
|
|
|
func (e *newmanExecuteMockUtils) Glob(string) (matches []string, err error) {
|
|
if e.errorOnGlob {
|
|
return nil, errors.New("error on Glob")
|
|
}
|
|
|
|
return e.filesToFind, nil
|
|
}
|
|
|
|
func (e *newmanExecuteMockUtils) RunExecutable(executable string, params ...string) error {
|
|
if e.errorOnRunShell {
|
|
return errors.New("error on RunExecutable")
|
|
}
|
|
if e.errorOnLoggingNode && executable == "node" && params[0] == "--version" {
|
|
return errors.New("error on RunExecutable")
|
|
}
|
|
if e.errorOnLoggingNpm && executable == "npm" && params[0] == "--version" {
|
|
return errors.New("error on RunExecutable")
|
|
}
|
|
if e.errorOnNewmanExecution && strings.Contains(executable, "newman") {
|
|
return errors.New("error on newman execution")
|
|
}
|
|
if e.errorOnNewmanInstall && sliceUtils.ContainsString(params, "install") {
|
|
return errors.New("error on newman install")
|
|
}
|
|
|
|
length := len(e.executedExecutables)
|
|
if length < e.commandIndex+1 {
|
|
e.executedExecutables = append(e.executedExecutables, executedExecutables{})
|
|
length++
|
|
}
|
|
|
|
e.executedExecutables[length-1].executable = executable
|
|
e.executedExecutables[length-1].params = params
|
|
e.commandIndex++
|
|
|
|
return nil
|
|
}
|
|
|
|
func (e *newmanExecuteMockUtils) Getenv(key string) string {
|
|
if key == "HOME" {
|
|
return "/home/node"
|
|
}
|
|
return ""
|
|
}
|