JMeter JDBC stored Procedure invocation with BLOB parameter - jdbc

For testing purpose I need to invoke a DB2 Stored Procedure via JMeter.
I set up a JDBC connection, then add the JDBC Request step, but I have problem when populating the parameters.
The problem is that one of the parameters is a BLOB taken from a .bin file, and I can't find a way to insert it. The parameter are read from a CSV file.
What I did was:
Query Type: Callable statement
CALL MY.STOREDPROCEDURE(?,?,?)
Parameter values: ${par1},FROM_FILE('${par2}'),'a'
Parameter types: IN VARCHAR, INOUT BLOB, OUT VARCHAR
The error I get is that it can't convert String to Blob (
Illegal conversion: can not convert from "java.lang.String" to
"java.sql.Blob" ERRORCODE=-4474 SQLSTAT=null.).
I think that the problem is that the FROM_FILE function return a String with the content of the file.
Following an idea I found on-line I set up a JSR233 Sampler to load the file with a Groovy script, I saved the file as an Object, but when i read it it still seems to be read as a String, even with a groovy script (${__groovy()}).
I tried to do add a cast in the invocation but then I will get an error about the "Literal replacement parsing failed for procedure call".
How can I pass a Blob to the invocation?

Related

how to pass the dynamic filename in csv data set config in jmeter while the dynamic names are generated to save data of previous request?

I have one http request whose response comes in nested json and using groovy i am saving that data in different csv file on the basis of conditions.
the name of csv file is generated dynamically and saved in a variable
using vars.put() function
vars.put("_cFileName",cFileName.toString());
when try to use this variable in csv data set config
enter image description here
getting error message
2022-01-19 16:58:39,370 ERROR o.a.j.t.JMeterThread: Test failed!
java.lang.IllegalArgumentException: File ${_cFileName} must exist and be readable
it is not converting the name to actual file name
But in case if file name is not dynaamic and the variable is defined under user defined variable in test plan it will able to convert to actual file name?
is there any way we can use the dynamic name created in an previos request post processor?
You cannot, as per JMeter Test Elements Execution Order Configuration Elements are executed before everything else, CSV Data Set Config is a Configuration Element hence it's being initialized before any JMeter Variables are being set.
The solution would be moving to __CSVRead() function, JMeter Functions are evaluated at the time they're being called so it's possible to provide dynamic file name there, see How to Pick Different CSV Files at JMeter Runtime guide for more details if needed.

Using JMETER GUI JDBC Request with Callable Statement – how do I getResultSet/MetaData?

I’ve got a call to my database working as a SQL select statement. But I am working to call a stored procedure using JMeter for further testing. I’m strictly working off of the JMX files and do not have JMETER integrated into our main Java project at this time.
I’ve setup the JMETER GUI with the JDBC Connection Configuration and the JDBC Request. I’ve made a successful call to my database with my callable statement with my string INPUT and get the string OUTPUT parameter string.
The OUTPUT parameter string only contains information about the call (user,system, success, etc…), but none of the values/data from the table -- which are found in the ResultSet/MetaData. But I cannot figure out how to get the ResultSet or the Metadata using the JDBC Request in JMETER.
In Java, I know I use the statement and just call statement.getResultSet() and perform a loop while resultSet.next() exists. How do I do this in JMETER?
I've tried adding an additional out parameter but then my statement rejects the call, because there is only one in-parameter. I've tried a variety of JMeter Assertions - but because the main call is only returning the out parameter, I cannot grab additional data.
Query: call XXXXX.readUser(?)
Parameter Values: ${inputJSONString}
Parameter Types: INOUT VARCHAR
Variable Names: ouputJSONString
Result Variable Name: ouputJSONString
View Results Tree: Response code: 200, Response message: OK, Output variables by position: Contains the whole JSON out parameter string with user, system, and success. Returns the table column headers but no values.
I do not have errors - the call is being made successfully. I just cannot figure out how to access the Result Set from JMETER.
Don't use the same reference name for the Variable Names and the Result Variable Name as the latter one will be overwritten.
So
Change ouputJSONString to i.e. ouputJSONStringObject
Add JSR223 PostProcessor as the child of the request
You will be able to access the JMeter's representation of the ResultSet as vars.getObject('ouputJSONStringObject') (basically ArrayList of HashMaps
See Debugging JDBC Sampler Results in JMeter article for more details.
Unfortunately you cannot access the normal ResultSet as it is not exposed anywhere and being converted via private function

Jmeter - convert a string to base64

I've just started out trying to write some tests in jmeter. It's the first time I've used it in earnest, and I'm struggling a bit with it.
I am running a test that searches for data on a website.
The returned data is in the format baseURL/customerID=
Now, the customer number depends on the customer being searched for and it is in base64.
I'm struggling to see how I can get the url updated.
I can see in the request that the field is parameter, and I know what the value is, as I have it stored in a csv file as CustomerID.
How can I convert that csv data to the url parameter?
I'm trying to use beanshell at the moment with this:
import org.apache.commons.codec.binary.Base64;
String customerID = vars.get("customerID");
String customerStringEncoded = Bas64Encoder.encode(customerID);
vars.put("customerStringEncoded",customerStringEncoded);
But it seems that it can't locate customerID.
I am supplying it wiht ${CustomerID} in the preprossor menu option, but I don't know what is wrong.
the error is "Typed variable declaration : Attempt to resolve method: encode() on undefined variable or class name: Bas64Encoder
"
Any tips?
Thanks
tgb
If the data is being stored in csv, you can use the "CSV Data Set config" to read the CSV File. CSVhttp://jmeter.apache.org/usermanual/component_reference.html#CSV_Data_Set_Config

How to convert string from JS string format in Jmeter

I am newbie in Jmeter. I am able to capture the session id as "result.sessionToken = 'A45833C7\x2D4535\x2D49C8\x2DBB46\x2D15819383F3BB';" using "Regular Expression Extractor". However, this session Token ID in request is going in different format "A45833C7-4535-49C8-BB46-15819383F3BB".
Can anyone tell me, how to convert the captured dynamic data from 1 format to other? We have "Convert" attribute in "web_reg_save_param()" function in Load runner, do we have such function in Jmeter?
OR
How can we write our own code to replace "\x2D" with "-"?
Assuming that you have ID variable with the value of A45833C7\x2D4535\x2D49C8\x2DBB46\x2D15819383F3BB
You can replace \x2 with - Using __javaScript() function as follows:
Just replace
${__javaScript("${ID}".split('\x2').join('-'),)}
Replace and store result into ID variable
${__javaScript("${ID}".split('\x2').join('-'),ID)}
Replace and store result into FOO variable
${__javaScript("${ID}".split('\x2').join('-'),FOO)}
For more information on using JMeter Functions see How to Use JMeter Functions post series

JMeter using a variable as input for a response assertion pattern

I have a test plan in JMeter that has a Response Assertion where I'd like to use a variable that comes from a CSV Data Set Config. So my Pattern looks like:
${assert1}
Which corresponds (at least in my thoughts) to what comes from the file used in CSV Data Set Config, but it doesn't work. I have seen multiple suggestions to use a Regular Expression Extractor, but the examples I saw refer to something they're trying to capture from a page. In my case I am using an external csv file.
My question: how can I use a variable as input for a Response Assertion pattern ?
I have successfully used a CSV Data Set Config as a source of string that I use in a url parameter, and then use a Response Assertion to seek out that parameter in the response.
Variable name: P.
URL: /product/${P}.
The response assertion Parterns to Test: ${P}.
I wonder if it is not necessary to use the CSV data variable in the request in order for it to be available in the response assertion?
If my understanding is right,
here your problem:
You want to use the value from your CSV as part of URL and that too via variable.
Solution:
Configure your CSV Data Set Config like this:
Filename: url csv path
variable name : assert1
Delimiter : , (if your CSV comma separated)
leave remaining unchanged
That's it you can use the variable assert1 anywhere: ${assert1}.

Resources