在 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 界面,用户可以通过它进行监控操作。 |
Composer在线学习地址:学习地址
类命名规范
为了更好地组织和管理测试代码,
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










