Skip to content

Commit

Permalink
skip_on_error_failed added. Tests added. Updated Readme.
Browse files Browse the repository at this point in the history
  • Loading branch information
lpezet committed Jun 23, 2019
1 parent 46deb36 commit d40ae53
Show file tree
Hide file tree
Showing 3 changed files with 296 additions and 18 deletions.
39 changes: 34 additions & 5 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -155,6 +155,22 @@ Mods are features of the ETL template. They execute code, download files, import
The idea is to leverage as much as possible of the existing and be as efficient as possible.
For more details, see the [Mods](Mods.md) page.

## Control Flow

Mods can decide whether to **skip** the remaining steps for a given activity, or even terminate (**exit**) the process.
Use cases can be:

* Mod detects that no new data has been found, decides to exit the ETL process.
* Mod detects that data didn't change and decides not to continue the current activity of doing work already done before

It's up to Mods to expose that functionality. For example, the **Commands Mod** expose the following properties:

```yml
skip_on_test_failed: true|false
exit_on_test_failed: true|false
```


## Tags

Tags can be used to make the process more dynamic. You might want your ETL process to start with a step figuring out which files to ingest (e.g. only new ones). And you would want the next step to download those files and only those files.
Expand All @@ -170,14 +186,23 @@ step1:
commands:
orion_pic:
command: printf "orion-nebula-xlarge_web.jpg"
var: file_to_download
step2:
files:
/tmp/orion-nebula.jpg:
source: https://www.nasa.gov/sites/default/files/thumbnails/image/{{ $.step1.commands.orion_pic.result }}
source: https://www.nasa.gov/sites/default/files/thumbnails/image/{{ $.vars.file_to_download }}
```

The tag here is `{{ $.step1.commands.orion_pic.result }}`. It basically refers to the `result` of the step1 command *orion_pic*.
You can see the full JSON of the result of each activity and mod in the [Results](#results) section to help figure out attributes available to use in tags.
The tag here is `{{ $.vars.file_to_download }}`. It basically refers to the `var` of the step1 command *orion_pic*.

The context used in tags is as follows:

```yml
vars:
...vars go here...
env:
...environment variables here from process.env.....
```

Here's another example using tags and making use of the `result_as_json` attribute of the `commands` mod. The `result` of the command will be parsed and stored as JSON instead of a string. This allows us to, for example, use the result as an array to download multiple files. The `files` mod will interpret that array and download multiple files.

Expand All @@ -189,20 +214,21 @@ var template = {
"file_to_download": {
command: "printf '[\"PIA08653/PIA08653~small.jpg\",\"PIA21073/PIA21073~small.jpg\"]'",
result_as_json: true
var: files_to_download
}
}
},
step2: {
files: {
"/tmp/{{ $.step1.commands.file_to_download.result }}": {
source: "https://images-assets.nasa.gov/image/{{ $.step1.commands.file_to_download.result }}"
source: "https://images-assets.nasa.gov/image/{{ $.vars.files_to_download }}"
}
}
}
};
```

In `step2`, the `files` mod is used to specify a dynamic file to download with tags. Each `file_to_download` result, will be downloaded from `https://images-assets.nasa.gov/image/` and stored in `/tmp/`.
In `step2`, the `files` mod is used to specify a dynamic file to download with tags. Each file stores in `files_to_download` variable, will be downloaded from `https://images-assets.nasa.gov/image/` and stored in `/tmp/`.

## Events

Expand All @@ -213,6 +239,8 @@ ETL will emit some events during the ETL process.

## Results

##### *OBSOLETE: rework done, need doc to be updated. Advice is to NOT rely on Mod results, but use the Content with vars & env for tags.*

The ETL `process()` method returns a Promise. Upon success, the data **resolved** will contain the results of the process and each activity.

Reusing the advanced template from the [Tags](#tags) section:
Expand All @@ -225,6 +253,7 @@ var template = {
"file_to_download": {
command: "printf '[\"PIA08653/PIA08653~small.jpg\",\"PIA21073/PIA21073~small.jpg\"]'",
result_as_json: true
var: files_to_
}
}
},
Expand Down
15 changes: 12 additions & 3 deletions lib/commands.js
Original file line number Diff line number Diff line change
Expand Up @@ -161,22 +161,26 @@ ModClass.prototype._exec = function( pParent, pKey, pSpecs, pExecutor, pContext
}

var exec_test = function( pTest ) {
logger.info('[%s] Test for command [%s]...', pParent, pKey);
logger.info('[%s] Testing for command [%s]...', pParent, pKey);
var oTest = '(' + pTest + ') && echo "continue" || echo "stop"';
return new Promise(function( resolve, reject ) {
const data = { error: null, result: null, message: null, exit: false, skip: false, pass: false, _stdout: null, _stderr: null };
pExecutor.exec( oTest, { context: pKey }, function( error, stdout, stderr ) {
var data = { error: error, result: null, message: null, exit: false, pass: false, _stdout: stdout, _stderr: stderr };
data.error = error;
data._stdout = stdout;
data._stderr = stderr;
var func = null;
try {
//console.log('###### Done executing test command...');
if ( error ) {
logger.error('[%s] Test failed for command [%s], exit code = %s, error = %j. Skipping command.', pParent, pKey, error.code, error);
if ( oCmdSpecs['exit_on_test_failed'] ) data.exit = true;
if ( oCmdSpecs['skip_on_test_failed'] ) data.skip = true;
func = reject;
} else {
if ( ! stdout ) {
logger.error('[%s] Unexpected test result (stdout=[%s]). Skipping command %s.', pParent, stdout, pKey );
if ( oCmdSpecs['exit_on_test_failed'] ) data.exit = true;
if ( oCmdSpecs['skip_on_test_failed'] ) data.skip = true;
func = reject;
} else {
if ( stdout.match(/continue/g) ) {
Expand All @@ -190,6 +194,7 @@ ModClass.prototype._exec = function( pParent, pKey, pSpecs, pExecutor, pContext
//reject( stdout );
//var oData = { error: error, exit: false, context: pParent + '..' + pKey };
if ( oCmdSpecs['exit_on_test_failed'] ) data.exit = true;
if ( oCmdSpecs['skip_on_test_failed'] ) data.skip = true;
data.pass = false;
//reject( oData )
func = resolve;
Expand All @@ -198,7 +203,11 @@ ModClass.prototype._exec = function( pParent, pKey, pSpecs, pExecutor, pContext
}
} catch(e) {
data.error = e;
if ( oCmdSpecs['exit_on_test_failed'] ) data.exit = true;
if ( oCmdSpecs['skip_on_test_failed'] ) data.skip = true;
data.pass = false;
func = reject;
//func = resolve;
}
func( data );
});
Expand Down
Loading

0 comments on commit d40ae53

Please sign in to comment.