2019-11-13 14:43:53 +01:00
|
|
|
package helper
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"io"
|
|
|
|
"io/ioutil"
|
|
|
|
"os"
|
|
|
|
"path/filepath"
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/SAP/jenkins-library/pkg/config"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
|
|
|
func configOpenFileMock(name string) (io.ReadCloser, error) {
|
|
|
|
meta1 := `metadata:
|
|
|
|
name: testStep
|
2020-03-19 17:24:35 +01:00
|
|
|
aliases:
|
|
|
|
- name: testStepAlias
|
|
|
|
deprecated: true
|
2019-11-13 14:43:53 +01:00
|
|
|
description: Test description
|
|
|
|
longDescription: |
|
|
|
|
Long Test description
|
|
|
|
spec:
|
2020-01-15 12:16:25 +01:00
|
|
|
outputs:
|
|
|
|
resources:
|
2021-12-15 17:07:47 +03:00
|
|
|
- name: reports
|
|
|
|
type: reports
|
|
|
|
params:
|
|
|
|
- filePattern: "test-report_*.json"
|
|
|
|
subFolder: "sonarExecuteScan"
|
|
|
|
- filePattern: "report1"
|
|
|
|
type: general
|
2020-01-15 12:16:25 +01:00
|
|
|
- name: commonPipelineEnvironment
|
|
|
|
type: piperEnvironment
|
|
|
|
params:
|
|
|
|
- name: artifactVersion
|
|
|
|
- name: git/commitId
|
2021-05-20 13:11:57 +02:00
|
|
|
- name: git/headCommitId
|
2020-01-15 12:16:25 +01:00
|
|
|
- name: git/branch
|
2020-11-02 08:51:58 +01:00
|
|
|
- name: custom/customList
|
|
|
|
type: "[]string"
|
2020-01-15 12:16:25 +01:00
|
|
|
- name: influxTest
|
|
|
|
type: influx
|
|
|
|
params:
|
|
|
|
- name: m1
|
|
|
|
fields:
|
|
|
|
- name: f1
|
|
|
|
tags:
|
|
|
|
- name: t1
|
2019-11-13 14:43:53 +01:00
|
|
|
inputs:
|
2021-03-01 13:03:42 +01:00
|
|
|
resources:
|
|
|
|
- name: stashName
|
|
|
|
type: stash
|
2019-11-13 14:43:53 +01:00
|
|
|
params:
|
|
|
|
- name: param0
|
2021-11-23 15:37:28 +01:00
|
|
|
aliases:
|
|
|
|
- name: oldparam0
|
2019-11-13 14:43:53 +01:00
|
|
|
type: string
|
|
|
|
description: param0 description
|
|
|
|
default: val0
|
|
|
|
scope:
|
|
|
|
- GENERAL
|
|
|
|
- PARAMETERS
|
|
|
|
mandatory: true
|
|
|
|
- name: param1
|
2021-11-23 15:37:28 +01:00
|
|
|
aliases:
|
|
|
|
- name: oldparam1
|
|
|
|
deprecated: true
|
2019-11-13 14:43:53 +01:00
|
|
|
type: string
|
|
|
|
description: param1 description
|
|
|
|
scope:
|
|
|
|
- PARAMETERS
|
2021-10-01 12:49:05 +02:00
|
|
|
possibleValues:
|
|
|
|
- value1
|
|
|
|
- value2
|
|
|
|
- value3
|
2022-02-23 15:16:05 +01:00
|
|
|
deprecationMessage: use param3 instead
|
2019-11-13 14:43:53 +01:00
|
|
|
- name: param2
|
|
|
|
type: string
|
2021-10-01 12:49:05 +02:00
|
|
|
description: param2 description
|
2019-11-13 14:43:53 +01:00
|
|
|
scope:
|
|
|
|
- PARAMETERS
|
2021-10-01 12:49:05 +02:00
|
|
|
mandatoryIf:
|
|
|
|
- name: param1
|
|
|
|
value: value1
|
|
|
|
- name: param3
|
|
|
|
type: string
|
|
|
|
description: param3 description
|
|
|
|
scope:
|
|
|
|
- PARAMETERS
|
|
|
|
possibleValues:
|
|
|
|
- value1
|
|
|
|
- value2
|
|
|
|
- value3
|
|
|
|
mandatoryIf:
|
|
|
|
- name: param1
|
|
|
|
value: value1
|
|
|
|
- name: param2
|
|
|
|
value: value2
|
2019-11-13 14:43:53 +01:00
|
|
|
`
|
|
|
|
var r string
|
|
|
|
switch name {
|
2021-11-15 14:20:20 +01:00
|
|
|
case "testStep.yaml":
|
2019-11-13 14:43:53 +01:00
|
|
|
r = meta1
|
|
|
|
default:
|
|
|
|
r = ""
|
|
|
|
}
|
|
|
|
return ioutil.NopCloser(strings.NewReader(r)), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
var files map[string][]byte
|
|
|
|
|
|
|
|
func writeFileMock(filename string, data []byte, perm os.FileMode) error {
|
|
|
|
if files == nil {
|
|
|
|
files = make(map[string][]byte)
|
|
|
|
}
|
|
|
|
files[filename] = data
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestProcessMetaFiles(t *testing.T) {
|
|
|
|
|
2019-11-21 11:12:30 +01:00
|
|
|
stepHelperData := StepHelperData{configOpenFileMock, writeFileMock, ""}
|
2021-11-15 14:20:20 +01:00
|
|
|
ProcessMetaFiles([]string{"testStep.yaml"}, "./cmd", stepHelperData)
|
2019-11-13 14:43:53 +01:00
|
|
|
|
|
|
|
t.Run("step code", func(t *testing.T) {
|
|
|
|
goldenFilePath := filepath.Join("testdata", t.Name()+"_generated.golden")
|
|
|
|
expected, err := ioutil.ReadFile(goldenFilePath)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed reading %v", goldenFilePath)
|
|
|
|
}
|
2020-07-17 08:06:11 +02:00
|
|
|
resultFilePath := filepath.Join("cmd", "testStep_generated.go")
|
|
|
|
assert.Equal(t, string(expected), string(files[resultFilePath]))
|
2021-06-16 08:43:30 +02:00
|
|
|
//t.Log(string(files[resultFilePath]))
|
2019-11-13 14:43:53 +01:00
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("test code", func(t *testing.T) {
|
|
|
|
goldenFilePath := filepath.Join("testdata", t.Name()+"_generated.golden")
|
|
|
|
expected, err := ioutil.ReadFile(goldenFilePath)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed reading %v", goldenFilePath)
|
|
|
|
}
|
2020-07-17 08:06:11 +02:00
|
|
|
resultFilePath := filepath.Join("cmd", "testStep_generated_test.go")
|
|
|
|
assert.Equal(t, string(expected), string(files[resultFilePath]))
|
2019-11-13 14:43:53 +01:00
|
|
|
})
|
2020-01-31 15:39:45 +01:00
|
|
|
|
|
|
|
t.Run("custom step code", func(t *testing.T) {
|
|
|
|
stepHelperData = StepHelperData{configOpenFileMock, writeFileMock, "piperOsCmd"}
|
2021-11-15 14:20:20 +01:00
|
|
|
ProcessMetaFiles([]string{"testStep.yaml"}, "./cmd", stepHelperData)
|
2020-01-31 15:39:45 +01:00
|
|
|
|
|
|
|
goldenFilePath := filepath.Join("testdata", t.Name()+"_generated.golden")
|
|
|
|
expected, err := ioutil.ReadFile(goldenFilePath)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed reading %v", goldenFilePath)
|
|
|
|
}
|
2020-07-17 08:06:11 +02:00
|
|
|
resultFilePath := filepath.Join("cmd", "testStep_generated.go")
|
|
|
|
assert.Equal(t, string(expected), string(files[resultFilePath]))
|
2021-06-16 08:43:30 +02:00
|
|
|
//t.Log(string(files[resultFilePath]))
|
2020-01-31 15:39:45 +01:00
|
|
|
})
|
2019-11-13 14:43:53 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestSetDefaultParameters(t *testing.T) {
|
|
|
|
t.Run("success case", func(t *testing.T) {
|
2019-12-13 09:55:45 +00:00
|
|
|
sliceVals := []string{"val4_1", "val4_2"}
|
|
|
|
stringSliceDefault := make([]interface{}, len(sliceVals))
|
|
|
|
for i, v := range sliceVals {
|
|
|
|
stringSliceDefault[i] = v
|
|
|
|
}
|
2019-11-13 14:43:53 +01:00
|
|
|
stepData := config.StepData{
|
|
|
|
Spec: config.StepSpec{
|
|
|
|
Inputs: config.StepInputs{
|
|
|
|
Parameters: []config.StepParameters{
|
2020-01-24 14:30:27 +01:00
|
|
|
{Name: "param0", Type: "string", Default: "val0"},
|
|
|
|
{Name: "param1", Type: "string"},
|
|
|
|
{Name: "param2", Type: "bool", Default: true},
|
|
|
|
{Name: "param3", Type: "bool"},
|
|
|
|
{Name: "param4", Type: "[]string", Default: stringSliceDefault},
|
|
|
|
{Name: "param5", Type: "[]string"},
|
|
|
|
{Name: "param6", Type: "int"},
|
|
|
|
{Name: "param7", Type: "int", Default: 1},
|
2019-11-13 14:43:53 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
expected := []string{
|
2020-05-25 19:48:59 +02:00
|
|
|
"`val0`",
|
2019-11-13 14:43:53 +01:00
|
|
|
"os.Getenv(\"PIPER_param1\")",
|
|
|
|
"true",
|
|
|
|
"false",
|
2020-05-25 19:48:59 +02:00
|
|
|
"[]string{`val4_1`, `val4_2`}",
|
2019-11-13 14:43:53 +01:00
|
|
|
"[]string{}",
|
2020-01-24 14:30:27 +01:00
|
|
|
"0",
|
|
|
|
"1",
|
2019-11-13 14:43:53 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
osImport, err := setDefaultParameters(&stepData)
|
|
|
|
|
2020-09-24 07:41:06 +02:00
|
|
|
assert.NoError(t, err, "error occurred but none expected")
|
2019-11-13 14:43:53 +01:00
|
|
|
|
|
|
|
assert.Equal(t, true, osImport, "import of os package required")
|
|
|
|
|
|
|
|
for k, v := range expected {
|
|
|
|
assert.Equal(t, v, stepData.Spec.Inputs.Parameters[k].Default, fmt.Sprintf("default not correct for parameter %v", k))
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("error case", func(t *testing.T) {
|
|
|
|
stepData := []config.StepData{
|
|
|
|
{
|
|
|
|
Spec: config.StepSpec{
|
|
|
|
Inputs: config.StepInputs{
|
|
|
|
Parameters: []config.StepParameters{
|
2020-01-24 14:30:27 +01:00
|
|
|
{Name: "param0", Type: "n/a", Default: 10},
|
|
|
|
{Name: "param1", Type: "n/a"},
|
2019-11-13 14:43:53 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Spec: config.StepSpec{
|
|
|
|
Inputs: config.StepInputs{
|
|
|
|
Parameters: []config.StepParameters{
|
2020-01-24 14:30:27 +01:00
|
|
|
{Name: "param1", Type: "n/a"},
|
2019-11-13 14:43:53 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for k, v := range stepData {
|
|
|
|
_, err := setDefaultParameters(&v)
|
2020-09-24 07:41:06 +02:00
|
|
|
assert.Error(t, err, fmt.Sprintf("error expected but none occurred for parameter %v", k))
|
2019-11-13 14:43:53 +01:00
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGetStepInfo(t *testing.T) {
|
|
|
|
|
|
|
|
stepData := config.StepData{
|
|
|
|
Metadata: config.StepMetadata{
|
|
|
|
Name: "testStep",
|
|
|
|
Description: "Test description",
|
|
|
|
LongDescription: "Long Test description",
|
|
|
|
},
|
|
|
|
Spec: config.StepSpec{
|
|
|
|
Inputs: config.StepInputs{
|
|
|
|
Parameters: []config.StepParameters{
|
|
|
|
{Name: "param0", Scope: []string{"GENERAL"}, Type: "string", Default: "test"},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2020-01-15 12:16:25 +01:00
|
|
|
myStepInfo, err := getStepInfo(&stepData, true, "")
|
|
|
|
|
|
|
|
assert.NoError(t, err)
|
2019-11-13 14:43:53 +01:00
|
|
|
|
|
|
|
assert.Equal(t, "testStep", myStepInfo.StepName, "StepName incorrect")
|
|
|
|
assert.Equal(t, "TestStepCommand", myStepInfo.CobraCmdFuncName, "CobraCmdFuncName incorrect")
|
|
|
|
assert.Equal(t, "createTestStepCmd", myStepInfo.CreateCmdVar, "CreateCmdVar incorrect")
|
|
|
|
assert.Equal(t, "Test description", myStepInfo.Short, "Short incorrect")
|
|
|
|
assert.Equal(t, "Long Test description", myStepInfo.Long, "Long incorrect")
|
2020-03-19 17:24:35 +01:00
|
|
|
assert.Equal(t, stepData.Spec.Inputs.Parameters, myStepInfo.StepParameters, "Metadata incorrect")
|
2019-11-13 14:43:53 +01:00
|
|
|
assert.Equal(t, "addTestStepFlags", myStepInfo.FlagsFunc, "FlagsFunc incorrect")
|
|
|
|
assert.Equal(t, "addTestStepFlags", myStepInfo.FlagsFunc, "FlagsFunc incorrect")
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestLongName(t *testing.T) {
|
|
|
|
tt := []struct {
|
|
|
|
input string
|
|
|
|
expected string
|
|
|
|
}{
|
|
|
|
{input: "my long name with no ticks", expected: "my long name with no ticks"},
|
|
|
|
{input: "my long name with `ticks`", expected: "my long name with ` + \"`\" + `ticks` + \"`\" + `"},
|
|
|
|
}
|
|
|
|
|
|
|
|
for k, v := range tt {
|
|
|
|
assert.Equal(t, v.expected, longName(v.input), fmt.Sprintf("wrong long name for run %v", k))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-01-15 12:16:25 +01:00
|
|
|
func TestGolangNameTitle(t *testing.T) {
|
2019-11-13 14:43:53 +01:00
|
|
|
tt := []struct {
|
|
|
|
input string
|
|
|
|
expected string
|
|
|
|
}{
|
|
|
|
{input: "testApi", expected: "TestAPI"},
|
|
|
|
{input: "apiTest", expected: "APITest"},
|
|
|
|
{input: "testUrl", expected: "TestURL"},
|
|
|
|
{input: "testId", expected: "TestID"},
|
|
|
|
{input: "testJson", expected: "TestJSON"},
|
|
|
|
{input: "jsonTest", expected: "JSONTest"},
|
|
|
|
}
|
|
|
|
|
|
|
|
for k, v := range tt {
|
2021-12-15 17:07:47 +03:00
|
|
|
assert.Equal(t, v.expected, GolangNameTitle(v.input), fmt.Sprintf("wrong golang name for run %v", k))
|
2019-11-13 14:43:53 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestFlagType(t *testing.T) {
|
|
|
|
tt := []struct {
|
|
|
|
input string
|
|
|
|
expected string
|
|
|
|
}{
|
|
|
|
{input: "bool", expected: "BoolVar"},
|
2020-01-24 14:30:27 +01:00
|
|
|
{input: "int", expected: "IntVar"},
|
2019-11-13 14:43:53 +01:00
|
|
|
{input: "string", expected: "StringVar"},
|
|
|
|
{input: "[]string", expected: "StringSliceVar"},
|
|
|
|
}
|
|
|
|
|
|
|
|
for k, v := range tt {
|
|
|
|
assert.Equal(t, v.expected, flagType(v.input), fmt.Sprintf("wrong flag type for run %v", k))
|
|
|
|
}
|
|
|
|
}
|
2019-12-13 09:55:45 +00:00
|
|
|
|
|
|
|
func TestGetStringSliceFromInterface(t *testing.T) {
|
|
|
|
tt := []struct {
|
|
|
|
input interface{}
|
|
|
|
expected []string
|
|
|
|
}{
|
|
|
|
{input: []interface{}{"Test", 2}, expected: []string{"Test", "2"}},
|
|
|
|
{input: "Test", expected: []string{"Test"}},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, v := range tt {
|
|
|
|
assert.Equal(t, v.expected, getStringSliceFromInterface(v.input), "interface conversion failed")
|
|
|
|
}
|
|
|
|
}
|