UI自动化和WPF的经验

时间:2009-03-13 19:06:40

标签: wpf ui-automation

我们正在开发一个相当大的基于WPF的应用程序,并希望在我们的测试套件中包含一些自动UI测试(它已包含许多单元测试)。

来自Microsoft的UI Automation Framework部分听起来非常适合在测试设置中以编程方式启动和与应用程序交互。但是,我一直在努力寻找样本和技术经验的可靠参考,MSDN上提供的文章和小样本不足以让我相信它是一个可靠的选择。

那么,有没有人在他们的测试套件中使用UI Automation Framework有真实的经验?有什么警告和陷阱?编写测试脚本时的任何最佳实践,您是否可以“记录和重放”到可编写脚本的格式,您应该从应用程序中促进测试的程度,您是如何将它合并到自动构建中的?我们是否应该寻找与UI自动化框架不同的另一个方向?

随时在这里发布您的经历或链接到我可能错过的一些好的参考

3 个答案:

答案 0 :(得分:7)

在我工作的地方,我们刚开始为我们的系统评估一些测试工具。我们遇到了一个名为white的工具,它使用UI自动化框架。请注意,白色也有记录功能,虽然我认为它看起来有问题,但仍在开发中。

我们尝试做的是将它们设置为单元测试,即[TestFixture] [Test]等。 然后我们能够在单元测试的同时通过nunit运行它们。

我们发现在您的窗口中访问某些组件可能很困难,但没有太多机会调查原因。

如果您不介意购买该软件,我建议您TestComplete

答案 1 :(得分:6)

我正在为工作中的WPF应用程序进行UI自动化。我正在使用White和IronRuby,效果很好。我已经写了我在这里完成的工作:http://www.natontesting.com/2010/02/17/how-to-test-a-wpf-app-using-ironruby-and-white/

答案 2 :(得分:2)

我们最初选择了白色,然后离开了它。它试图通过Win32 API,Winforms,Java应用程序和MS UI自动化API进行通用和抽象。 MS UI自动化API也尝试通过win32 api和winforms以及WPF进行通用和抽象,因此您最终会出现“最低公分母最低公分母”情景。

这样做的结果是,White元素搜索API不够灵活,无法找到我们需要查找的各种UI元素,并且它没有暴露足够的底层UI自动化框架元素供我们做任何事情对它有用。

我们最终选择了自己开发的一种框架;我们直接使用MS UIAutomation框架,但是有扩展方法和辅助类来处理它没有解决的场景。 (主要是键盘和鼠标输入)。

注意:我们的测试脚本和自行开发的框架都使用IronRuby。 Ruby能够将方法添加到现有类中,并且它的灵活语法(与method_missing结合使用)对于这类事物来说非常棒。