Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Execute a Python script from a file. This operation differs from executePythonFile by executing the file for every file in the package. This operation has the same support for inputs and outputs available to it as the executePythonFile operation. In addition it has the following variables available with information about a particular file.

File Level Variables With Example

Variable name

Description

Value if File Name (with path) is /XXHR/publisher/APXSOBLX_1.rtf

FILE_PATH

File path of the

partial

package deploy file. (File Name (with path)) on the

partial

package deployment screen.

/XXHR/publisher/APXSOBLX_1.rtf

FILE_NAME

File name of the

partial

package deploy file.

APXSOBLX_1

FILE_PATH_PREFIX

File path, excluding the file name and extension.

/XXHR/publisher

FILE_EXTENSION

File extension on the

partial

package deploy file.

rtf

SOURCE_FILE

Fully qualified location of the file on the endpoint.

Fully qualified path to file being processed. This can be different locations for build and deploy workflow execution as there might be some checkout folder specified for build. See examples below for build and deploy workflow where FILE_PATH is in bold text.

  • /home/oracle/application/localhost/work/846808/840047/temp/

PartialExecute
  • PackageExecute/EBSCustomizations/XXHR/import/XXHR_Second_CP.ldt

  • /home/oracle/application/localhost/work/846808/840059/temp/import/XXHR_Second_CP.ldt

FILE_HASH

The Hash of the file as generated recorded by FlexDeploy.

FILE_SCM_REVISION

The SCM Revision of the

partial

package deploy file.

All file attributes defined on Project Files tab are included as well.

Environment/Instance Properties

...

Project Properties

Property Name

Property Code

Required

Description

Stop On Deployment Error

FDPYTHON_STOP_ON_DEPLOYMENT_ERROR

No

Stop deploying package files if any error occurs. If unchecked all files will be deployed even if one or more files fails. This is for

partial

package operations only. True by default.

Inputs

Input Name

Input Code

Required

Description

File Path

FDPYTHON_INP_FILE_PATH

Yes

File path of the file to run.

Artifacts

This operation delegates the consume/produce artifacts decision to the workflow developer.

Endpoint Selection

This operation delegates endpoint selection to the workflow developer. The workflow editor will default the selection to "All", which selects all available endpoints associated to the environment instanceTarget. Selecting a specific resource will result in selection of endpoints associated to the environment instance Target which have that resource defined.

Endpoint Execution

This operation delegates endpoint execution to the workflow developer. The workflow editor will default to "Any", which will execute on any one of the selected endpoints, which will be randomly picked from selected endpoints or a specific endpoint where previous step may have executed. Changing this value to "All" to will result in execution on all selected endpoints.

Special Considerations

FlexDeploy Properties

FlexDeploy will pass in any Properties normally available in workflows via System Environment Variables.

Example

Property Example
Code Block
languagepytitleProperty Example
import os
​
TEST_INP = ​os.getenv('TEST_INP')

Outputs

User defined outputs – an output must be defined in the workflow editor to be accessible. Within your script use the setOutputs(key, Value) function to set any outputs.

Example

Output Example
Code Block
title
languagepyOutput Example
setOutputs("MY_STRING_OUTPUT","Output result") # output will be "Output result"

Setting Status

The status of the File can be set in your script using several functions available, see the example below. If an exception occurs in your script, the status will be set to Failed. Statuses will only be set when deploying.

Setting the status examples
Code Block
languagepytitleSetting the status examples
setObjectResultStatusSuccess() # Status will be Success
setObjectResultStatusFailed() # Status will be Failed
setObjectResultStatusSkipped() # Status will be Skipped
setObjectResultStatusNotAttempted() # Status will be Not Attempted
setObjectResultStatusIgnore() # Status will be Unknown