《AngularJS深度剖析与最佳实践》一2.13 端到端测试

简介:

本节书摘来自华章出版社《AngularJS深度剖析与最佳实践》一书中的第2章,第2.13节,作者 雪狼 破狼 彭洪伟,更多章节内容可以访问云栖社区“华章计算机”公众号查看

2.13 端到端测试

端到端测试(e2e test),也称为场景测试,它模拟的是用户真实的操作场景:
用户打开http://xxx地址。
在搜索框中输入了abc。
然后点击其后的搜索按钮。
这时候,他期望看到一个列表,列出所有在标题的任意位置包含了字符串abc的条目,并且每条结果中的abc这三个字母被高亮。
所谓端到端,也就是一端是浏览器,另一端是服务器,这个测试贯通了前后端,具有近似于验收测试的价值。
端到端测试不是什么新技术,它在前后端分离架构盛行之前就已经被广泛采用了,比如Selenium,而且Selenium也同样可应用于Angular中。
Angular的端到端测试工具称为Protractor,事实上,它就是基于Selenium的,在Selenium的基础上,它增加了一些Angular特有的元素选取方式,如根据ng-model选取元素等。
我的建议是,除非你所在的开发组织已经把Angular作为唯一的前端选项,否则请使用Selenium中传统的函数,而不要使用Protractor特有的根据ng-model选取元素等函数,这将让你们的测试独立于前端技术栈而被复用。
在我的工程实践中,只会使用id、class等少数查阅方式,而不会根据ng-model等进行查阅。并且,由于Angular的特点,被测试程序中可以不用任何id,所以,我们可以完全把id留给测试人员使用。如果写测试的人员有权修改源码,那么他/她可以自由的添加、删除id,而不用担心破坏了程序的逻辑和样式。遵循这个约定,可以让开发与测试的协同更加有效。
这里不展开讲解,只把我在种子工程中写的一些代码加上注释供大家自行研究:
1)pages/HomePage.js

// 这是一个页面对象,用来封装页面中的元素和操作,以简化规约代码,并提供一定的变更隔离
module.exports = function() {
    this.title = function() {
        // browser对象封装一组用来访问浏览器属性的函数
        return browser.getTitle();
    };
    // 根据id查找元素
    this.name = element(by.id('name'));
    this.nameEcho = element(by.id('name-echo'));
    this.get = function() {
        // 控制浏览器访问特定地址
        browser.get('http://localhost:5000/#/');
    };
};

2)demoSpec.js

// 取得页面对象
var HomePage = require('./pages/HomePage');

describe('e2e范例,如果修改了首页,请修改本测试 >', function () {
    var homePage;
    // 所有测试语句执行之前,先在浏览器中打开它
    beforeEach(function () {
        homePage = new HomePage();
        homePage.get();
    });

    it('默认的标题是Showcase', function() {
        expect(homePage.title()).toBe('Showcase');
    });
    it('输入用户名后应该回显', function() {
        // 检查初始状态是否符合预期
        expect(homePage.nameEcho.getText()).toBe('Hello,');
        // 模拟用户输入
        homePage.name.sendKeys('test');
        // 检查操作后状态是否符合预期
        expect(homePage.nameEcho.getText()).toBe('Hello,test');
    });
});
相关文章
|
1月前
|
Java 测试技术 开发者
Java单元测试与集成测试:确保代码质量的最佳实践
【4月更文挑战第2天】在软件开发中,单元测试验证单个代码单元(如Java类或方法)的功能,确保其正确性;而集成测试则关注多个组件协作时的交互。JUnit是常见的Java单元测试框架,集成测试则检验组件间接口的兼容性。Spring框架提供了集成测试的支持。遵循良好编码习惯,编写可测试代码,设计全面的测试用例,是保证代码质量和稳定性的关键。
|
3月前
|
安全 测试技术 UED
你知道SBTM(会话式测试管理)的最佳实践吗?
你知道SBTM(会话式测试管理)的最佳实践吗?
|
4月前
|
JavaScript 前端开发 Devops
负载测试的最佳实践
负载测试的最佳实践
|
4月前
|
安全 测试技术 数据库
安全测试的最佳实践
安全测试的最佳实践
|
6月前
|
消息中间件 弹性计算 Java
使用阿里云性能测试工具 JMeter 场景压测 RocketMQ 最佳实践
使用阿里云性能测试工具 JMeter 场景压测 RocketMQ 最佳实践
|
14天前
|
前端开发 IDE 数据可视化
深入理解与应用自动化测试框架Selenium的最佳实践
【4月更文挑战第30天】 本文将深入剖析自动化测试框架Selenium的核心原理,并结合最佳实践案例,探讨如何有效提升测试覆盖率和效率。文中不仅涉及Selenium的架构解析,还将提供针对性的策略来优化测试脚本,确保测试流程的稳定性与可靠性。通过实例演示,读者可以掌握如何在不同测试场景中灵活运用Selenium,以及如何处理常见的技术挑战。
|
14天前
|
JavaScript 前端开发 安全
【TypeScript技术专栏】TypeScript与Cypress端到端测试
【4月更文挑战第30天】随着前端开发复杂度提升,测试成为关键环节,Cypress因其强大的端到端测试和与TypeScript的集成备受青睐。TypeScript增强了代码的可读性和维护性,确保测试准确性和可靠性。在Cypress中,TypeScript用于定义测试变量、自定义命令和断言,提高测试代码质量。Cypress的优势包括模拟真实用户操作、时间旅行功能和强大的调试工具,能有效提升测试效率和准确性。结合两者,前端开发者能实现高效、全面的端到端测试。
|
16天前
|
资源调度 监控 JavaScript
AngularJS的测试:使用Jasmine和Karma进行测试的技术探索
【4月更文挑战第28天】本文介绍了在AngularJS项目中使用Jasmine和Karma进行测试的方法。Jasmine是BDD风格的JavaScript测试框架,提供清晰的测试用例,而Karma是测试运行器,负责在不同环境运行测试并生成报告。要使用它们,需安装两者,配置Karma,编写Jasmine测试用例,然后运行Karma执行测试。遵循最佳实践,如编写有意义的测试用例、模块化、覆盖率分析和自动化测试,能提升代码质量和稳定性。
|
2月前
|
敏捷开发 数据管理 测试技术
深入探索软件测试:方法、挑战与最佳实践
【2月更文挑战第20天】 在数字化时代,软件已成为不可或缺的核心。确保软件的质量和可靠性,软件测试扮演着至关重要的角色。本文将深入探讨软件测试的各种方法,面临的挑战以及实施的最佳实践。我们将从单元测试的基础出发,逐步过渡到集成和系统测试,最后讨论自动化测试的策略。文章旨在为软件测试工程师提供深度洞见,帮助他们更有效地设计和执行测试计划,以确保软件产品的质量。
|
4月前
|
安全 测试技术 API
API测试清单和最佳实践
API测试清单和最佳实践
API测试清单和最佳实践

热门文章

最新文章