Using CSV DATA SET CONFIG element for Salesforce lightning Scripts
First, we will create a test plan. The Test Plan contains one Thread Group. The Thread Group consists of “CSV Data Set Config” and “HTTP Request”. Also, we will add an “View Results Tree”. See Figure 1.
data:image/s3,"s3://crabby-images/29845/298453877caaec8eb7f656fba344189167da373f" alt="Jmeter Pic1"
“View Results Tree” are listeners that are used for gathering results. So, let us look at the CSV Data Set Config configuration at Figure 2.
data:image/s3,"s3://crabby-images/11672/116724535ad86beefdeec0da81df24ce4bca695e" alt="Jmeter Pic2"
You will need to fill in at least three values in this screen:
- Filename: if your file is in the /bin directory, this can just be the filename. If it’s somewhere else, use the full path to the file.
- Variable names: this is the equivalent to a “column name” in a spreadsheet.
- Delimiter: a comma is the default delimiter, but if your file uses tabs, this is the place to mention that.
The other fields are optional but they may be useful to you.
Here I have considered a scenario to create an Account record in Salesforce Lightning
You should be familiar with HTTP(S) Test Script Recorder to assist the creation of JMeter test plans.
We have five variables that are sent for creating an Account record request in Salesforce Lightning.
They are accname, active,sla,slaexpiration,slaserial. Look at the Figure 3 to see what we have in data.csv
JMeter supports CSV files with quoted data that includes new lines.
By default, the file is only opened once, and each thread will use a different line from the file. However, the order in which lines are passed to threads depends on the order in which they execute, and it may vary between iterations. Lines are read at the start of each test iteration. The file name and mode are resolved in the first iteration.
data:image/s3,"s3://crabby-images/adf10/adf1071477ee5e47116f61b561299d053a970258" alt="Jmeter Pic7"
Now let us switch to the Login request where the Account is created in Salesforce Lightning, Figure 4.
data:image/s3,"s3://crabby-images/9f242/9f242a74adf30b02054e1988734e873cff2c16b6" alt="Jmeter Pic3"
In this request, you can see the table with the following parameters that are passed with the request
All the variables in ‘CSV Data Set Config’ can be seen on the message which contains all the values that are passed along with the request
I have highlighted the fields that are required to create an Account record in Salesforce
data:image/s3,"s3://crabby-images/1b793/1b79326f1f7dc0e423956f70782fb5538664f72a" alt="JMeter Pic4"
Now, we need to pass the variable names using construction ${….} means that this is a variable and not an absolute value as shown in Figure 6.
data:image/s3,"s3://crabby-images/b1589/b1589264fe3ec52646332e9b1c65ea6ed507aeec" alt="Jmeter pic5"
Now, if we run the test plan, JMeter will parse ‘csv_data.txt’ and change ${accnname}, ${slaserial}, etc., with their values. The results are displayed in Figure 7.
data:image/s3,"s3://crabby-images/e1413/e1413f246aa5a3d16669d2dba2084f0e987bf4f4" alt=""
Note: Every ‘CSV Data Set Config’ is visible to all Thread Groups by default. If you need to use separate the ‘CSV Data Set Config’ elements for each Thread, then create multiple data files that you need, and set the ‘CSV Data Set Config’ element from “Sharing mode” to “Current Thread”.
Thank you..