1
0
mirror of https://github.com/SAP/jenkins-library.git synced 2025-01-18 05:18:24 +02:00
Marcus Holl db5022a4ff New Scenario Step: SAP UI5 on SAP Cloud Platform (#388)
This scenario builds a UI5 app and deploys it to SAP Cloud Platform (neo).
2019-01-15 13:32:01 +01:00
..

Create a Pipeline for SAP UI5 or SAP Fiori on SAP Cloud Platform

Create an application based on SAP UI5 or SAP Fiori and deploy the build result into an SAP Cloud Platform account in the Neo environment.

This document describes a scenario step, which means that it combines various different steps to create a complete pipeline.

Prerequisites

  • You have installed the Java Runtime Environment 8.
  • You have installed Jenkins 2.60.3 or higher.
  • You have set up Project “Piper”. See README.
  • You have installed the Multi-Target Application (MTA) Archive Builder 1.0.6 or newer. See SAP Development Tools.
  • You have installed Node.js including node and npm. See Node.js.
  • You have installed the SAP Cloud Platform Neo Environment SDK. See SAP Development Tools.

Project Prerequisites

This scenario step requires additional files in your project and the execution environment on your Jenkins instance. On the project level, provide and adjust the following template:

File Name Description
.npmrc This file contains a reference to the SAP NPM registry (@sap:registry https://npm.sap.com), which is required to fetch dependencies to build the application. Place it in the root directory of your project.
mta.yaml This file controls the behavior of the MTA toolset. Place it in your application root folder and adjust the values in brackets with your data.
package.json This file lists the required development dependencies for the build. Add the content to your existing package.json file.
Gruntfile.js This file controls the grunt build. By default the tasks clean, build, and lint are executed. Place it in the root directory of your project.

Context

In this scenario step, we want to show how to build an application based on SAP UI5 or SAP Fiori by using the multi-target application (MTA) concept and how to deploy the build result into an SAP Cloud Platform account in the Neo environment. This document comprises the mtaBuild and the neoDeploy steps.

This pipeline in Jenkins Blue Ocean

Example

Jenkinsfile

Following the convention for pipeline definitions, use a Jenkinsfile which resides in the root directory of your development sources.

@Library('piper-lib-os') _

fioriOnCloudPlatformPipeline script:this

Configuration (.pipeline/config.yml)

This is a basic configuration example, which is also located in the sources of the project.

steps:
  mtaBuild:
    buildTarget: 'NEO'
    mtaJarLocation: '/opt/sap/mta.jar'
  neoDeploy:
    neoCredentialsId: 'NEO_DEPLOY'
    neoHome: '/opt/sap/neo-sdk/'
    account: 'your-account-id'
    host: 'hana.ondemand.com'

Configuration for the MTA Build

Parameter Description
buildTarget The target platform to which the mtar can be deployed. Possible values are: CF, NEO, XSA
mtaJarLocation The location of the multi-target application archive builder jar file, including file name and extension.

Configuration for the Deployment to SAP Cloud Platform

Parameter Description
account The SAP Cloud Platform account to deploy to.
host The SAP Cloud Platform host to deploy to.
neoCredentialsId The Jenkins credentials that contain the user and password which are used for the deployment on SAP Cloud Platform.
neoHome The path to the neo-java-web-sdk tool that is used for the deployment.

Parameters

For the detailed description of the relevant parameters, see: