Forum Discussion
Good grief!
So as I was waiting 10000ms for the panel to be missing, it was found! Seems there's a 2nd panel(2) that exists when my first condition doesn't happen. So essentially, my code is always falling into the true section of the if statement which made me believe that the false was never being triggered.
Ugh.
Is it Friday yet? :)
This is one reason why depending upon a single property (like Name) is insufficient for object identification... there are two objects that potentially are identified as ["Panel"](2)... what makes them unique? is there a className that distinguishes them? innerText? contentText? etc...
This is why "FindChild" has arrays as the first two parameters... an array of property names and an array of property values so, again, you're not dependant upon a single property...
AND... again... this is why NameMapping works the way it does... it works on that same "Child" object principle... look for a child of the parent objects with this set of property/value pairs...
- bo_roop7 years agoContributor
Yup... and I agree.
But going back to my original post: "I also can't reliable use a FindChild event as TestComplete does not replay 100% of the time. "
The script will not reliably find the child control every time for me.
I have a page in my IE11 browser:
AnyPage = Sys["Browser"]("iexplore")["Page"](ProjectSuite["Variables"]["ServerURL"]+"/*");
and I need to find the textbox in our floating menu in the old UI:
AnyPage["Table"](1)["Cell"](0, 0)["Panel"](1)["Textbox"]("menuSearch")
or in the new UI:
["Panel"](2)["Nav"]("menu_root")["Panel"](0)["Textbox"]("menu_search_input")
So I'm trying to write a function that checks for the existence of one and then potentially the other... without relying on a variable that says which version of the UI we're running against. (which is how my current implementation gets around this issue)
I know there are plenty of properties that change between these two textboxes. (idStr being the most important). But running the FindChild function on the two textboxes will not reliably replay in TestComplete on each of my pages.
So I was trying to go down to the root of the menu's hierarchy (table vs. panel and see if I could get it to work that way)... and I'm not having much luck that way either.
I'm open to suggestions. :)
- tristaanogre7 years agoEsteemed Contributor
Can you share an example of your attempt to use FindChild that is not working? I don't think the problem is necessarily in FindChild, but perhaps simply in finding the correct properties to work with.
- tristaanogre7 years agoEsteemed Contributor
Generally speaking.... start with a common parent object on both UI's... let's called it PanelX. So, you could do your code like this (I'm using a JavaScript syntax but, technically, this should work fine even in your C#Script since it is, under the covers, just JScript with support for C# Syntax).
var myObject = PanelX.FindChildEx(['ObjectType','idStr'],['Textbox','menuSearch'], 5, true, 10000) if (myObject.Exists) { Log.Message('Must be using the old UI'); } else { myObject = PanelX.FindChildEx(['ObjectType','idStr'],['Textbox','menu_search_input'], 5, true, 10000); if (myObject.Exists){ Log.Message('Must be using the new UI'); } else { Log.Warning('Could not find the object in either UI pattern'); } }
Basically... search for it at a depth of 5 (this is assuming that PanelX is at most 5 ancestors above the desired child object) using the old UI idStr and continue pinging it for 10 seconds until either the object is found or the time out is reached. If it is not found there, search using the new idStr and continue pinging for 10 seconds. If it's not found there, log a warning, otherwise, myObject is now the desired object.