e2e_appmon Best Practices checklist
search cancel

e2e_appmon Best Practices checklist

book

Article ID: 33526

calendar_today

Updated On:

Products

DX Unified Infrastructure Management (Nimsoft / UIM) CA Unified Infrastructure Management On-Premise (Nimsoft / UIM) CA Unified Infrastructure Management SaaS (Nimsoft / UIM)

Issue/Introduction

  • e2e_appmon Best Practices checklist items for setting up the e2e machine and recording scripts

Environment

  • UIM (any version)
  • e2e_appmon
  • e2e_appmon_dev probe (any version)

Cause

  • e2e guidance

Resolution

Detailed requirements for running e2e transactions:

  • Dedicated workstation:
No one can RDP/login to the workstation as it needs to run undisturbed. e2e takes over the desktop (console 0/Winsta0). You are able to see/watch your running e2e transaction via remote control software such as VNC/Real VNC. Other remote viewers such as logmein/Lan Manager are not as well tested so we cannot guarantee behavior. You can see/watch the transaction via VNC/Real VNC but you shouldn't have to keep the session open to successfully run the script. As you may know you can determine if the scripts are running successfully via the e2e GUI status.

Do NOT use Remote desktop as it interferes with the interactive session if you login. If yu login and the probe is activated it will disconnect your RDP session.
Since Vista, Windows makes a difference between Windows stations and desktops. The interactive window station, Winsta0, is the only window station that can display a user interface or receive user input. It is assigned to the logon session of the interactive user. So when Windows is logged out or locked or when you disconnect from a Remote session, the session still exists but not the interactive window station. So any interactive script that you try to run will fail. And when you minimize a Remote desktop session, the session is locked and so any interactive script will stop running properly. Note that you can login via RDP to record your synthetic transaction script but you must not leave the user logged in when you're finished - you must logoff the system.
  • Robot:
You must install a Nimsoft Robot on the dedicated transaction workstation/desktop and then deploy the e2e_appmon_dev probe there.
  • Probe:
Use the e2e_appmon_dev probe in all cases (and not just e2e_appmon). This is for convenience since if you have any trouble recording a script on one system, e.g., monitor and you try running it on the 2nd system and it fails for some reason, you can use the script editor to make modifications.  You can do this while you're accessing any system since you have access to the full e2e development workbench with e2e_appmon_dev probe versus just e2e_appmon.
 
  • Screen Resolution:
  • Both systems need to be identical - for example, 1024x768 especially if you are copying image files to other dedicated workstations to run the scripts form a different location. Keep resolution the same on the workstations and within VNC session when recording scripts or any saved image files, e.g., bitmaps not be selectable and will fail when the script is run due to differences in resolution.
  • e2e_appmon_dev user:

    • You will need a login user name and password on the computer where the probe script(s) are run. userid/pwd entered in the profile must be for a domain account or local user account with full access and admin privileges as well as full privileges to the applications that need to be monitored.

  • Application login:
You may choose to create a separate account(s) that you can use to login to the application(s).
  • Once the script/scripts are recorded, you can copy the .src, .lst, and .rob files as well as any .bmp/image files from the system where the scripts were recorded to the other system(s) you want to run the scripts from - other dedicated workstations at other physical locations for instance. The files must be stored in ...e2escripting\scripts. You can create and use a custom probe for that so you can copy the files via drag and drop. Note that later versions of e2e allow you to configure this within the probe.
  • Viewing Scripts:
You can deploy your remote_control probe on the hub/local system (requires VNC server on the workstation/laptop system) OR simply install VNC server on the remote system and VNC client (the viewer) on your primary hub if you want to watch the transactions execute. Some customers choose to use other remote control software such as LAN Manager, TightVNC but RealVNC seems to work best. Note that the old remote_control probe (internally developed) may no longer work with more recent versions of e2e.
  • Security:

Security considerations for highly secured environment: You must keep the workstation desktop 'open' by disabling the screensaver, timeouts, etc. Note that you can use VMware to keep the Guest OS open but keep the physical machine locked. Other considerations for highly-secure environments include removing the monitor/keyboard, locking the rack/physical space.


Other Notes/Best Practices:

  • Internet Explorer is always launched with low-level privileges. It can prevent some menu options in IE7/IE8 to be recorded. In this case, use the keyboard shortcuts. See an example at Internet Explorer keyboard shortcuts in the Help. See other Articles on browser support.

  • An "about blank" page is seen by IE8/IE9 under Windows 7 as a suspicious page. So avoid using StartBrowser("IE","about blank"), prefer to use StartBrowser("IE","www.my_site.com").

  • Pure text capture is not allowed in a web page under IE8/IE9, use WinTask Capture Wizard to capture the object content instead of a rectangle.

  • Never use the Windows Start menu when you record your actions: the programs list in that menu varies from one Windows start to another. When you record your actions and want to start a program, use Shell statement and its wizard. And for ease of use, when you start Recording mode, you are asked if you want to launch a program.

Use ClickOnBitmap (for mouse clicks not correctly executed)
This happens on software where options are not in the menus but in icons. WinTask does not access by object icons.

Two functions for addressing this problem:

    • ClickOnBitmap

         or

    • ClickOnText

ClickOnBitmap

Click on the relevant script line where you want to change the function.

Use the Nimrecorder wizard via the Nimrecorder Functions window.

 

The wizard will walk you through the process automatically generate the correct lines for the script and you can then paste in the function-script lines.

ClickOnBitmap - usage example:

1. Select the browser icon to bring the page with the object into view
 
2. Select Nimrecorder and click the wizard button to open the wizard.
 
3. Position it for full-easy access
 
4. Select browser icon again
 
5. Hover on the Nimrecorder icon and select the open wizard window
 
6. Click Capture to begin...
 
7. Choose the 'Defined area' option in the wizard
 
8. Draw a box around the object using the mouse but don't select any other images or text along with it. Be conservative.
 
9. Save the image using a descriptive name
 
10. Click check and watch if the object is selected using a red box and check the accuracy in the wizard.
 
11. Then click 'Paste into the Script'
 
12. Using the Nimrecorder and/or if the script is only failing when run by the probe, run the script to see if it completes or fails again on the object.
 
13. If the recorder is getting lost due to the window definition captured in the wizard, try truncating the window, for example:
 
Here is the full window captured originally but the object selection ended up failing:
 
'ClickHTMLElement("BUTTON[INNERTEXT='Close X',INDEX=2]")
UseWindow("MSEDGE.EXE|Chrome_WidgetWin_1|Best CD Rates Of August 2024 - Up to 5.25% | Bankrate - Profile 1 - Microsoft​ Edge",1)
ClickOnBitmap("C:\Program Files (x86)\Nimsoft\e2e_scripting\scripts\CaptureX.bmp", left, single,
InArea(3654,679,156,141))
 
and here the window has been manually truncated which allowed it to work as expected and select the object.
 
'ClickHTMLElement("BUTTON[INNERTEXT='Close X',INDEX=2]")
UseWindow("MSEDGE.EXE|Chrome_WidgetWin_1|Best CD Rates Of August 2024 - Up to 5.2",1)
ClickOnBitmap("C:\Program Files (x86)\Nimsoft\e2e_scripting\scripts\CaptureX.bmp", left, single,
InArea(3654,679,156,141))
 

Browser support

- In e2e_appmon_dev v 2.0 or higher, you can use IE10/11
- Chrome version 32
- Firefox (any version starting at version 10 or higher)
- MS Edge (e2e_apmon v3.01 or higher)
- WTBho add on may be running in limited mode and can’t access the DOM (document object model) This can disable the proper functionality for text synchronization.

For any errors encountered during script execution check Articles.

According to WinTask Support note that since Windows 7, you can no longer use Pause and UseWindow when working on web pages.


OCR recognition: Even if it works for a while it can stop working...

This function's unreliability lies within WinTask itself or due to idiosyncrasies of Windows environments and is NOT reliable/consistent based on my experience in he field and in testing. Use either ClickOnBitmap or Sync on Image function instead.

Also note that as of the latest WinTask version, you cannot use "Wait for text" as it is no longer useable. As per the Help file in:

C:\Program Files\Nimsoft\e2e_scripting\HtmlHelp\default.htm

In the Remarks section it states:

"If the text to search is in a new window, prefer UseWindow function to wait for this new window (and so new text in this new window). Do not use a Pause until text to detect that a web page has finished to load, a UsePage is enough. Note too that within Internet Explorer, only a pause until OCR text can be used."

For examples search using the Navigation menu on the left side of your browser:

Capturing Data in a Web Page

or

Capturing Data Using OCR

and

'Wait for Image' or even Wait for OCR Text example is available - just search on Wait for Image and note that the font is a bit hard to see on the left-side since its blue on blue.

Other:
See also nimWaitForWebContents in the Help file if you want to include that as a checkpoint within the NimRecorder script enabling the e2e_appmon probe to measure intermediate times in the process in addition to the total runtime of the script.

Other script example:
captured_string$ has the text captured from the indicated cell. Then an if-then-else statement can help as per below.

'UsePage("Cisco Unified CCX Serviceability")
ret = CaptureHTML("DIV[CONTENT='SHUTDOWN', INDEX='1']",captured_string$)

If captured_string$ = “SHUTDOWN” then
<generate alarm, do whatever else>
nimEnd()
end()
endif

'UsePage("Cisco Unified CCX Serviceability")
ret = CaptureHTML("DIV[CONTENT='PARTIAL SERVICE', INDEX='1']",captured_string$)

If captured_string$ = “PARTIAL SERVICE” then
<generate alarm, do whatever else>
endif

Your script continues from here…

Additional Information

WinTask Support

You can access script assistance for WinTask-specific scripting issues at [email protected]