Forum Discussion
I'm getting an object does not exist error if it's not on the page at all
Can you provide a relevant line of code and exact error message from test log, including the text from the Additional Info pane?
My apologies. That was old data - I was having the issue on Friday before a minor code change last thing in the day that fixed it and I forgot about it over the weekend doh ! :smileysad:. Today I have it working, but I'm still hoping to find a way of making it a bit more efficient. My Run Timeout is currently 30 seconds (yes, some controls on my site actually take that long), so this function could take 30 seconds plus change before it continues. On a page with just 4 controls, that could add 2 minutes. I am using a FindChildEx though - that cuts it down. I could do:
var currentTimeout = Options.Run.Timeout; Options.Run.Timeout = 100; // find table, wait etc. Options.Run.Timeout = currentTimeout
But that opens the window again for the table actually being there, but the timeout being too short for TC to track it down because the page loads a bit slow. I'm not saying there's a better solution than the current one I have. It would just be nice to ask TC to just tell me if it's on the page as quick as possible rather than try and find it for a long time that I make up and tweak every time the test doesn't find the table even though it's there all because I made the delay too short.
- AlexKaras6 years agoChampion Level 3
It would just be nice to ask TC to just tell me if it's on the page as quick as possibleThe general sequence is like this:
-- If the click on some web element can reload page/page data (as opposed to just displaying/hiding something on the page via script), then page.Wait() must be executed. .Wait() method of the page object waits until the web page source is obtained from web server and the browser completes initial page processing;
-- If the page contains elements that are downloaded from web server via additional requests (Ajax) and you either need to interact with these elements or web page is not responsive until these elements ere obtained, then you must execute page.<container>.WaitChildEx() with the long enough timeout to delay until the elements are obtained. (Note, it is safe to set very long timeouts here because .WaitXXX() methods return as soon as the sought for object is obtained. The only case when too long timeout might be not reasonable is when it is OK for the sought for object to be absent on the page. In this case you must find a good enough timeout value to wait long enough for the object but not wait too long.)
-- Optionally, depending on the implementation of the tested application, you may need to additionally wait for the found object become visible on the page. (It may be required to check different indicators to ensure element's visibility: from .Visible property in the simplest case to the values of class/width/height properties of the element itself or including a set of its parents.)
-- One more additional delay might be required if the data for the target web element are also obtained via separate request. If this is the case, then you must figure out criteria that are met when the element is populated with data and delay appropriately;
-- It is usually safe to proceed with the test actions after all above actions are done.
- RUDOLF_BOTHMA6 years agoCommunity Hero
OK, Nuanced variation of the same question:
More detail:
If this table is on the page it will be there the moment the page is rendered and it just gets popped up when a callback starts and moved back when the callback ends, so the only thing that changes is the VisibleOnScreen property
How would you go about distinguishing between an item that doesn't exist anywhere on the page (not in the HTML) and an item that took too long to exist ? In both cases a .Findxxx would come back after some time with a stub. If it is because the table is on the page but TC couldn't find it in time, theres something wrong with the page and I want to at least log a warning. If it's not there at all in the HTML it means I have no controls on the page that call the loading panel, so I can skip right obver this and continue. I can survive without this to be honest, but it would be useful to be able to make sure those control changes run smoothly without having to know beforehand on each page if it has a loading panel or not and write tests ccordingly
- AlexKaras6 years agoChampion Level 3
Well...
It is a usual and well-known problem with Ajax-enabled pages when they do not contain an indicator that all processing on the page has been completed - when test code fails to find the dynamic objects like LoadingPanel, it is not easy to determine whether the object was not found because the given data processing is over and the object has already been removed from page DOM (so there is no reason to wait for it) or because the data processing has not been started yet (for example, because of slow network or backend overload and thus the code must continue to wait for the object).
How would you go about distinguishing between an item that doesn't exist anywhere on the page (not in the HTML) and an item that took too long to exist ? In both cases a .Findxxx would come back after some time with a stub.
No. If the object is not in the page DOM, then indeed .FindChild() or .FindChildEx() returns an empty stub and testcode must wait until the object appears. (Or the timeout defined by quality of service requirements elapses. In case such requirements exist.)
If test code should delay until the object is gone (e.g. LoadingPanel is hidden), then test code may use the .WaitProperty method. For the discussed example the code may be like this:
LoadingPanel = Aliases.<container>.FindChildEx('loadingPanel', 60000);
// some data processing is triggered here
...
// wait until the data processing is over
LoadingPanel.WaitProperty('Visible', false, 60000);
...
Related Content
Recent Discussions
- 13 hours agoAivanitskiy
- 17 hours agonastester