You've already forked sap-jenkins-library
							
							
				mirror of
				https://github.com/SAP/jenkins-library.git
				synced 2025-10-30 23:57:50 +02:00 
			
		
		
		
	* Switch to service key for CPI GetMplStatus
Introduces read method for service key files, mock utils and tests.
* Use secret text instead of file
* Change serviceKey definition
* Update cpiUpload to use Service Key
retrieved the host and uaa information from service key
* Update cpiDeploy to use service key
retrieved the host and uaa information from service key
* Update cpiServiceEndpoint to use Service Key
retrieved the host and uaa information from service key
* Update cpiDownload to use Service Key
retrieved the host and uaa information from service key
* Update cpiUpdateConfig to use Service Key
retrieved the host and uaa information from service key
* Refactor serviceKey var name
* Fixed references to service key to follow the real format
they should be accessed through oauth instead of uaa because of the format of the json
* Rename ServiceKey to APIServiceKey
To support having a different service key(and for readability), we need to change the name to API.
* Add STAGES and STEPS yaml
add in to each yaml file of cpi integration
* Revert "Add STAGES and STEPS yaml"
This reverts commit aa2665d158.
* Change comments/formatting commonUtils
Make comments more understandable and follow code climate suggestions
* Change documentation files for steps
remove OAuth and host and change credentials to be servicekey
Co-authored-by: Oliver Feldmann <oliver.feldmann@sap.com>
Co-authored-by: Thorsten Duda <thorsten.duda@sap.com>
		
	
		
			
				
	
	
		
			90 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			90 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package cmd
 | |
| 
 | |
| import (
 | |
| 	"io/ioutil"
 | |
| 	"os"
 | |
| 	"path/filepath"
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/SAP/jenkins-library/pkg/mock"
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| )
 | |
| 
 | |
| type integrationArtifactDownloadMockUtils struct {
 | |
| 	*mock.ExecMockRunner
 | |
| 	*mock.FilesMock
 | |
| }
 | |
| 
 | |
| func newIntegrationArtifactDownloadTestsUtils() integrationArtifactDownloadMockUtils {
 | |
| 	utils := integrationArtifactDownloadMockUtils{
 | |
| 		ExecMockRunner: &mock.ExecMockRunner{},
 | |
| 		FilesMock:      &mock.FilesMock{},
 | |
| 	}
 | |
| 	return utils
 | |
| }
 | |
| 
 | |
| func TestRunIntegrationArtifactDownload(t *testing.T) {
 | |
| 	t.Parallel()
 | |
| 
 | |
| 	t.Run("Successfull Download of Integration flow Artifact", func(t *testing.T) {
 | |
| 		tempDir, tmpErr := ioutil.TempDir("", "")
 | |
| 		defer os.RemoveAll(tempDir) // clean up
 | |
| 		assert.NoError(t, tmpErr, "Error when creating temp dir")
 | |
| 		apiServiceKey := `{
 | |
| 			"oauth": {
 | |
| 				"url": "https://demo",
 | |
| 				"clientid": "demouser",
 | |
| 				"clientsecret": "******",
 | |
| 				"tokenurl": "https://demo/oauth/token"
 | |
| 			}
 | |
| 		}`
 | |
| 
 | |
| 		config := integrationArtifactDownloadOptions{
 | |
| 			APIServiceKey:          apiServiceKey,
 | |
| 			IntegrationFlowID:      "flow1",
 | |
| 			IntegrationFlowVersion: "1.0.1",
 | |
| 			DownloadPath:           tempDir,
 | |
| 		}
 | |
| 
 | |
| 		httpClient := httpMockCpis{CPIFunction: "IntegrationArtifactDownload", ResponseBody: ``, TestType: "PositiveAndGetetIntegrationArtifactDownloadResBody"}
 | |
| 
 | |
| 		err := runIntegrationArtifactDownload(&config, nil, &httpClient)
 | |
| 		absolutePath := filepath.Join(tempDir, "flow1.zip")
 | |
| 		assert.DirExists(t, tempDir)
 | |
| 		if assert.NoError(t, err) {
 | |
| 			assert.Equal(t, fileExists(absolutePath), true)
 | |
| 			t.Run("check url", func(t *testing.T) {
 | |
| 				assert.Equal(t, "https://demo/api/v1/IntegrationDesigntimeArtifacts(Id='flow1',Version='1.0.1')/$value", httpClient.URL)
 | |
| 			})
 | |
| 
 | |
| 			t.Run("check method", func(t *testing.T) {
 | |
| 				assert.Equal(t, "GET", httpClient.Method)
 | |
| 			})
 | |
| 		}
 | |
| 	})
 | |
| 
 | |
| 	t.Run("Failed case of Integration Flow artifact Download", func(t *testing.T) {
 | |
| 		apiServiceKey := `{
 | |
| 			"oauth": {
 | |
| 				"url": "https://demo",
 | |
| 				"clientid": "demouser",
 | |
| 				"clientsecret": "******",
 | |
| 				"tokenurl": "https://demo/oauth/token"
 | |
| 			}
 | |
| 		}`
 | |
| 
 | |
| 		config := integrationArtifactDownloadOptions{
 | |
| 			APIServiceKey:          apiServiceKey,
 | |
| 			IntegrationFlowID:      "flow1",
 | |
| 			IntegrationFlowVersion: "1.0.1",
 | |
| 			DownloadPath:           "tmp",
 | |
| 		}
 | |
| 
 | |
| 		httpClient := httpMockCpis{CPIFunction: "IntegrationArtifactDownload", ResponseBody: ``, TestType: "Negative"}
 | |
| 
 | |
| 		err := runIntegrationArtifactDownload(&config, nil, &httpClient)
 | |
| 
 | |
| 		assert.EqualError(t, err, "HTTP GET request to https://demo/api/v1/IntegrationDesigntimeArtifacts(Id='flow1',Version='1.0.1')/$value failed with error: Unable to download integration artifact, Response Status code:400")
 | |
| 	})
 | |
| }
 |