Versions Compared

Key

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

This MettleCI capability takes a specified set of input ISX files and modifies them based on instructions provided in a supplied YAML Recipe file. The first public interface to the Transmuter function will be made This feature is available from the MettleCI command line.

Command

From the MettleCI Command Line, run the asset-transformer transform command, supplying values for these parameters:

  • isx: path to an ISX archive or directory containing archives

  • user: DataStage user to credit changes to

  • transforms: path to a YAML-format Recipe file describing transforms the changes to perform

Example

Assume the following:

  • getmsg.isx contains a parallel routine Parallel Routine definition with containing the target filepath string we wish to be replacedreplce

  • u915264 is the valid datastage DataStage user that should be credited we wish to credit for the last save in the routine definition

  • Recipe file changeLibFileInfo.yml contains:

    Code Block
    - transform: SearchAndReplace

...

  • 
      xpath: /[contains(name(),'DSRoutineSDO')]/@modulePath

...

  • 
      searchString: /usr/local/dstage/[A-Za-z0-9_]/Routine/([A-Za-z0-9_]*).o

...

  • 
      replaceString: /usr/local/dstage/cplusplus/routines/$1.so

Then executing Executing the following command from a DOS command promptprompt…

Code Block
$> mettleci asset-transformer transform
  -isx C:\Users\

...

u915264\transmuter\getmsg.isx 
  -user

...

 u915264  
  -transforms changeStaticLibToDynamicLibFilename.yml

will …will result in this output:

Code Block
C:\Users\u915264\transmuter>mettleci asset-transformer transform -isx C:\Users\u915264\transmuter\getmsg.isx -user u915264 -transforms changeStaticLibToDynamicLibFilename.yml
MettleCI Command Line (build 118)
(C) 2018-2020 Data Migrators Pty Ltd
----------------------------------
ISX File: C:\Users\x247317au915264\transmuter\getmsg.isx
----------------------------------
Applying 'SearchAndReplace' transform to asset 'getmsg'
Replaced '/usr/local/dstage/TPODS/Routine/get_msg_code.o' with '/usr/local/dstage/cplusplus/routines/get_msg_code.so'
C:\Users\u915264\transmuter>

Note the message showing Notes:

  • The example uses a single ISX but any valid filepath (a directory, a wildcard expression, etc) can be used and all ISX files found that way will be processed

  • In this example the message shows the target and replacement strings. Other transforms

...

  • will produce different, transform-specific output.

See also

Child pages (Children Display)