mirror of
https://github.com/SAP/jenkins-library.git
synced 2025-01-18 05:18:24 +02:00
0f4e30e9db
This commit replaces `ioutil.TempDir` with `t.TempDir` in tests. The directory created by `t.TempDir` is automatically removed when the test and all its subtests complete. Prior to this commit, temporary directory created using `ioutil.TempDir` needs to be removed manually by calling `os.RemoveAll`, which is omitted in some tests. The error handling boilerplate e.g. defer func() { if err := os.RemoveAll(dir); err != nil { t.Fatal(err) } } is also tedious, but `t.TempDir` handles this for us nicely. Reference: https://pkg.go.dev/testing#T.TempDir Signed-off-by: Eng Zer Jun <engzerjun@gmail.com> Co-authored-by: Oliver Nocon <33484802+OliverNocon@users.noreply.github.com>
332 lines
9.6 KiB
Go
332 lines
9.6 KiB
Go
package abaputils
|
|
|
|
import (
|
|
"encoding/json"
|
|
"fmt"
|
|
"io/ioutil"
|
|
"os"
|
|
"testing"
|
|
|
|
"github.com/pkg/errors"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
var executionLogString string
|
|
|
|
func init() {
|
|
executionLog := PullEntity{
|
|
ToExecutionLog: AbapLogs{
|
|
Results: []LogResults{
|
|
{
|
|
Index: "1",
|
|
Type: "LogEntry",
|
|
Description: "S",
|
|
Timestamp: "/Date(1644332299000+0000)/",
|
|
},
|
|
},
|
|
},
|
|
}
|
|
executionLogResponse, _ := json.Marshal(executionLog)
|
|
executionLogString = string(executionLogResponse)
|
|
}
|
|
func TestPollEntity(t *testing.T) {
|
|
|
|
t.Run("Test poll entity - success case", func(t *testing.T) {
|
|
|
|
logResultSuccess := fmt.Sprintf(`{"d": { "sc_name": "/DMO/SWC", "status": "S", "to_Log_Overview": { "results": [ { "log_index": 1, "log_name": "Main Import", "type_of_found_issues": "Success", "timestamp": "/Date(1644332299000+0000)/", "to_Log_Protocol": { "results": [ { "log_index": 1, "index_no": "1", "log_name": "", "type": "Info", "descr": "Main import", "timestamp": null, "criticality": 0 } ] } } ] } } }`)
|
|
client := &ClientMock{
|
|
BodyList: []string{
|
|
`{"d" : ` + executionLogString + `}`,
|
|
logResultSuccess,
|
|
`{"d" : { "EntitySets" : [ "LogOverviews" ] } }`,
|
|
`{"d" : { "status" : "S" } }`,
|
|
`{"d" : { "status" : "R" } }`,
|
|
},
|
|
Token: "myToken",
|
|
StatusCode: 200,
|
|
}
|
|
|
|
options := AbapEnvironmentOptions{
|
|
CfAPIEndpoint: "https://api.endpoint.com",
|
|
CfOrg: "testOrg",
|
|
CfSpace: "testSpace",
|
|
CfServiceInstance: "testInstance",
|
|
CfServiceKeyName: "testServiceKey",
|
|
Username: "testUser",
|
|
Password: "testPassword",
|
|
}
|
|
|
|
config := AbapEnvironmentCheckoutBranchOptions{
|
|
AbapEnvOptions: options,
|
|
RepositoryName: "testRepo1",
|
|
}
|
|
|
|
con := ConnectionDetailsHTTP{
|
|
User: "MY_USER",
|
|
Password: "MY_PW",
|
|
URL: "https://api.endpoint.com/Entity/",
|
|
XCsrfToken: "MY_TOKEN",
|
|
}
|
|
status, _ := PollEntity(config.RepositoryName, con, client, 0)
|
|
assert.Equal(t, "S", status)
|
|
})
|
|
|
|
t.Run("Test poll entity - error case", func(t *testing.T) {
|
|
logResultError := fmt.Sprintf(`{"d": { "sc_name": "/DMO/SWC", "status": "S", "to_Log_Overview": { "results": [ { "log_index": 1, "log_name": "Main Import", "type_of_found_issues": "Error", "timestamp": "/Date(1644332299000+0000)/", "to_Log_Protocol": { "results": [ { "log_index": 1, "index_no": "1", "log_name": "", "type": "Info", "descr": "Main import", "timestamp": null, "criticality": 0 } ] } } ] } } }`)
|
|
client := &ClientMock{
|
|
BodyList: []string{
|
|
`{"d" : ` + executionLogString + `}`,
|
|
logResultError,
|
|
`{"d" : { "EntitySets" : [ "LogOverviews" ] } }`,
|
|
`{"d" : { "status" : "E" } }`,
|
|
`{"d" : { "status" : "R" } }`,
|
|
},
|
|
Token: "myToken",
|
|
StatusCode: 200,
|
|
}
|
|
|
|
options := AbapEnvironmentOptions{
|
|
CfAPIEndpoint: "https://api.endpoint.com",
|
|
CfOrg: "testOrg",
|
|
CfSpace: "testSpace",
|
|
CfServiceInstance: "testInstance",
|
|
CfServiceKeyName: "testServiceKey",
|
|
Username: "testUser",
|
|
Password: "testPassword",
|
|
}
|
|
|
|
config := AbapEnvironmentCheckoutBranchOptions{
|
|
AbapEnvOptions: options,
|
|
RepositoryName: "testRepo1",
|
|
}
|
|
|
|
con := ConnectionDetailsHTTP{
|
|
User: "MY_USER",
|
|
Password: "MY_PW",
|
|
URL: "https://api.endpoint.com/Entity/",
|
|
XCsrfToken: "MY_TOKEN",
|
|
}
|
|
status, _ := PollEntity(config.RepositoryName, con, client, 0)
|
|
assert.Equal(t, "E", status)
|
|
})
|
|
}
|
|
|
|
func TestGetRepositories(t *testing.T) {
|
|
t.Run("Get Repositories from config - success case", func(t *testing.T) {
|
|
expectedRepositoryList := []Repository{{
|
|
Name: "testRepo",
|
|
Branch: "testBranch",
|
|
}, {
|
|
Name: "testRepo2",
|
|
Branch: "testBranch2",
|
|
}, {
|
|
Name: "testRepo3",
|
|
Branch: "testBranch3",
|
|
}, {
|
|
Name: "testRepository",
|
|
Branch: "testBranch",
|
|
}, {
|
|
Name: "testRepository",
|
|
}}
|
|
|
|
dir := t.TempDir()
|
|
oldCWD, _ := os.Getwd()
|
|
_ = os.Chdir(dir)
|
|
|
|
defer func() {
|
|
_ = os.Chdir(oldCWD)
|
|
}()
|
|
|
|
manifestFileString := `
|
|
repositories:
|
|
- name: 'testRepo'
|
|
branch: 'testBranch'
|
|
- name: 'testRepo2'
|
|
branch: 'testBranch2'
|
|
- name: 'testRepo3'
|
|
branch: 'testBranch3'`
|
|
|
|
err := ioutil.WriteFile("repositoriesTest.yml", []byte(manifestFileString), 0644)
|
|
|
|
config := RepositoriesConfig{
|
|
BranchName: "testBranch",
|
|
RepositoryName: "testRepository",
|
|
RepositoryNames: []string{"testRepository"},
|
|
Repositories: "repositoriesTest.yml",
|
|
}
|
|
|
|
repositories, err := GetRepositories(&config, true)
|
|
|
|
assert.Equal(t, expectedRepositoryList, repositories)
|
|
assert.NoError(t, err)
|
|
})
|
|
t.Run("Get Repositories from file config - failure case", func(t *testing.T) {
|
|
expectedRepositoryList := []Repository([]Repository{})
|
|
expectedErrorMessage := "Error in config file repositoriesTest.yml, AddonDescriptor doesn't contain any repositories"
|
|
|
|
dir := t.TempDir()
|
|
oldCWD, _ := os.Getwd()
|
|
_ = os.Chdir(dir)
|
|
|
|
defer func() {
|
|
_ = os.Chdir(oldCWD)
|
|
}()
|
|
|
|
manifestFileString := `
|
|
repositories:
|
|
- repo: 'testRepo'
|
|
- repo: 'testRepo2'`
|
|
|
|
err := ioutil.WriteFile("repositoriesTest.yml", []byte(manifestFileString), 0644)
|
|
|
|
config := RepositoriesConfig{
|
|
Repositories: "repositoriesTest.yml",
|
|
}
|
|
|
|
repositories, err := GetRepositories(&config, false)
|
|
|
|
assert.Equal(t, expectedRepositoryList, repositories)
|
|
assert.EqualError(t, err, expectedErrorMessage)
|
|
})
|
|
t.Run("Get Repositories from config - failure case", func(t *testing.T) {
|
|
expectedRepositoryList := []Repository([]Repository{})
|
|
expectedErrorMessage := "Error in config file repositoriesTest.yml, AddonDescriptor doesn't contain any repositories"
|
|
|
|
dir := t.TempDir()
|
|
oldCWD, _ := os.Getwd()
|
|
_ = os.Chdir(dir)
|
|
|
|
defer func() {
|
|
_ = os.Chdir(oldCWD)
|
|
}()
|
|
|
|
manifestFileString := `
|
|
repositories:
|
|
- repo: 'testRepo'
|
|
- repo: 'testRepo2'`
|
|
|
|
err := ioutil.WriteFile("repositoriesTest.yml", []byte(manifestFileString), 0644)
|
|
|
|
config := RepositoriesConfig{
|
|
Repositories: "repositoriesTest.yml",
|
|
}
|
|
|
|
repositories, err := GetRepositories(&config, false)
|
|
|
|
assert.Equal(t, expectedRepositoryList, repositories)
|
|
assert.EqualError(t, err, expectedErrorMessage)
|
|
})
|
|
t.Run("Get Repositories from empty config - failure case", func(t *testing.T) {
|
|
expectedRepositoryList := []Repository([]Repository{})
|
|
expectedErrorMessage := "Failed to read repository configuration: You have not specified any repository configuration. Please make sure that you have correctly specified it. For more information please read the User documentation"
|
|
|
|
config := RepositoriesConfig{}
|
|
|
|
repositories, err := GetRepositories(&config, false)
|
|
|
|
assert.Equal(t, expectedRepositoryList, repositories)
|
|
assert.EqualError(t, err, expectedErrorMessage)
|
|
})
|
|
}
|
|
|
|
func TestCreateLogStrings(t *testing.T) {
|
|
t.Run("Clone LogString Tag and Commit", func(t *testing.T) {
|
|
repo := Repository{
|
|
Name: "/DMO/REPO",
|
|
Branch: "main",
|
|
CommitID: "1234567",
|
|
Tag: "myTag",
|
|
}
|
|
logString := repo.GetCloneLogString()
|
|
assert.Equal(t, "repository / software component '/DMO/REPO', branch 'main', commit '1234567'", logString, "Expected different string")
|
|
})
|
|
t.Run("Clone LogString Tag", func(t *testing.T) {
|
|
repo := Repository{
|
|
Name: "/DMO/REPO",
|
|
Branch: "main",
|
|
Tag: "myTag",
|
|
}
|
|
logString := repo.GetCloneLogString()
|
|
assert.Equal(t, "repository / software component '/DMO/REPO', branch 'main', tag 'myTag'", logString, "Expected different string")
|
|
})
|
|
t.Run("Pull LogString Tag and Commit", func(t *testing.T) {
|
|
repo := Repository{
|
|
Name: "/DMO/REPO",
|
|
Branch: "main",
|
|
CommitID: "1234567",
|
|
Tag: "myTag",
|
|
}
|
|
logString := repo.GetPullLogString()
|
|
assert.Equal(t, "repository / software component '/DMO/REPO', commit '1234567'", logString, "Expected different string")
|
|
})
|
|
t.Run("Pull LogString Tag", func(t *testing.T) {
|
|
repo := Repository{
|
|
Name: "/DMO/REPO",
|
|
Branch: "main",
|
|
Tag: "myTag",
|
|
}
|
|
logString := repo.GetPullLogString()
|
|
assert.Equal(t, "repository / software component '/DMO/REPO', tag 'myTag'", logString, "Expected different string")
|
|
})
|
|
}
|
|
|
|
func TestCreateRequestBodies(t *testing.T) {
|
|
t.Run("Clone Body Tag and Commit", func(t *testing.T) {
|
|
repo := Repository{
|
|
Name: "/DMO/REPO",
|
|
Branch: "main",
|
|
CommitID: "1234567",
|
|
Tag: "myTag",
|
|
}
|
|
body := repo.GetCloneRequestBody()
|
|
assert.Equal(t, `{"sc_name":"/DMO/REPO", "branch_name":"main", "commit_id":"1234567"}`, body, "Expected different body")
|
|
})
|
|
t.Run("Clone Body Tag", func(t *testing.T) {
|
|
repo := Repository{
|
|
Name: "/DMO/REPO",
|
|
Branch: "main",
|
|
Tag: "myTag",
|
|
}
|
|
body := repo.GetCloneRequestBody()
|
|
assert.Equal(t, `{"sc_name":"/DMO/REPO", "branch_name":"main", "tag_name":"myTag"}`, body, "Expected different body")
|
|
})
|
|
t.Run("Pull Body Tag and Commit", func(t *testing.T) {
|
|
repo := Repository{
|
|
Name: "/DMO/REPO",
|
|
Branch: "main",
|
|
CommitID: "1234567",
|
|
Tag: "myTag",
|
|
}
|
|
body := repo.GetPullRequestBody()
|
|
assert.Equal(t, `{"sc_name":"/DMO/REPO", "commit_id":"1234567"}`, body, "Expected different body")
|
|
})
|
|
t.Run("Pull Body Tag", func(t *testing.T) {
|
|
repo := Repository{
|
|
Name: "/DMO/REPO",
|
|
Branch: "main",
|
|
Tag: "myTag",
|
|
}
|
|
body := repo.GetPullRequestBody()
|
|
assert.Equal(t, `{"sc_name":"/DMO/REPO", "tag_name":"myTag"}`, body, "Expected different body")
|
|
})
|
|
}
|
|
|
|
func TestGetStatus(t *testing.T) {
|
|
t.Run("Graceful Exit", func(t *testing.T) {
|
|
|
|
client := &ClientMock{
|
|
NilResponse: true,
|
|
Error: errors.New("Backend Error"),
|
|
StatusCode: 500,
|
|
}
|
|
connectionDetails := ConnectionDetailsHTTP{
|
|
URL: "example.com",
|
|
}
|
|
|
|
_, status, err := GetStatus("failure message", connectionDetails, client)
|
|
|
|
assert.Error(t, err, "Expected Error")
|
|
assert.Equal(t, "", status)
|
|
})
|
|
}
|