mirror of
https://github.com/SAP/jenkins-library.git
synced 2025-01-08 04:21:26 +02:00
6d5fdd41bf
* fix code climate issues * fix code climate issues * Update GitUtils.groovy
45 lines
1.3 KiB
Groovy
45 lines
1.3 KiB
Groovy
import com.sap.piper.GenerateDocumentation
|
|
import static com.sap.piper.Prerequisites.checkScript
|
|
import com.sap.piper.analytics.InfluxData
|
|
|
|
import groovy.transform.Field
|
|
|
|
@Field STEP_NAME = getClass().getName()
|
|
|
|
@Field Set GENERAL_CONFIG_KEYS = []
|
|
|
|
@Field Set STEP_CONFIG_KEYS = []
|
|
|
|
@Field Set PARAMETER_KEYS = [
|
|
/** Defines the name of the measurement which is written to the Influx database.*/
|
|
'measurementName'
|
|
]
|
|
|
|
/**
|
|
* This step is used to measure the duration of a set of steps, e.g. a certain stage.
|
|
* The duration is stored in a Map. The measurement data can then be written to an Influx database using step [influxWriteData](influxWriteData.md).
|
|
*
|
|
* !!! tip
|
|
* Measuring for example the duration of pipeline stages helps to identify potential bottlenecks within the deployment pipeline.
|
|
* This then helps to counter identified issues with respective optimization measures, e.g parallelization of tests.
|
|
*/
|
|
@GenerateDocumentation
|
|
def call(Map parameters = [:], body) {
|
|
|
|
def script = checkScript(this, parameters)
|
|
|
|
def measurementName = parameters.get('measurementName', 'test_duration')
|
|
|
|
//start measurement
|
|
def start = System.currentTimeMillis()
|
|
|
|
body()
|
|
|
|
//record measurement
|
|
def duration = System.currentTimeMillis() - start
|
|
|
|
InfluxData.addField('pipeline_data', measurementName, duration)
|
|
|
|
return duration
|
|
}
|