mirror of
https://github.com/SAP/jenkins-library.git
synced 2024-12-14 11:03:09 +02:00
164327667c
* Add abaputils pkg and go files * Add ReadServiceKeyAbapEnvironment function * Fixes * Add structs for SC, Pull and Branch * Minor Improvements * Adapt unit tests to new abaputils pkg * Fixes * Add adapted tests * Fixes * Fix cloudfoundry test * Add check for host prefix (HTTPS) * Fix tests + cleanup * Fixes * Fixes * Fix * Add mock for abaputils pkg unit tests * Adapt abaputils comments * Add abapEnvironmentCheckoutBranch step setup * Change description of abapEnvCheckoutBranch step * Add http client code * Disable code due to missing interace * Add coding for use of abaputils * Adapt checkout branch step * Adapt URL for checkout_branch function import * Fixes * Add unit test for missing params case * Fix for missing mapping of CfSpace * Fix for missing mapping of CfSpace * Add working code for a Branch Checkout * Fix host schema * Remove LogoutOption param of unit tests and steps * Fix unit test * Fix unit test CF ReadServiceKey * Add abapEnvironmentCheckoutBranch step setup * Change description of abapEnvCheckoutBranch step * Add http client code * Disable code due to missing interace * Add coding for use of abaputils * Adapt checkout branch step * Adapt URL for checkout_branch function import * Fixes * Fix for missing mapping of CfSpace * Add working code for a Branch Checkout * Adapt changes of abautils pkg * Add test for polling * Minor fix * Fix yaml spacing * Add longdescription to yaml * Refactor abaputil methods * Refactoring * Refactoring * Minor fix * Minor fixeds * Adapt to new abaputils.AUtilsMock * Delete obsolete initial checks for params * Fix manageGitRepoUtils_test.go * Adjust pollEntity tests Co-authored-by: Daniel Mieg <56156797+DanielMieg@users.noreply.github.com>
245 lines
8.9 KiB
Go
245 lines
8.9 KiB
Go
package abaputils
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/SAP/jenkins-library/pkg/command"
|
|
"github.com/SAP/jenkins-library/pkg/mock"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestCloudFoundryGetAbapCommunicationInfo(t *testing.T) {
|
|
t.Run("CF GetAbapCommunicationArrangementInfo - Error - parameters missing", func(t *testing.T) {
|
|
|
|
//given
|
|
options := AbapEnvironmentOptions{
|
|
//CfAPIEndpoint: "https://api.endpoint.com",
|
|
CfSpace: "testSpace",
|
|
CfOrg: "testOrg",
|
|
CfServiceInstance: "testInstance",
|
|
Username: "testUser",
|
|
Password: "testPassword",
|
|
CfServiceKeyName: "testServiceKeyName",
|
|
}
|
|
|
|
//when
|
|
var connectionDetails ConnectionDetailsHTTP
|
|
var err error
|
|
var autils = AbapUtils{
|
|
Exec: &command.Command{},
|
|
}
|
|
connectionDetails, err = autils.GetAbapCommunicationArrangementInfo(options, "")
|
|
|
|
//then
|
|
assert.Equal(t, "", connectionDetails.URL)
|
|
assert.Equal(t, "", connectionDetails.User)
|
|
assert.Equal(t, "", connectionDetails.Password)
|
|
assert.Equal(t, "", connectionDetails.XCsrfToken)
|
|
|
|
assert.EqualError(t, err, "Parameters missing. Please provide EITHER the Host of the ABAP server OR the Cloud Foundry ApiEndpoint, Organization, Space, Service Instance and a corresponding Service Key for the Communication Scenario SAP_COM_0510")
|
|
assert.Error(t, err)
|
|
})
|
|
t.Run("CF GetAbapCommunicationArrangementInfo - Error - reading service Key", func(t *testing.T) {
|
|
|
|
//given
|
|
options := AbapEnvironmentOptions{
|
|
CfAPIEndpoint: "https://api.endpoint.com",
|
|
CfSpace: "testSpace",
|
|
CfOrg: "testOrg",
|
|
CfServiceInstance: "testInstance",
|
|
Username: "testUser",
|
|
Password: "testPassword",
|
|
CfServiceKeyName: "testServiceKeyName",
|
|
}
|
|
|
|
//when
|
|
var connectionDetails ConnectionDetailsHTTP
|
|
var err error
|
|
var autils = AbapUtils{
|
|
Exec: &command.Command{},
|
|
}
|
|
connectionDetails, err = autils.GetAbapCommunicationArrangementInfo(options, "")
|
|
|
|
//then
|
|
assert.Equal(t, "", connectionDetails.URL)
|
|
assert.Equal(t, "", connectionDetails.User)
|
|
assert.Equal(t, "", connectionDetails.Password)
|
|
assert.Equal(t, "", connectionDetails.XCsrfToken)
|
|
|
|
assert.Error(t, err)
|
|
})
|
|
t.Run("CF GetAbapCommunicationArrangementInfo - Success", func(t *testing.T) {
|
|
|
|
//given
|
|
|
|
const testURL = "https://testurl.com"
|
|
const oDataURL = "/sap/opu/odata/sap/MANAGE_GIT_REPOSITORY/Pull"
|
|
const username = "test_user"
|
|
const password = "test_password"
|
|
const serviceKey = `
|
|
cf comment test \n\n
|
|
{"sap.cloud.service":"com.sap.cloud.abap","url": "` + testURL + `" ,"systemid":"H01","abap":{"username":"` + username + `","password":"` + password + `","communication_scenario_id": "SAP_COM_0510","communication_arrangement_id": "SK_I6CBIRFZPPJDKYNATQA32W","communication_system_id": "SK_I6CBIRFZPPJDKYNATQA32W","communication_inbound_user_id": "CC0000000001","communication_inbound_user_auth_mode": "2"},"binding":{"env": "cf","version": "0.0.1.1","type": "basic","id": "i6cBiRfZppJdKynaTqa32W"},"preserve_host_header": true}`
|
|
|
|
options := AbapEnvironmentOptions{
|
|
CfAPIEndpoint: "https://api.endpoint.com",
|
|
CfSpace: "testSpace",
|
|
CfOrg: "testOrg",
|
|
CfServiceInstance: "testInstance",
|
|
Username: "testUser",
|
|
Password: "testPassword",
|
|
CfServiceKeyName: "testServiceKeyName",
|
|
}
|
|
|
|
m := &mock.ExecMockRunner{}
|
|
m.StdoutReturn = map[string]string{"cf service-key testInstance testServiceKeyName": serviceKey}
|
|
var autils = AbapUtils{
|
|
Exec: m,
|
|
}
|
|
//when
|
|
var connectionDetails ConnectionDetailsHTTP
|
|
var err error
|
|
connectionDetails, err = autils.GetAbapCommunicationArrangementInfo(options, oDataURL)
|
|
|
|
//then
|
|
assert.Equal(t, testURL+oDataURL, connectionDetails.URL)
|
|
assert.Equal(t, username, connectionDetails.User)
|
|
assert.Equal(t, password, connectionDetails.Password)
|
|
assert.Equal(t, "", connectionDetails.XCsrfToken)
|
|
|
|
assert.NoError(t, err)
|
|
})
|
|
}
|
|
func TestHostGetAbapCommunicationInfo(t *testing.T) {
|
|
t.Run("HOST GetAbapCommunicationArrangementInfo - Success", func(t *testing.T) {
|
|
|
|
//given
|
|
|
|
const testURL = "https://testurl.com"
|
|
const oDataURL = "/sap/opu/odata/sap/MANAGE_GIT_REPOSITORY/Pull"
|
|
const username = "test_user"
|
|
const password = "test_password"
|
|
const serviceKey = `
|
|
cf comment test \n\n
|
|
{"sap.cloud.service":"com.sap.cloud.abap","url": "` + testURL + `" ,"systemid":"XYZ","abap":{"username":"` + username + `","password":"` + password + `","communication_scenario_id": "SAP_COM_XYZ","communication_arrangement_id": "SK_testing","communication_system_id": "SK_testing","communication_inbound_user_id": "CC0000000000","communication_inbound_user_auth_mode": "2"},"binding":{"env": "cf","version": "0.0.1.1","type": "basic","id": "i6cBiRfZppJdtestKynaTqa32W"},"preserve_host_header": true}`
|
|
|
|
options := AbapEnvironmentOptions{
|
|
Host: testURL,
|
|
Username: username,
|
|
Password: password,
|
|
}
|
|
|
|
m := &mock.ExecMockRunner{}
|
|
m.StdoutReturn = map[string]string{"cf service-key testInstance testServiceKeyName": serviceKey}
|
|
var autils = AbapUtils{
|
|
Exec: m,
|
|
}
|
|
|
|
//when
|
|
var connectionDetails ConnectionDetailsHTTP
|
|
var err error
|
|
connectionDetails, err = autils.GetAbapCommunicationArrangementInfo(options, oDataURL)
|
|
|
|
//then
|
|
assert.Equal(t, testURL+oDataURL, connectionDetails.URL)
|
|
assert.Equal(t, username, connectionDetails.User)
|
|
assert.Equal(t, password, connectionDetails.Password)
|
|
assert.Equal(t, "", connectionDetails.XCsrfToken)
|
|
|
|
assert.NoError(t, err)
|
|
})
|
|
t.Run("HOST GetAbapCommunicationArrangementInfo - Success - w/o https", func(t *testing.T) {
|
|
|
|
//given
|
|
|
|
const testURL = "testurl.com"
|
|
const oDataURL = "/sap/opu/odata/sap/MANAGE_GIT_REPOSITORY/Pull"
|
|
const username = "test_user"
|
|
const password = "test_password"
|
|
const serviceKey = `
|
|
cf comment test \n\n
|
|
{"sap.cloud.service":"com.sap.cloud.abap","url": "` + testURL + `" ,"systemid":"H01","abap":{"username":"` + username + `","password":"` + password + `","communication_scenario_id": "SAP_COM_0510","communication_arrangement_id": "SK_I6CBIRFZPPJDKYNATQA32W","communication_system_id": "SK_I6CBIRFZPPJDKYNATQA32W","communication_inbound_user_id": "CC0000000001","communication_inbound_user_auth_mode": "2"},"binding":{"env": "cf","version": "0.0.1.1","type": "basic","id": "i6cBiRfZppJdKynaTqa32W"},"preserve_host_header": true}`
|
|
|
|
options := AbapEnvironmentOptions{
|
|
Host: testURL,
|
|
Username: username,
|
|
Password: password,
|
|
}
|
|
|
|
m := &mock.ExecMockRunner{}
|
|
m.StdoutReturn = map[string]string{"cf service-key testInstance testServiceKeyName": serviceKey}
|
|
var autils = AbapUtils{
|
|
Exec: m,
|
|
}
|
|
|
|
//when
|
|
var connectionDetails ConnectionDetailsHTTP
|
|
var err error
|
|
connectionDetails, err = autils.GetAbapCommunicationArrangementInfo(options, oDataURL)
|
|
|
|
//then
|
|
assert.Equal(t, "https://"+testURL+oDataURL, connectionDetails.URL)
|
|
assert.Equal(t, username, connectionDetails.User)
|
|
assert.Equal(t, password, connectionDetails.Password)
|
|
assert.Equal(t, "", connectionDetails.XCsrfToken)
|
|
|
|
assert.NoError(t, err)
|
|
})
|
|
}
|
|
func TestReadServiceKeyAbapEnvironment(t *testing.T) {
|
|
t.Run("CF ReadServiceKeyAbapEnvironment - Failed to login to Cloud Foundry", func(t *testing.T) {
|
|
|
|
//given .
|
|
options := AbapEnvironmentOptions{
|
|
Username: "testUser",
|
|
Password: "testPassword",
|
|
CfAPIEndpoint: "https://api.endpoint.com",
|
|
CfSpace: "testSpace",
|
|
CfOrg: "testOrg",
|
|
CfServiceInstance: "testInstance",
|
|
CfServiceKeyName: "testKey",
|
|
}
|
|
|
|
//when
|
|
var abapKey AbapServiceKey
|
|
var err error
|
|
abapKey, err = ReadServiceKeyAbapEnvironment(options, &command.Command{})
|
|
|
|
//then
|
|
assert.Equal(t, "", abapKey.Abap.Password)
|
|
assert.Equal(t, "", abapKey.Abap.Username)
|
|
assert.Equal(t, "", abapKey.Abap.CommunicationArrangementID)
|
|
assert.Equal(t, "", abapKey.Abap.CommunicationScenarioID)
|
|
assert.Equal(t, "", abapKey.Abap.CommunicationSystemID)
|
|
|
|
assert.Equal(t, "", abapKey.Binding.Env)
|
|
assert.Equal(t, "", abapKey.Binding.Type)
|
|
assert.Equal(t, "", abapKey.Binding.ID)
|
|
assert.Equal(t, "", abapKey.Binding.Version)
|
|
assert.Equal(t, "", abapKey.SystemID)
|
|
assert.Equal(t, "", abapKey.URL)
|
|
|
|
assert.Error(t, err)
|
|
})
|
|
}
|
|
|
|
func TestTimeConverter(t *testing.T) {
|
|
t.Run("Test example time", func(t *testing.T) {
|
|
inputDate := "/Date(1585576809000+0000)/"
|
|
expectedDate := "2020-03-30 14:00:09 +0000 UTC"
|
|
result := ConvertTime(inputDate)
|
|
assert.Equal(t, expectedDate, result.String(), "Dates do not match after conversion")
|
|
})
|
|
t.Run("Test Unix time", func(t *testing.T) {
|
|
inputDate := "/Date(0000000000000+0000)/"
|
|
expectedDate := "1970-01-01 00:00:00 +0000 UTC"
|
|
result := ConvertTime(inputDate)
|
|
assert.Equal(t, expectedDate, result.String(), "Dates do not match after conversion")
|
|
})
|
|
t.Run("Test unexpected format", func(t *testing.T) {
|
|
inputDate := "/Date(0012300000001+0000)/"
|
|
expectedDate := "1970-01-01 00:00:00 +0000 UTC"
|
|
result := ConvertTime(inputDate)
|
|
assert.Equal(t, expectedDate, result.String(), "Dates do not match after conversion")
|
|
})
|
|
}
|