Visual Studio 中不同项目类型的集成测试

Integration Testing In Visual Studio With Different Project Types

我们正在开发新的 CRM,它既为本地用户使用 WPF,又为现场用户使用 Windows 通用应用程序(商店应用程序)。基本流程是这样

  1. 客户致电并安排在 WPF 应用程序中的现场用户。
  2. 现场用户通过通用应用在 Surface 上进行服务呼叫和更新。
  3. 客户从 WPF 应用程序中获得账单。

所有模块都已到位并且可以正常工作,但由于项目类型不同,我似乎无法对整个项目流程进行集成测试。

我需要做的是在我的 WPF 应用程序的单元测试中添加对我的通用应用程序的引用(或相反),这样我就可以测试通过这两个组件的流程。

过去几周我一直在寻找解决方案,但一直没有想出任何方法来做到这一点。如果这不是直接可能的(我猜这是不可能的),有什么方法可以设置测试播放列表,以便集成测试 运行 以特定顺序进行。

我希望避免将样本数据硬编码到数据库中以测试通用应用程序,因为这不会显示从一个应用程序到另一个应用程序再返回的真实数据流。感谢任何帮助。

2015 年 8 月 21 日更新:

我们意识到,由于框架的差异,最好的解决方案是 运行 某种类型的有序测试。我们正在使用 MSTest。这个问题是 Visual Studios 中的有序测试不是解决方案范围的,它们只允许在单元测试项目中使用,这意味着它将使用该项目的引用,并且不允许两个测试。

我们不关心是否必须切换到不同的测试框架,因为拥有适当的测试比使用特定框架更重要。

您应该使用便携式 Class 库 (PCL)。您可以在添加新项目屏幕的 Visual Studio 中创建一个 PCL。

创建 PCL 时,它会询问您要定位的项目类型。由于您声明了 WPF 和 Windows Store 应用程序,因此您将使用 .Net 4.5(或您使用的任何版本)和 WIndows 8.1(或 8.0)

PCL 将允许您在 运行 时间为目标项目编写具有最低级别语言功能的代码。在您的情况下,这将是 Window 的应用商店应用。

现在,您需要将逻辑移至 PCL,而不是将您的逻辑存储在 Window 的商店项目中。

编译 PCL 后,您需要添加对 Window 商店应用的引用,以便您可以使用 Windows 商店应用中的逻辑(您将必须为 PCL 添加命名空间才能使其工作)。您还将在单元测试项目中添加对 PCL 的引用。因为您在 PCL 中同时定位了 运行 次,您将能够从集成测试中调用代码。

由于您的所有逻辑都在 PCL 中,您应该能够测试所有内容。 Window 的商店应用程序中现在唯一的东西应该是视图特定数据。

如果您需要更改 PCL 的目标(比如说希望它与 Windows Phone 一起使用),您可以编辑 [=30] 的属性=] 项目,并更改目标。请注意,如果您添加的目标 运行 时间比您当前选择的时间更紧,您将不得不重构您的代码以仅使用在最低功能 运行 时间内可用的功能。