Forum Discussion
AlexanderM
13 years agoStaff
Hi Aakash,
Thank you for the screenshots.
We have analyzed them in our test lab and found a couple of important differences that can explain the behavior variations you observe on different computers:
1. First of all, you are looking at two different applications - iCam and RTVue.
2. According to your screenshots, and, specifically, to the window classes, these apps were probably compiled in different versions of Visual Studio: iCam was built in Visual Studio 2008, and RTVue - in Visual Studio 2010.
This explains the different tree structure in TestComplete, because MSAA technology that you are using to recognize your third party controls is implemented on the side of the application as an MSAA provider. For standard controls like ListView, the MSAA provider functionality is built into the application by the IDE when you are compiling the app, and the functioning of the MSAA provider can vary from one version of a compiler (or MFC library) to another.
I have created a standard MFC application with a ListView control in Visual Studio 2010, and I saw the same tree structure as that you observe. So, the cause of this is that the MSAA provider's behavior in Visual Studio 2010 is other than that of the MSAA provider built into the apps built in VS 2008. This difference has nothing to do with your application or the settings of your TestComplete project.
In this situation, using the same test for different applications is difficult due to the differences of the MSAA structure. If the object structure differences are specific only to this control, while the structure is the same in all other screens of the applications, you can try using conditional logic to make one test set work for both applications. However, if the object structure differences are seen in many other places of the application's UI, it may be easier to create and maintain two different test sets for the two applications.
So, the right question is now as follows:
How can one test the XTPPropertyGrid control in an application built in VS 2010?
Or how should one build/configure such an application, so that the grid contents were represented as a set of MSAA elements?
We have checked the compiled samples on the CodeJock web site, and they do not demonstrate the issue - the grid rows are represented as the MSAA Row elements:
http://www.codejock.com/downloads/samples/propertygrid.asp
This is true for both the 32-bit and the 64-bit samples. Can you send us a sample application (preferably, with the source code) which demonstrates the problematic behavior? We could try to find a way to test this control when MSAA is not working.
Related Content
Recent Discussions
- 2 days ago
- 8 days ago
- 11 days ago