Sunday, February 23, 2014

How jmeter scripts be executed over specific time period.

Think that you need to execute performance test for 1 hour.

Steps:

One possible way is use “Scheduler” in thread group.


Once you tick on “scheduler”, start time and end time can be given.
For example:
Start time: 2014/02/20 09:00:00
End Time: 2014/02/20 10:00:00

However, using scheduler is a overhead when you have to repeat the test several times, it should be edited again and again.

There is another way to execute jmeter scripts over particular time period by overcoming modification overhead.

Use "Ultimate thread group".
For that use have to download additional plug-in called “JMeterPlugins-Standard-1.1.3” and place it in lib/ext folder.
  1. Download stnadard plu-in (JMeterPlugins-Standard-1.1.3.zip) from http://jmeter-plugins.org/downloads/all/
  2. Unzip the downloaded file
  3. Navigate to lib/ext and copy “JmeterPlugins-Standard.jar” and place it on jmeter distribution lib/ext folder
  4. restart jmeter if it already started.
  5. On the jmeter UI, now you can add “ultimate thread group”
  6. Click on “Add Row”
Now you can define how long the test should be executed by using the “Hold Load for, sec” option.

For one hour test explained above you can use the below settings:



Note: No need to modify this script over and over again when you want to run it for several times. 















View Jmeter summary in non-GUI mode


I recently had to execute jmeter scripts on non GUI mode and wanted to view results while the test is executing.

Usually, on UI mode we can view the summary from “Summary Report” option.


But, when the test is executing through non GUI mode, usually we can not view the result rather waiting until the results written to particular file.

Below example shows how the jmeter scripts execute on non GUI mode.

 ./bin/jmeter.sh -n -t ~/jmeter/scripts/test1.jmx -l ~/jmeter/results/results1.jtl  

Note: test1.jmx file is the jmeter test plan. Result1.jtl is the result file generated.

When the test execution happening over long time and we need to view results during that period. For that we can use “Summariser” option.

Summariser is a special listener that only applies to non GUI mode. 
This option is provided in jmeter.properties file. (Actually $jmeter_home/bin).

jmeter.propertie contains special section for summariser options

 #---------------------------------------------------------------------------  
 # Summariser - Generate Summary Results - configuration (mainly applies to non-GUI mode)  
 #---------------------------------------------------------------------------  
 #  
 # Define the following property to automatically start a summariser with that name  
 # (applies to non-GUI mode only)  
 #summariser.name=summary  
 #  
 # interval between summaries (in seconds) default 3 minutes  
 #summariser.interval=180  
 #  
 # Write messages to log file  
 #summariser.log=true  
 #  
 # Write messages to System.out  
 #summariser.out=true  

What you need to do is uncomment the 4 options.

summariser.name=summary
summariser.interval=180 : Here you can define any time interval to display the results.
summariser.log=true

summariser.out=true

Now execute the same command and see the summary during test execution.

 ./bin/jmeter.sh -n -t ~/jmeter/scripts/test1.jmx -l ~/jmeter/results/results1.jtl  

Summary will be printed on the jmeter console:

 Creating summariser <summary>  
 Created the tree successfully using /home/ubuntu/jmeter/scripts/test1 .jmx  
 Starting the test @ Thu Feb 20 10:25:14 UTC 2014 (1392891914636)  
 Waiting for possible shutdown message on port 4445  
 summary + 99960 in  104s = 961.9/s Avg:  26 Min:   3 Max:  806 Err:   0 (0.00%) Active: 30 Started: 30 Finished: 0  
 summary + 306897 in  180s = 1704.5/s Avg:  17 Min:   3 Max:  297 Err:   0 (0.00%) Active: 30 Started: 30 Finished: 0  
 summary = 406857 in  284s = 1433.0/s Avg:  19 Min:   3 Max:  806 Err:   0 (0.00%)  
 summary + 298083 in  180s = 1655.7/s Avg:  17 Min:   3 Max:  322 Err:   0 (0.00%) Active: 30 Started: 30 Finished: 0  
 summary = 704940 in  464s = 1519.5/s Avg:  18 Min:   3 Max:  806 Err:   0 (0.00%)  
 summary + 264542 in  155s = 1704.9/s Avg:  16 Min:   3 Max:  304 Err:   0 (0.00%) Active: 0 Started: 30 Finished: 30  
 summary = 969482 in  619s = 1566.2/s Avg:  18 Min:   3 Max:  806 Err:   0 (0.00%)  
 Tidying up ...  @ Thu Feb 20 10:35:35 UTC 2014 (1392892535107)  

The main advantage of this is you can see what is happening during long running test. 











Wednesday, February 19, 2014

WSO2 ESB becomes fastest ESB in the space


It is very exited to see WSO2 ESB becomes world fastest ESB. This has been clearly proved by recent analysis of performance round: WSO2ESB Performance Round 7.5”. It has compared with WSO2 ESB newest release: ESB 4.8.1 and other leading open source ESBs.

Summary of the result as follows:











Sunday, February 9, 2014

XML to JSON conversion when multiple attributes and elements exists

There are situations that we need to convert xml payloads into JSON. WSO2 ESB provides this support and refer http://docs.wso2.org/display/ESB481/JSON+Support for more details.

To convert an XML payload into JSON, we have to set the messageType property to application/json in synapse configuration.

Here I discuss about XML to JSON conversion when multiple attributes and elements available in the payload.
You may receive a soap request as follows:

SOAP Request:
 <soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:m0="http://services.samples" xmlns:xsd="http://services.samples/xsd">  
 <soapenv:Header/>  
 <soapenv:Body>  
 <m0:getQuote xmlns:m0="http://services.samples" id="12345">  
 <person sex="female" fn:target="urn:getQuote" xmlns:fn="abcdef" id="12345">  
 <firstname>Anna</firstname>  
 <lastname id="12345678">Smith</lastname>  
 </person>  
 <m0:request>  
 <m0:symbol>A</m0:symbol>  
 </m0:request>  
 </m0:getQuote>  
 </soapenv:Body>  
 </soapenv:Envelope>   

Person element contains multiple attributes sex, target, namespace and id.
i.e:  <person sex="female" fn:target="urn:getQuote" xmlns:fn="abcdef" id="12345">  

Also, lastnname is a sub element of person and it contains attribute as id and text content as "Smith"
i.e: <lastname id="12345678">Smith</lastname>

We will see how to covert such payload into json and its how the response looks like.

In ESB create a proxy service with SimpleStockQuote endpoint.

Proxy Service Configuration:
 <?xml version="1.0" encoding="UTF-8"?>  
 <proxy xmlns="http://ws.apache.org/ns/synapse"  
 name="XMLtoJSON"  
 transports="https,http"  
 statistics="disable"  
 trace="disable"  
 startOnLoad="true">  
 <target>  
 <inSequence>  
 <property name="messageType" value="application/json" scope="axis2"/>  
 <log level="full"/>  
 <respond/>  
 </inSequence>  
 <outSequence>  
 <send/>  
 </outSequence>  
 <endpoint>  
 <address uri="http://localhost:9000/services/SimpleStockQuoteService/"/>  
 </endpoint>  
 </target>  
 <description/>  
 </proxy>   


Note: 
For conversion, use "<property name="messageType" value="application/json" scope="axis2"/>" in the configuration as discussed above.

1. You have to start sample backend to receove response which is provided with WSO2 ESB. (Start axis2Service @ESB_HOME/samples/axis2Server)
2. Built SimpleStockQuote Service @ESB_HOME/samples/axis2Server/src/SimpleStockQuoteService by running "ant" command.
3. Send the SOAP request to proxy service using SOAP UI.


Response should be as follows:

 HTTP/1.1 200 OK  
 Host: shashi-ThinkPad-T530:8280  
 SOAPAction: "urn:getQuote"  
 Accept-Encoding: gzip,deflate  
 Content-Type: application/json  
 Date: Fri, 24 Jan 2014 06:00:54 GMT  
 Server: WSO2-PassThrough-HTTP  
 Transfer-Encoding: chunked  
 Connection: Keep-Alive  
 {"getQuote":{"@id":"12345","person":{"@id":"12345","@sex":"female","@target":"urn:getQuote","firstname":"Anna","lastname":{"@id":"12345678","$":"Smith"}},"request":{"symbol":"A"}}}  


Points to focus in response:

1. Content-Type should be 'application/json'
2. XML: 
<person sex="female" fn:target="urn:getQuote" xmlns:fn="abcdef" id="12345">  

JSON:
"person":{"@id":"12345","@sex":"female","@target":"urn:getQuote"

*** Attributes displayed with prefix '@' in JSON conversion. ("@id":"12345")
When nodes has text content as well as attributes, that text content is stored in a key with “$”

XML:
 <lastname id="12345678">Smith</lastname>  

JSON:
"lastname":{"@id":"12345678","$":"Smith"}

If a node has multiple children with the same tag name, they are converted into a numerically indexed array e.g. “person”
XML
 <person>Anvar</person>  
 <person>Porter</person>  
 <person>Raj</person>  

JSON
"person":["Anvar","Porter","Raj"]


SOAP request:
 <soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:m0="http://services.samples" xmlns:xsd="http://services.samples/xsd">  
 <soapenv:Header/>  
 <soapenv:Body>  
 <m0:getQuote xmlns:m0="http://services.samples" id="12345">  
 <person>Anvar</person>  
 <person>Porter</person>  
 <person>Raj</person>  
 <m0:request>  
 <m0:symbol>A</m0:symbol>  
 </m0:request>  
 </m0:getQuote>  
 </soapenv:Body>  
 </soapenv:Envelope>  


Response:
 HTTP/1.1 200 OK  
 Host: shashi-ThinkPad-T530:8280  
 SOAPAction: "urn:mediate"  
 Accept-Encoding: gzip,deflate  
 Content-Type: application/json  
 Date: Sun, 09 Feb 2014 02:49:07 GMT  
 Server: WSO2-PassThrough-HTTP  
 Transfer-Encoding: chunked  
 Connection: Keep-Alive  
 {"getQuote":{"@id":"12345","person":["Anvar","Porter","Raj"],"request":{"symbol":"A"}}}