观察并随后分析软件组件的运行时行为是成功调试软件中的一项重要实践。理解软件的运行时行为涉及两个关键实践:
运行时观察和分析技术自身不依赖于测试,目前可以观察和分析运行时行为而不需要预定义的测试输入或使用测试技术来模拟应用程序行为。但是,可以将测试与运行时观察技术及工具成功组合:例如,可以在测试执行期间执行自动化运行时观察的工具,提高对组件在响应测试时发生的运行时行为的可视性。
仔细观察软件运行时执行期间发生的所有行为虽然重要,但通常存在对特别监视很有用的重要观察点。这些重要观察点通常是:
-
决策点,在该点软件逻辑路径将要或刚产生分支。
-
完成点,在该点完成重要逻辑路径,通常会导致软件环境中的状态更改。
-
两个单独应用程序组件之间的接口点。
-
软件及其执行环境之间的接口点,包括所有到硬件组件的接口。
这些观察点可能还与控制点相一致,在控制点适合改变应用程序状态或通过逻辑路径的控制流。这些关注点通常称为控制和观察点(PCO)。
运行时观察不将静态观察法(例如复审静态软件源代码或复审在可视模型中捕获到的软件构建块之间的关系等)作为主要方法。
它需要可执行软件组件,并提供通过其他调试技术无法得到的有价值信息,这些信息是关于在测试环境中或最终部署环境中,已开发的组件在运行时的行为。然后可以将从运行时行为捕获到的观察与静态元素相联系,以提供更多认识。
软件运行时分析只是理解软件组件行为的实践,方法是通过分析组件运行时执行期间收集的数据。实施者开发组件期间,运行时观察和分析是实施者进行的调试活动的一个方面。
由于从运行时行为可以捕捉到的低级别信息的可能数量、生成信息的速度以及随后理解的潜在大量信息的难度,自动化工具支持是使该实践切实可行的关键因素。可以采取各种方法自己提供工具支持,并且已有大量商业上可用的工具,可节约您自己创建工具所需的时间、工作量和成本。
请参阅 PurifyPlus 以获取关于运行时观察和分析工具的更多信息。
|