2020-08-27 07:54:03 +02:00
|
|
|
package cmd
|
|
|
|
|
|
|
|
import (
|
|
|
|
"path/filepath"
|
|
|
|
"testing"
|
2020-09-30 16:40:36 +02:00
|
|
|
"time"
|
2020-08-27 07:54:03 +02:00
|
|
|
|
2020-09-30 16:40:36 +02:00
|
|
|
abapbuild "github.com/SAP/jenkins-library/pkg/abap/build"
|
2020-08-27 07:54:03 +02:00
|
|
|
"github.com/SAP/jenkins-library/pkg/abaputils"
|
|
|
|
piperhttp "github.com/SAP/jenkins-library/pkg/http"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
2020-09-30 16:40:36 +02:00
|
|
|
func testSetup(client piperhttp.Sender, buildID string) abapbuild.Build {
|
|
|
|
conn := new(abapbuild.Connector)
|
2020-08-27 07:54:03 +02:00
|
|
|
conn.Client = client
|
2020-09-30 16:40:36 +02:00
|
|
|
conn.DownloadClient = &abapbuild.DownloadClientMock{}
|
2020-08-27 07:54:03 +02:00
|
|
|
conn.Header = make(map[string][]string)
|
2020-09-30 16:40:36 +02:00
|
|
|
b := abapbuild.Build{
|
|
|
|
Connector: *conn,
|
2020-08-27 07:54:03 +02:00
|
|
|
BuildID: buildID,
|
|
|
|
}
|
|
|
|
return b
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestCheckIfFailedAndPrintLogsWithError(t *testing.T) {
|
|
|
|
t.Run("checkIfFailedAndPrintLogs with failed build", func(t *testing.T) {
|
|
|
|
var repo abaputils.Repository
|
2020-09-30 16:40:36 +02:00
|
|
|
b := testSetup(&abapbuild.ClMock{}, "ABIFNLDCSQPOVMXK4DNPBDRW2M")
|
|
|
|
b.RunState = abapbuild.Failed
|
2020-08-27 07:54:03 +02:00
|
|
|
var buildsWithRepo []buildWithRepository
|
|
|
|
bWR := buildWithRepository{
|
|
|
|
build: b,
|
|
|
|
repo: repo,
|
|
|
|
}
|
|
|
|
buildsWithRepo = append(buildsWithRepo, bWR)
|
|
|
|
err := checkIfFailedAndPrintLogs(buildsWithRepo)
|
|
|
|
assert.Error(t, err)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestCheckIfFailedAndPrintLogs(t *testing.T) {
|
|
|
|
t.Run("checkIfFailedAndPrintLogs", func(t *testing.T) {
|
|
|
|
var repo abaputils.Repository
|
2020-09-30 16:40:36 +02:00
|
|
|
b := testSetup(&abapbuild.ClMock{}, "ABIFNLDCSQPOVMXK4DNPBDRW2M")
|
|
|
|
b.RunState = abapbuild.Finished
|
2020-08-27 07:54:03 +02:00
|
|
|
var buildsWithRepo []buildWithRepository
|
|
|
|
bWR := buildWithRepository{
|
|
|
|
build: b,
|
|
|
|
repo: repo,
|
|
|
|
}
|
|
|
|
buildsWithRepo = append(buildsWithRepo, bWR)
|
|
|
|
err := checkIfFailedAndPrintLogs(buildsWithRepo)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestStarting(t *testing.T) {
|
|
|
|
t.Run("Run starting", func(t *testing.T) {
|
2020-09-30 16:40:36 +02:00
|
|
|
client := &abapbuild.ClMock{
|
2020-08-27 07:54:03 +02:00
|
|
|
Token: "MyToken",
|
|
|
|
}
|
2020-09-30 16:40:36 +02:00
|
|
|
conn := new(abapbuild.Connector)
|
2020-08-27 07:54:03 +02:00
|
|
|
conn.Client = client
|
|
|
|
conn.Header = make(map[string][]string)
|
|
|
|
var repos []abaputils.Repository
|
|
|
|
repo := abaputils.Repository{
|
|
|
|
Name: "RepoA",
|
|
|
|
Version: "0001",
|
|
|
|
PackageName: "Package",
|
|
|
|
PackageType: "AOI",
|
|
|
|
SpLevel: "0000",
|
|
|
|
PatchLevel: "0000",
|
|
|
|
Status: "P",
|
|
|
|
Namespace: "/DEMO/",
|
|
|
|
}
|
|
|
|
repos = append(repos, repo)
|
|
|
|
repo.Status = "R"
|
|
|
|
repos = append(repos, repo)
|
|
|
|
|
|
|
|
builds, buildsAlreadyReleased, err := starting(repos, *conn)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.Equal(t, 1, len(builds))
|
|
|
|
assert.Equal(t, 1, len(buildsAlreadyReleased))
|
2020-09-30 16:40:36 +02:00
|
|
|
assert.Equal(t, abapbuild.Accepted, builds[0].build.RunState)
|
|
|
|
assert.Equal(t, abapbuild.RunState(""), buildsAlreadyReleased[0].build.RunState)
|
2020-08-27 07:54:03 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestStartingInvalidInput(t *testing.T) {
|
|
|
|
t.Run("Run starting", func(t *testing.T) {
|
2020-09-30 16:40:36 +02:00
|
|
|
client := &abapbuild.ClMock{
|
2020-08-27 07:54:03 +02:00
|
|
|
Token: "MyToken",
|
|
|
|
}
|
2020-09-30 16:40:36 +02:00
|
|
|
conn := new(abapbuild.Connector)
|
2020-08-27 07:54:03 +02:00
|
|
|
conn.Client = client
|
|
|
|
conn.Header = make(map[string][]string)
|
|
|
|
var repos []abaputils.Repository
|
|
|
|
repo := abaputils.Repository{
|
|
|
|
Name: "RepoA",
|
|
|
|
Status: "P",
|
|
|
|
}
|
|
|
|
repos = append(repos, repo)
|
|
|
|
_, _, err := starting(repos, *conn)
|
|
|
|
assert.Error(t, err)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestPolling(t *testing.T) {
|
|
|
|
t.Run("Run polling", func(t *testing.T) {
|
|
|
|
var repo abaputils.Repository
|
2020-09-30 16:40:36 +02:00
|
|
|
b := testSetup(&abapbuild.ClMock{}, "ABIFNLDCSQPOVMXK4DNPBDRW2M")
|
2020-08-27 07:54:03 +02:00
|
|
|
var buildsWithRepo []buildWithRepository
|
|
|
|
bWR := buildWithRepository{
|
|
|
|
build: b,
|
|
|
|
repo: repo,
|
|
|
|
}
|
|
|
|
buildsWithRepo = append(buildsWithRepo, bWR)
|
2020-09-30 16:40:36 +02:00
|
|
|
timeout := time.Duration(600 * time.Second)
|
|
|
|
pollInterval := time.Duration(1 * time.Second)
|
|
|
|
err := polling(buildsWithRepo, timeout, pollInterval)
|
2020-08-27 07:54:03 +02:00
|
|
|
assert.NoError(t, err)
|
2020-09-30 16:40:36 +02:00
|
|
|
assert.Equal(t, abapbuild.Finished, buildsWithRepo[0].build.RunState)
|
2020-08-27 07:54:03 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestDownloadSARXML(t *testing.T) {
|
|
|
|
t.Run("Run downloadSARXML", func(t *testing.T) {
|
|
|
|
var repo abaputils.Repository
|
2020-09-30 16:40:36 +02:00
|
|
|
b := testSetup(&abapbuild.ClMock{}, "ABIFNLDCSQPOVMXK4DNPBDRW2M")
|
2020-08-27 07:54:03 +02:00
|
|
|
var buildsWithRepo []buildWithRepository
|
|
|
|
bWR := buildWithRepository{
|
|
|
|
build: b,
|
|
|
|
repo: repo,
|
|
|
|
}
|
|
|
|
buildsWithRepo = append(buildsWithRepo, bWR)
|
|
|
|
repos, err := downloadSARXML(buildsWithRepo)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
downloadPath := filepath.Join(GeneralConfig.EnvRootPath, "commonPipelineEnvironment", "abap", "SAPK-001AAINITAPC1.SAR")
|
|
|
|
assert.Equal(t, downloadPath, repos[0].SarXMLFilePath)
|
|
|
|
})
|
|
|
|
}
|