Skip to main content

Performance Testing of Documentum

Before starting details of how to do performance testing on Documentum I will try share a basic of Documentum so you can get an idea why we need a different approach while doing performance testing on it.

What is Documentum?
Documentum is content management software that provides management of document content and attributes. Documentum product is a three-tier, client-server system built on top of a relational database.

Documentum components comprise the following:
·         Content Server - Manage access to the metadata stored in the relational database and the  Content files, usually stored in the file system
·         Webtop/Wdk Server - J2EE-based web application framework


Behavior behind the scene:
An applet is invoked at the client side when a file within the docbase is accessed and while files are imported into a docbase.
Applet/UCF client being client side Java application requires a JVM for each user and it cannot be run in Web/Http virtual user of Load Runner.




Performance Testing of Documentum:
I have performed load testing of Documentum using LoadRunner as well as RPT.
But approach in both is different. EMC has done well work while giving support for performance testing.


Correlation for Documentum:
As we know in performance testing Correlation is the main activity. It is always good practice to perform manual correlation.
But while doing performance testing of documentum, it is recommended to perform Auto Correlation.
To perform auto correlation a file called “Documentum.cor” or “EMC_docuementum.cor” (which defines basic correlation rules) needs to be imported. During auto correlation all the Request IDs, Reload IDs, Serial Numbers & UCF Request Keys get correlated. This common approach in both tools. Now I will share steps for LoadRunner tool and in next post related to RPT.

Performance Testing of Documentum using LoadRunner:

Documentum is a web based application but scripting in LoadRunner cannot be done the conventional way of using Web (HTTP/HTML) protocol. Invocation of applets and JVM startup for each user requirement makes scripting difficult in LoadRunner.
The solution for this problem was brought about by LoadRunner and EMC and they introduced WebTop Development kit which contain various dll, correlation suits, invoker.bat  and files which can be used which creating and executing the script.
Important Points before starting the testing:
1.      Ask your Documentum admin to provide you the winsuite installation: set up content server repository on the loadgenerator
2.      Get details of docbroker port and hostname
3.      Get Eclispe  on same system : this will help us verify compilation errors
4.      Include JARs which developer would include in his code
5.      server monitoring aspects - same old same old - get rstat daemons running on the Content\DB server
6.      Need to use The Java Vuser protocol

After this we can record our scripts and using auto correlation file, script will be modified. We can still correlate session id and UID variable manually.


Executing Scripts in Load runner:
For executing the recorded scripts for multiple users first we need to setup Load generator system in following manner:

1.       Ensure at least one manual content transfer has been done to the load generator machine. It will download the UCF client binaries such as UCFWin32JNI.dll, ucf-client-impl.jar, ucf-client-api.jar into the folder
C:\Documents and Settings\<windowsusername>\Documentum\ucf\<hostname>\shared\bin

2.       The “PATH” Environment Variable needs to be set to UCF binary folder. UCF Client invoker will fail if path is not set properly and also check for java installation& its path settings.


3.       UCFInvokerTool.zip has to extract and all “.renamed” extensions from filenames must be removed.
4.       All the paths in the startInvoker.bat file has to be updated to match the working environment
5.       The path settings in ucf.client.config.xml file have to be checked.
6.       The path to the DLL has to be updated in the vuser_init section of the sample scripts.
7.       The invoker can be started using “startInvoker.bat”.

We require also more modification at Script level:

1.       getUID function: Created by EMC which need to use in LR script


2.      Replace hardcoded UID with correlation.

EMC also provides support documents for script modification which is very useful if you are aware of Documentum structure and behavior.

Please note that WebTop Development kit has provided by EMC support. They have done well done job for support in performance testing.

Happy Testing!!!!!

Comments

  1. Hi Seema,
    Very nice overview of using LR with Documentum. You mentioned you have done the same using RPT. Can you share your experience on how to setup RPT and what protocol to use.
    thanks

    ReplyDelete
    Replies
    1. @Shammy,
      For performing performance testing on Documentum with RPT is much easier .

      What you require for it as below:
      1. Get a license and correlation file from BSD/EMC team (They own the Documentum)
      2. Install the license of BSD
      3. Apply to RPT
      4. Disable the Automatic correlation in RPT tool
      5. Record the script using HTTP protocol
      6. Right click on script and select "Correlation" option


      Now you are ready for performance testing.

      Delete
    2. Is possible to record using another protocol, not java Vuser

      Delete
  2. Thank you Shammy. I will share the post on it.

    ReplyDelete
  3. Is possible to record using another protocol, not java Vuser

    ReplyDelete
  4. It's remarkable to pay a visit this site and reading the views of all friends regarding this article, while I am also eager of
    getting familiarity.

    ReplyDelete

Post a Comment

Popular posts from this blog

Pacing Calculation in Load runner

                                        Today i will share my understanding on “Pacing”. Usually people take pacing as think time only. I will try to explain both terms first Think time and Pacing, both are a kind of “wait” or “delay” in terms of time but still both differ from each other. Think time: Think Time is the time or delay which user can take between two actions For example, User opens a URL by pressing “Enter” and login page appears but to enter user name or password user is taking some time like copying from other place or remembering it or something like that. This wait or delay we can term as think time in load runner. Think time can be inserted by user in script or captured by tool itself Whereas, Pacing is the delay between two iterations of test. We can give pacing time by using “Runtime Settings” of load runner tool. We can calculate Pacing/Think...

MI Listener in LoadRunner

In a regular LoadRunner load test scenario (not over a firewall), The Controller has direct access to the LoadRunner agents running on remote machines. This enables the Controller to connect directly to those machines. When running Vusers or monitoring applications over a firewall, this direct connection is blocked by the firewall. The connection cannot be established by the Controller, because it does not have permissions to open the firewall. LoadRunner solves this problem by using a communication configuration based on HTTPS or secured TCP/IP. This configuration uses the standard SSL port on the firewall (port 443). The MI Listener is a component that serves as router between the Controller and the LoadRunner agent. When the LoadRunner agent connects to the MI Listener, the MI Listener keeps a listing of the connection to the agent using a symbolic name that the agent passed to it. When the Controller connects to the MI Listener, it communicates to the MI Li...

Configuring Vuser, Controller and Load Agent using MI Listener

          Configuring Vuser, Controller and Load Agent using MI Listener To Configure Vuser, Controller and Load Agent using MI Listener , make sure MI listener is running Running Vusers over a firewall : To set up your system to run Vusers over a firewall Ø   On each load generator machine that will be running over a firewall, configure the LoadRunner agent to communicate with the MI Listener. Ø   Configure the Controller machine to recognize the load generator and MI Listener machines. Configuring LoadRunner Agents over the Firewall Ø   Stop the LoadRunner agent by right-clicking its icon in the system tray and selecting Close. Ø   Run Agent Configuration from Start > Programs > LoadRunner > Advanced Settings, or run \launch_service\bin\AgentConfig.exe. Ø   Select the Enable Firewall Agent check box, and then click Settings. Ø   The Agent Configuration dialog box opens. Ø ...

Mobile Web(Http/HTML) Protocol IN Loadrunner

Today i will share my learning on performance testing performed on mobile application. We can use Load runner tool for mobile based applications. HP LoadRunner 11.50 has two new protocols for helping to record mobile applications: ·          Mobile Application – HTTP/HTML : recording scripts at the transport level for both browser-based mobile applications and native mobile applications, that communicate with their servers over HTTP ·          Mobile TruClient: recording scripts for browser-based mobile applications through the browser-based user interface.  This protocol is based on Ajax TruClient, using a browser modified to emulate the mobile browser. These protocols are independent of mobile operating systems, so will work on different versions of iOS, Android, Windows Mobile, WebOs (Palm), Blackberry, etc. Let’s see the picture behind the scene: We can run the p...

Run Vugen script using command prompt

We can also run or replay our Vugen script using Dos Command Prompt (CMD) " LoadRunner install dir" \bin\mmdrv.exe -usr "path to .usr file" Note: LoadRunner install dir: Path of directory where Loadrunner has installed Hope this will help you guys. Happy Exploring!!!!

CITRIX Error in Load runner: Failed to get window size, wrong format.

Citrix based Applications are now days very popular. We can perform load testing on Citrix based application using load runner tool also. Quick tips for Citrix applications: 1. You can use "HTTP" and "Citirix" protocol together in load runner. 2. Try to keep windows in full screen mode. Some time while replaying the recorded script can give some error too. one of the error i have encountered was: Error: Failed to get window size, wrong format. Unable to detect client version. Warning: Extension CitrixClientImpl.dll reports error -1 on call to function ExtPerThreadInitialize Error: Vuser failed to initialize extension CitrixClientImpl.dll Resolve the issue: 1. Save the script after recording. 2. Go to Script directory and look for "default.cfg” file 3. Open the file into edit mode 4. Add below mentioned code in file and save it [CITRIX] DesktopColors=32 Colors=True Color (24 bit) Enctyption=128 Bit Window=1024 x 768 ...

Heap Dump : how to generate heap dump

Heap dump is important when it’s come to performance testing. Let’s start with what is heap in an application. Heap: Heap is dynamically collective amount of data /memory in partially binary sorted tree structure. But we need to loop up on heap in term of memory. Heap is part of memory where memory for objects assigned dynamically. Heap dump : Heap Dump is snapshot of memory at certain point which contains below mentioned information: -information of java objects -information of java classes or we can define as A heap dump is a textual or binary representation of the Java heap which is usually written to a file.   Heap dump is always helpful to analyze memory leak or high usage of memory of java application. There are various tools which help us to generate the heap dump. We can also generate heap dump without using tools. What we require is JVM (Java Virtual Machine)on system. There are various vendors for JVM but let’s concentrate on Sun JVM. ...

Software being installed: Cucumber Eclipse Feature 0.0.23.201811220126 Missing requirement: Cucumber Editor 0.0.23.201811220126

Error:    cucumber.eclipse.feature.feature.group 0.0.23.201811220126 While installing cucumber plugin for eclipse, sometimes we faced below mentioned error Error : Cannot complete the install because one or more required items could not be found.   Software being installed: Cucumber Eclipse Feature 0.0.23.201811220126 (cucumber.eclipse.feature.feature.group 0.0.23.201811220126)   Missing requirement: Cucumber Editor 0.0.23.201811220126 (cucumber.eclipse.editor 0.0.23.201811220126) requires 'osgi.bundle; org.eclipse.pde.ui 3.5.0' but it could not be found   Cannot satisfy dependency:     From: Cucumber Eclipse Feature 0.0.23.201811220126 (cucumber.eclipse.feature.feature.group 0.0.23.201811220126)     To: org.eclipse.equinox.p2.iu; cucumber.eclipse.editor [0.0.23.201811220126,0.0.23.201811220126 ] Solution: Clear your eclipse cache with below steps: Open Eclipse and navigate to the ...

Record scripts on mobile applications in LoadRunner

Record scripts on mobile applications in LoadRunner : As LoadRunner 11 in Patch 3, Mobile App (HTTP/HTML) protocol added which can help us to record scripts of mobile apps. There are three recording options in the recording Wizard: 1.Record and Analyze Traffic - Use mobile sniffer agent to capture traffic and then analyze. This allows Vugen to connect to the mobile agent on the server or localhost and carry out the business process for recording. 2. Analyze Traffic - Analyze traffic using existing capture file to generate script. This allows Vugen to scan a pre-captured network traffic (WinPcap) file and generate the code based on the traffic. 3. Record Emulator - Record script using a mobile device emulator. This allows Vugen to record an emulator installed on the Vugen machine. With this option, you need to verify that you are able to bring up the emulator and navigate to a URL outside of Vugen to make sure the emulator settings are correct.