Profile picture for user m3b

Hello guys, 

In SoftwareAG document "REPORT SCRIPTING - BEST PRACTICES" , it is written in bold in the introduction :

"Completed reports should always be tested on their memory performance and quality"

But how can you , as a report programmer with no access to the Aris server, test the memory performance of a script ? 

Thanks

MB

 

 

by Kay Fischbach
Posted on Mon, 12/19/2022 - 09:14

I'm someone that does have access to the ARIS servers I'm writing reports for and to be honest the access doesn't matter in regards to testing memory performance. The ARIS server does so many things at any given moment that figuring out whether memory/CPU usage spikes stem from your report or some some other component (we also run Aware and ARCM on the same server) is practically impossible.

The way you go about this is think about what your report does from an algorithm point of view and what's going on in between the ARIS server and the database server.

For example, you want to list the names of all object definitions on an ARIS database:

A bad way to go about it (although it's the intitive way) would be:

  1. get the root group of the database
  2. recursively search all object defintions contained in this group (even if you just use the bRecursive flag with a single ObjDefList call on the root group)
  3. iterate through the object definitions and ask for the AT_NAME, attribute of each object

This is bad because

  • the recursive search concerns itself with group structures which don't matter for our task
  • requesting the name attribute object after object leads to an incredible amount of talking between the ARIS server and database server.

The good way to go about this is:

  1. use the database Find method to search for all object definitions
  2. pass that list of object definitions to the database ItemAttrMap method to fetch all required AT_NAME attributes in one go
  3. then either iterate through the object definitions and look up the required attribute via GUID in the HashMap result of the ItemAttrMap, or just iterate through the entries of the ItemAttrMap HashMap directly.

 

If you chech the algorihm time and space complexity, clean up after yourself (release no longer needed references, as described in the best practices document) and attempt to minimize the amount of talking between the ARIS server and database server by using methods that bundle what would be multiple requests into a single request whenever possible, you should have absolutely no problem writing very efficient reports.

 

 

1
by Michel Bénard Author
Posted on Thu, 12/22/2022 - 16:55

Thanks Kay !

0

Featured achievement

Question Solver
Share your expertise and have your answer accepted as best reply.
Recent Unlocks

Leaderboard

|
icon-arrow-down icon-arrow-cerulean-left icon-arrow-cerulean-right icon-arrow-down icon-arrow-left icon-arrow-right icon-arrow icon-back icon-close icon-comments icon-correct-answer icon-tick icon-download icon-facebook icon-flag icon-google-plus icon-hamburger icon-in icon-info icon-instagram icon-login-true icon-login icon-mail-notification icon-mail icon-mortarboard icon-newsletter icon-notification icon-pinterest icon-plus icon-rss icon-search icon-share icon-shield icon-snapchat icon-star icon-tutorials icon-twitter icon-universities icon-videos icon-views icon-whatsapp icon-xing icon-youtube icon-jobs icon-heart icon-heart2 aris-express bpm-glossary help-intro help-design Process_Mining_Icon help-publishing help-administration help-dashboarding help-archive help-risk icon-knowledge icon-question icon-events icon-message icon-more icon-pencil forum-icon icon-lock