What might be the reason(s) to adjust Connection Think Time for the page?
Hi,
The question was inspired by the "LC 4 - huge variance in page load times between LC4, LC3 and IE" thread (especially, http://community.smartbear.com/t5/LoadComplete/LC-4-huge-variance-in-page-load-times-between-LC4-LC3-and-IE/m-p/114875#M1248 and later).
Comments and corrections from Ryan and community are really welcome.
So, based on https://support.smartbear.com/viewarticle/78623/, there are three think times distinguished by LoadComplete:
a) Page Think Time - this is the time spent by the user reading and working with the current page;
b) Connection Think Time - this is the time passed since the browser started to download the page and opening additional connection(s) to web server to speed-up download of the additional resources required by the page. If more than one additional connections are opened, each of them has its own think time;
c) Request Think Time - this is the time passed between the end of one request and start of the next request issued within the same connection while downloading the same page.
Everything is more or less clear with a) and c) think times:
-- Page Think Time is completely determined by the end-user and can be set according to the usage statistics from production web server or according to the general expected end-user behavior. Increase or decrease of the Page Think Time effectively simulates how long end-user stays on the page;
-- Request Think Time, on the contrary, seems to be completely the internal matter of the web browser - it is up to it to dispatch requests by existing connections - and seems have no reason to be adjusted.
But Connection Think Time is something that is not completely clear to me at the moment.
It is my understanding, that the necessity to open a new connection is determined by the browser while parsing and processing already downloaded resources. This means that the delay to create a new connection (i.e. - the value of the Connection Think Time) is determined by: a) the connection speed; and b) the speed of resource processing (actually - by the time spent to execute associated jscript code).
If the above is correct, this means that adjustment of the Connection Think Time simulates the speed of connection (which is expected to be controlled by the Connection Speed parameter of the test setup, accessible in the Test Editor window) and the computational power of the client machine.
So, if I see a big value of the Connection Think Time on the Timeline tab for some secondary connection and this connection starts after the initial connection (the one that started download of this given page) was closed, for me this is an indication that it took a lot of time for the client browser to process the initial page resource. If I like to emulate a more fast client environment, then I may adjust the value of the Connection Think Time for this secondary connection.
Any comments on above?
Any ideas/experience about when adjustment of the Connection Think Time might be useful and what this suggested adjustment means from the process flow point of view?
Anything else I might miss?