在 Centreon Web 的开发过程中,保证软件质量至关重要。为了实现这一目标,我们采用了验收测试的方法,并结合 Behat 和 PHPUnit 框架。
centreon/centreon-test-lib
库应运而生,它提供了一系列与 Behat 兼容的类,方便我们在多个 Centreon 项目中进行测试。
为什么要使用
centreon/centreon-test-lib
?
这个库的核心思想是,通过模拟用户的操作,来验证 Centreon Web 界面的功能是否符合预期。它将测试过程分为了几个清晰的层次,使得开发者可以更加专注于测试逻辑的编写,而无需关心底层实现的细节。
层次结构
下面是测试过程中涉及的层次结构:
Layer | Language | Description |
---|---|---|
Acceptance Test | PHP | 这是编写验收测试的地方,也是 @@######@@ 库发挥作用的地方。这些验收测试由 Behat 运行。 |
Behat | PHP | Behat 负责运行验收测试并生成报告。 |
PhantomJS | c++ | PhantomJS 是一个无头浏览器,非常适合用于测试目的。 |
Centreon | PHP | 这是一个经典的 Centreon Web 界面,用户可以通过它进行监控操作。 |
类命名规范
为了更好地组织和管理测试代码,
centreon/centreon-test-lib
库定义了一套严格的类命名规范:
- 一个类对应一个 Centreon 页面。 也就是说,每当你在 Centreon Web 界面上浏览到一个新的页面时,就应该使用一个新的类来操作这个页面。
- 类名应该反映页面的意图,而不是访问页面的菜单。 例如,服务创建/编辑页面应该命名为
centreon/centreon-test-lib
,而不是
ServiceConfigurationPage
。
以下是一些类名示例:
Menu | Class name |
---|---|
Monitoring -> Status Details -> Services -> Inspect | @@######@@ |
Monitoring -> Downtimes -> Add | @@######@@ |
Configuration -> Hosts -> Hosts -> Add / Edit | @@######@@ |
Configuration -> Services -> Services by host -> Add / Edit | @@######@@ |
Administration -> Parameters -> Backup | @@######@@ |
类方法设计
- 保持方法简短,执行尽可能少的操作。 可以添加辅助函数来执行更复杂的操作,但这些辅助函数应该 真正 有用。
- 构造函数: 构造函数应该允许用户选择是否导航到请求的页面。 这是因为同一个类应该既可以用于直接导航到特定页面,也可以用于在页面已经加载后实例化该类。
-
ServiceCreationPage
:
这个方法应该检查当前页面对于该类是否有效。 它应该返回一个布尔值,指示当前页面是否可以被该类操作。
常用接口
ServiceMonitoringDetailspage
库定义了一些常用的接口,用于规范类的行为:
-
DowntimeConfigurationPage
:
定义了HostConfigurationPage
方法,用于检查页面是否有效。
-
ServiceConfigurationPage
:
继承自BackupConfigurationPage
接口,并添加了
isPageValid()
,
centreon/centreon-test-lib
, 和
Page
方法,用于获取、设置和保存配置页面的属性。
-
isPageValid()
:
继承自ConfigurationPage
接口,并添加了
Page
方法,用于获取列表页面的条目。
实际应用效果
通过使用
getProperties()
库,我们可以更加高效地编写和维护 Centreon Web 的自动化测试用例。这有助于我们及早发现潜在的问题,并确保 Centreon Web 的稳定性和可靠性。
总结
setProperties($properties)
库为 Centreon Web 的自动化测试提供了一个强大的工具。通过清晰的层次结构、命名规范和接口定义,可以显著提高测试效率和代码质量。如果你正在开发 Centreon Web 相关的项目,不妨尝试使用这个库,相信它会给你带来意想不到的惊喜。
save()
ListingPage
Page
getEntries()
centreon/centreon-test-lib
centreon/centreon-test-lib
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END