Testing a script
The scripting application now has a Test button to help test the script that you authored.
You can use Test to prepare the test data and execute the script right from the test dialog.
All the logs would be printed out in the Process Log text area without enabling any logging as long as the service
variable was used for the log.
In cases where the script needs an MBO for the test, the dialog provides a way (Object Path
) to select the MBO for testing the script. The following sample
way shows how to set the object path.
ASSET[assetnum='SPFN0001']
Note that if you had set the path value to just ASSET
, it would have created a new MBO for the Asset and used that for this script.
This selects an asset with assetnum SPFN0001 and uses the MBO for the mbo
variable in the script context.
This can be leveraged for testing Object or Attribute or Action or Condition Launch point scripts.
The dialog allows you to set attribute or value pairs to prepare the MBO for the test using the `Set Attribute Value’ table.
The process makes a best attempt to not commit the modified MBO, but in certain cases this is unavoidable. For example, in cases where the event is after a commit, the MBO is already committed.
For other cases, the script code itself might initiate a commit. The following screen shot showcases some of the test functionalities.
For tesing object init event:
data:image/s3,"s3://crabby-images/499d6/499d6bed71c68d95f412c749a7dff9eb21fde740" alt="Object Init Event Object Init Event"
Note that the resulting MBO is serialized and presented in the Data field of the dialog. This helps you to validate when the the script execution resulted in the right state of the MBO.
For testing “On Add” object events:
data:image/s3,"s3://crabby-images/e6d4a/e6d4a308563d766afee76971a088f885fba4a5c4" alt="Object on add Event Object on add Event"
As apparent you set values: ASSETNUM TESTADD10 ASSETTYPE FLEET
This results in an error because ASSETNUM and ASSETTYPE mismatch - as shown in the screen shot.
The following screenshot is when there is no error thrown:
data:image/s3,"s3://crabby-images/fc0b8/fc0b81996ce96799c63fb4c9f6ea03e3d7209cf0" alt="Object on add Event Object on add Event"
The following example is from app validate event:
data:image/s3,"s3://crabby-images/19554/19554941655e386f09cb093ccbf396d0703662d3" alt="app validate event app validate event"
Object path: ASSET Set values: ASSETNUM TESTVAL1 ASSETTYPE FLEET Result: Error is thrown because ASSETNUM and ASSETTYPE mismatch
Can Add Event
The following screen shot shows the Can Add Event
in which you select a PO which does not have a vendor and attempt to add a POLINE, using the object path notation to invoke the script.
data:image/s3,"s3://crabby-images/a8efe/a8efeb743dea6928de0e6e7280f34e2dfb88dc5e" alt="Can Add Event Can Add Event"
Object path: PO[ponum=‘1056’]/POLINE Result: Error is thrown because PO do not have vendor
Can Delete
The following screenshot shows the Can Delete Event
test:
data:image/s3,"s3://crabby-images/12567/125677880d86908ce46ea6071e4d04f1727f30f9" alt="Can Delete Event Can Delete Event"
Object path format: ASSET[assetnum=‘7500’] Result: Error is thrown of ASSETTYPE is FLEET
Adding setup logic for virtual (aka Nonpersistent) MBOs on setup:
data:image/s3,"s3://crabby-images/47422/4742202e4febdcb69b23560a4694dbfd18f62c06" alt="Setup Event Setup Event"
Object path format: ASSET[assetnum=‘ASSET1’ and siteid = ‘BEDFORD’]/ASCHANGESTATUS Result: Status set BROKEN and MEMO set to Test Broken Note: property mxe.script.callsetuponinit need to be set to 1
Testing OBJECTNAME.NEW script:
data:image/s3,"s3://crabby-images/3fc26/3fc26d2b07eacc0f6fc35d16b53da417365df4db" alt="Object new Event Object new Event"
Object path format: ASSET Result: EQ1 set to TEST EQ1
Testing OBJECTNAME.DUPLICATE script:
data:image/s3,"s3://crabby-images/8d4bd/8d4bd718cb11f90aeef6223156d58e03993616ad" alt="Object dup Event Object dup Event"
Object path format: ASSET[assetnum=‘1001’ and siteid=‘BEDFORD’] Result: ASSETNUM set to null
Testing Attribute validate event:
data:image/s3,"s3://crabby-images/0e4fb/0e4fb67e8659f0c288b325eacd549bd76c624748" alt="Attribute validate Event Attribute validate Event"
Object path format: ASSET Attribute values: ASSETNUM ATTRTEST1 PURCHASEPRICE 300 Result: Some error is thrown because PURCHASEPRICE > 200
Testing Attribute action event:
data:image/s3,"s3://crabby-images/1b4e6/1b4e62aa93aceac81b977586bcebc1d2e6229cab" alt="Attribute action Event Attribute action Event"
Object path format: ASSET Attribute values: ASSETNUM ATTRAC1 PURCHASEPRICE 100 Result: EQ7 set to 50
Testing Attribute init event:
data:image/s3,"s3://crabby-images/10815/108156306c8e9de68fd994b13a4ae1332510fade" alt="Attribute init Event Attribute init Event"
Object path format: ASSET[assetnum=‘1001’] Result: EQ2 set to ASSETNUM (1001)
Testing lookup scripts:
data:image/s3,"s3://crabby-images/55dfe/55dfe7249762789522884010d27dc9da733b98b9" alt="lookup Event lookup Event"
Object: ASSET Attribute: EQ11 Object path format: ASSET[assetnum=’ASSET1’] Result: Values for lookup will be from ALNDOMAIN PHONETYPE
Object Structure Script Processing - Inbound:
Function: beforeProcess(ctx)
data:image/s3,"s3://crabby-images/abcc7/abcc78c730272728b0f2100989732699aeb78344" alt="before process os Event before process os Event"
Use the “select file” option to select a xml or json file:
Test XML: MXITEM1.XML Test JSON: MXITEM1.JSON Result: Transaction is skipped for LOTTYPE=NOLOT
Object Structure Script Processing - Inbound:
Function: mboRules(ctx)
data:image/s3,"s3://crabby-images/366c0/366c01df8cfe0c71db2b8af7ea2bb2975440f787" alt="os mbo rules os mbo rules"
Test XML: MXINVISSUE1.XML Test JSON: MXINVISSUE1.JSON Result: Transaction is skipped for ISSUETYPE=RETURN
Testing object structure inbound:-Functions: beforeMboData(ctx) and afterMboData(ctx)
data:image/s3,"s3://crabby-images/9f347/9f347fc9f3b65aa29d72cb62b76e2ba41a897bcb" alt="beforembodata beforembodata"
Test XML: MXITEM2.XML Test JSON: MXITEM2.JSON Result: Set COMMODITYGROUP based on HIERARCHYPATH
Testing Object structure inbound function: changeStatus(ctx)
data:image/s3,"s3://crabby-images/ce932/ce932f2ac4eb4834eddce686aef81f5cf1a01817" alt="changestatus changestatus"
Test XML: MXITEM3.XML Test JSON: MXITEM3.JSON Result: Change Status with MEMO
Object Structure Script Processing - Outbound
data:image/s3,"s3://crabby-images/ece00/ece001fa264b34fa70aa0f87e0a71863b2993345" alt="os out os out"
Object path format: PO[ponum=‘1002’] Result: Set description Skip POLINE without ITEMNUM Skip TAX fields if TEXED is false
Object Structure Query:
data:image/s3,"s3://crabby-images/f4739/f47391f0d9eb04725515017c765bca36e3ce5a08" alt="os query os query"
Name: OSQUERY.MXAPIWO.EMXWOFILTER Object path format: WORKORDER Parameters: ASSETNUM 11200 STATUS WAPPR Result: Where clause applied to MboSet (assetnum=‘11200’ and status = ‘WAPPR’)
Object Structure Actions:
data:image/s3,"s3://crabby-images/5ab60/5ab601391a657ccea995192fbfbcbd685ec8a3c9" alt="os actions os actions"
Name: OSACTION.MXAPIASSET.SETPRIORITY Object path format: ASSET Parameters: ASSETNUM 11200 STATUS IT Result: Sets priority based on the ASSETTYPE
Event Filters For Publish Channel:
data:image/s3,"s3://crabby-images/cc675/cc675f1f42da5c06b1d5ea4ba25bef1591141b2c" alt="Event Filter Event Filter"
Name: PUBLISH.MXASSETINTERFACE.EVENTFILTER Object path format: ASSET Parameters: ASSETNUM 11200 STATUS IT Result: Sets priority based on the ASSETTYPE
Exits for Publish Channels External Exit:
data:image/s3,"s3://crabby-images/e8771/e8771481694e8960219860783b4477162a18a7de" alt="Publish Exits Publish Exits"
Name: PUBLISH.MXASSETINTERFACE.EXTEXIT.OUT Object path format: ASSET[assetnum=‘1008’]
Result: Set description to status if status is OPERATION
Exits for Publish Channels User Exit Before:
data:image/s3,"s3://crabby-images/e8771/e8771481694e8960219860783b4477162a18a7de" alt="Publish Exits Publish Exits"
Name: PUBLISH.MXASSETINTERFACE.USEREXIT.OUT.BEFORE
Test XML: MXASSET1.XML Test JSON: MXASSET1.JSON Result: Skip transaction if STATUS=BROKEN
Exits for Publish Channels User Exit After:
data:image/s3,"s3://crabby-images/c071b/c071babd1f5c2dfa21dbbc08ec363d5155e4c199" alt="Publish Exits Publish Exits"
Name: PUBLISH.MXASSETINTERFACE.USEREXIT.OUT.AFTER
Test XML: MXASSET1.XML Test JSON: MXASSET1.JSON Result: Display STATUS from IR record and EQ3 (set in before exit) from ER record
Enterprise service External Exit script:
data:image/s3,"s3://crabby-images/ee3ee/ee3ee4bfc9d9174ee29e4d12375e7499b6bf9d8a" alt="Ent Ext Exit Exits Ent Ext Exit Exits"
data:image/s3,"s3://crabby-images/7c362/7c362e8536a091f70d612699b1f7e8f5ff87d874" alt="Ent Ext All Exit Exits Ent Ext All Exit Exits"
Name: SYNC.MXITEMINTERFACE.EXTEXITIN
External System: EXTSYS1 Test XML: MXITEM1.XML Test JSON: MXITEM1.JSON Result: Skip transaction if LOTYPE = NOLOT Skip transaction if ITEMNUM is null Set description to ITEMNUM
Invoke Channel Scripting
data:image/s3,"s3://crabby-images/c4d91/c4d91d2c4e871b7718318453933907dda8fcb09b" alt="Invoke Channel Exit Invoke Channel Exit"
Name: INVOKE.ZIPCHANNEL.USEREXIT.OUT.AFTER Language: js New/Existing: New Object path format: PERSON Complete process: TRUE Attribute values: PERSONID TEST5 CITY BOSTON Result: Set STATEPROVINCE and POSTALCODE
Endpoint Scripting
data:image/s3,"s3://crabby-images/f9cb2/f9cb2746aae7250ddf4981d2f0529c278c781ddf" alt="Endpoint Script Endpoint Script"
Name: TESTENDPOINT Language: Python Test Script Type: ENDPOINT Test XML: MXITEM1.XML Test JSON: MXITEM1.JSON Result: Display payload Display script name from metadata
Condition Launch Point
data:image/s3,"s3://crabby-images/ee479/ee479bdc0490bfac9fc96ad767d04665179cf61c" alt="Condition Script Condition Script"
Name: SUMCOST Language: Python Where clause: assetnum = ‘11200’ Result: Return True of sum of SPAREPART QTY > 10 Return False of sum of SPAREPART QTY < 10
Action Launch Point
data:image/s3,"s3://crabby-images/66ff1/66ff107243bf0cd6d806c0fda3ac61b72fcb3c25" alt="Action LP Script Action LP Script"
Name: CACLMETER Language: Python Object path: ASSET[assetnum = ‘11430’] Result: Set EQ7 to ASSETMETER.OLDREADING
REST api
data:image/s3,"s3://crabby-images/c8ef3/c8ef32b90cd3623af97e7d90f427984d29ca9334" alt="REST Script REST Script"
Name: INVOKEREST Language: Python Query parameters: personid = ‘LIBERI siteid = ‘FLEET’ Result: Throw exception if site is invalid SET LOCATIONSITE to siteid
Role Scripting
data:image/s3,"s3://crabby-images/6a0f1/6a0f128d53bc68d75071fa2386fac817d70ea4b3" alt="Role Test Role Test"
Name: MAXROLE.EMXROLE Language: Python Where clause: assetnum = ‘11430’ Result: Check for PERSONGROUP TIER1 and TIER2
MXException script
data:image/s3,"s3://crabby-images/4329c/4329ca3a8ba7e2ee32e2ca55f29db46a987cb94a" alt="MXException Test MXException Test"
Result: Display original and additional message
Formula script
data:image/s3,"s3://crabby-images/1ca47/1ca47a4a6899c477d2d74effc1f7a713682d0845" alt="Formula Test Formula Test"
Name: STANDARDDEV Language: Python New/Existing: Existing Object path format: ASSET[assetnum=’11430’] Properties: param[0] = “ALLWO” param[1] = “estlabcost” Result: Display standard deviation