angular-cn/public/docs/ts/latest/guide/testing.jade

245 lines
6.3 KiB
Plaintext
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

:marked
We write **unit tests** to explore and confirm the **behavior** of parts of our application.
我们编写**单元测试**来探索并巩固应用程序中的**行为**部分。
1. They **guard** against breaking existing code (“regressions”) when we make changes.
1. 当我们做出修改时,它们会**守护**已有代码(回归测试),防止其被破坏。
1. They **clarify** what the code does both when used as intended and when faced with deviant conditions.
1. 当我们正确使用代码和面对异常情况时,它们会让代码的用途更加**明晰**。
1. They **reveal** mistakes in design and implementation. Tests force us to look at our code from many angles. When a part of our application seems hard to test, we may have discovered a design flaw, something we can cure now rather than later when it becomes expensive to fix.
1. 它们会**揭露**我们设计和实现中的错误。测试会强迫我们从多种角度看代码。如果应用程序的一个部分看起来很难测试,这可能就意味着存在设计缺陷。
我们可以立即修复它,而不用等到它变得不可收拾的那一天。
a(id="top")
:marked
# Table of Contents
# 目录
1. [Jasmine Testing 101](#jasmine-101)
1. [Jasmine测试简介](#jasmine-101)
- setup to run Jasmine tests in the browser
- 设置浏览器来运行Jasmine测试
- basic Jasmine testing skills
- Jasmine测试的基本技能
- write simple Jasmine tests in TypeScript
- 用TypeScript编写简单的Jasmine测试
- debug a test in the browser
- 在浏览器里调试一个测试
1. [The Application Under Test](#aut)
1. [被测试的应用程序](#aut)
1. [First app test](#first-app-tests)
1. [第一个应用程序测试](#first-app-tests)
- test a simple application interface outside of Angular
- 在Angular之外测试一个简单的应用程序接口
- where to put the test file
- 测试文件存放到哪儿
- load a test file with systemJS
- 使用systemJS调用一个测试文件
1. [Pipe driven development](#pipe-testing)
1. [测试驱动开发一个管道](#pipe-testing)
- create a test before creating a class
- 创建类之前,先创建一个测试
- load multiple test files in our test harness, using system.js
- 使用system.js往我们的测试套件里加载多个测试文件
- add the Angular 2 library to our test harness
- 往我们的测试套件里添加Angular 2的类库
- watch the new test fail, and fix it
- 看着新测试失败,然后修复它
1. Test an Asynchronous Service (forthcoming)
1. 测试异步服务(即将到来)
- test an asynchronous service class outside of Angular
- 在Angular外测试异步服务类
- write a test plan in code
- 用代码写测试计划
- fake a dependency
- 伪造一个依赖
- master the `catch(fail).then(done)` pattern
- 掌握`catch(fail).then(done)`模式
- move setup to `beforeEach`
- 把设置工作移入`beforeEach`
- test when a dependency fails
- 测试依赖失败时的情况
- control async test timeout
- 控制异步测试的超时时间
1. The Angular Test Environment (forthcoming)
1. Angular测试环境即将到来
- the Angular test environment and why we need help
- Angular测试环境以及我们为什么需要它的帮助
- add the Angular Test libraries to the test harness
- 把Angular测试库加入测试挽具中
- test the same async service using Angular Dependency Injection
- 使用Angular依赖注入测试同一个异步服务
- reduce friction with test helpers
- 减少与测试助手的摩擦
- introducing spies
- 引入侦探类
1. Test a Component (forthcoming)
1. 测试组件(即将到来)
- test the component outside of Angular
- 在Angular外面测试组件
- mock the dependent asynchronous service
- 模拟所依赖的异步服务
- simulate interaction with the view (no DOM)
- 仿真与视图的交互不涉及DOM
- use a spy-promise to control asynchronous test flow
- 使用侦探型承诺(spy-promise)来控制异步测试工作流
1. Test a Component in the DOM (forthcoming
1. 在DOM中测试组件即将到来
- test the component inside the Angular test environment
- 在Angular测试环境中测试组件
- use the `TestComponentBuilder`
- 使用`TestComponentBuilder`
- more test helpers
- 更多测试助手
- interact with the DOM
- 与DOM交互
- bind to a mock dependent asynchronous service
- 绑定到一个模拟的异步服务
1. Run the tests with karma (forthcoming)
1. 用Karma运行测试即将到来
Its a big agenda. Fortunately, you can learn a little bit at a time and put each lesson to use.
这是一个很大的日程表。幸运的是,我们可以一次只学一小点,然后把它们投入实战。
a(href="#top").to-top Back to top
.l-hr
a(id="jasmine-101")
:marked
# Jasmine Testing 101
# Jasmine测试简介
!= partial("../testing/jasmine-testing-101")
a(href="#top").to-top Back to top
a(href="#top").to-top 回到顶部
.l-hr
a(id="aut")
:marked
# The Application to Test
# 被测试的应用程序
!= partial("../testing/application-under-test")
a(href="#top").to-top Back to top
a(href="#top").to-top 回到顶部
.l-hr
a(id="first-app-tests")
:marked
# First app test
# 第一个应用程序测试
!= partial("../testing/first-app-tests")
a(href="#top").to-top Back to top
a(href="#top").to-top 回到顶部
.l-hr
a(id="pipe-testing")
:marked
# Pipe driven development
# 测试驱动开发一个管道
!= partial("../testing/testing-an-angular-pipe")
a(href="#top").to-top Back to top
a(href="#top").to-top 回到顶部
.alert.is-important
:marked
The testing chapter is still under development.
Please bear with us as we both update and complete it.
测试章节正在开发中,请耐心,我们会更新并完成它。