- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
虽然我相信我在关注 instructions here设置 $httpBackend 将选定的请求传递给服务器,它对我不起作用。
Here is a Plunkr with a failing test这显示了我在做什么,并在评论中解释了似乎出了什么问题。
我的探索表明,出于某种原因,模拟 $httpBackend
没有真实 $httpBackend
的内部副本这样,当需要通过 XHR 请求时,它会将其传递给模拟 $httpBackend
反而。第二次调用引发异常,因为它不知道如何处理请求。
对 dtabuenc 的回应
我感激地记得你关于中途测试的帖子。您确定了介于单元测试和 E2E 测试之间的重要集成测试范围。我站在那个中间地带。
我觉得你一点也不刻薄。你的回答是完全合理的......或者它是合理的如果它与“API reference / ngMockE2E / $httpBackend”的文本不矛盾。我引用:
This implementation can be used to respond with static or dynamic responses via the
when
api and its shortcuts (whenGET
,whenPOST
, etc) and optionally pass through requests to the real$httpBackend
for specific requests (e.g. to interact with certain remote apis or to fetch templates from a webserver) ...[I]n an end-to-end testing scenario or in a scenario when an application is being developed with the real backend api replaced with a mock, it is often desirable for certain category of requests to bypass the mock and issue a real http request .... To configure the backend with this behavior use the
passThrough
request handler of when instead ofrespond
.[emphasis mine].
$httpBackend
的问题保持沉默在 Jasmine 环境中使用。我想不出理由来排除它。如果有这样的原因,他们应该清楚地说明。说真的,谁读到了一个模拟组件,却没想到在测试环境中使用它?
$httpBackend
以获取特定请求,例如与某些远程 API 交互”正是我打算做的。除了该组件的非模拟版本之外,“真正的 $httpBackend”可能意味着什么?
The
ngMocksE2E
module is designed to be used on the "server" side of things where the actual angular application is executing.
$httpBackend
不限于端到端测试。它也适用于“在开发应用程序时将真正的后端 api 替换为模拟的场景”。
Of course I can test (and do test) with mock XHR responses the component's ability to respond properly to what I predict will be the backend's behavior. That is not the same as validating that the component responds appropriately to the actual backend's behavior ... which might change as the application evolves and depart from the mocked responses in some significant way.
ngMidwayTester
无法访问发出 XHR 请求的组件。 .但如果必须的话,我确实知道如何将真正的 XHR 助手塞入管道中。
$httpBackend
将某些请求传递给服务器 - 正如文档所宣称的那样 - 或者我将替换
passThrough
自己用一个有效的 XHR 实现来实现。
最佳答案
以下是对 $httpBackend
用途的解释。那是在ngMockE2E
模块。ngMockE2E
模块根本不是设计的,也不打算在 Jasmine 规范中使用。
在进行端到端测试时,测试有两个方面。一个是正在测试的 Angular 应用程序,另一个是 Jasmine 规范中的 angular-scenario 代码。
在 E2E 测试中,没有 angular 模块、ng-mocks 或任何与 jasmine 方面相关的东西(除了场景运行器)。ngMocksE2E
模块设计用于执行实际 Angular 应用程序的“服务器”端。它的主要目的是使我们能够预先响应,以便集成级别的 UI 测试可以比每个页面实际到服务器获取 JSON 更快地进行。
当与 ng-mocks
一起使用 Jasmine 时, angular 将始终用模拟后端替换 $httpBackend。添加 ngMocksE2E
时模块将无法获取任何“真实”$httpBackend
正如您已经发现的那样,只会包装模拟并在传递时委托(delegate)给它。
看起来您正在尝试编写的测试类型不是测试 UI 集成,而是测试应用程序 javascript 和服务器集成。
这是完全合法的测试风格(在 Angular 社区中被称为“midwayTesting”)。您的问题是您使用了错误的工具。
我会看看这个:
https://github.com/yearofmoo/ngMidwayTester
您将使用它来代替 angular-mocks 和 angular.module() 以促进我假设您想要进行的那种测试。
你可以在这里读更多关于它的内容:
http://www.yearofmoo.com/2013/01/full-spectrum-testing-with-angularjs-and-karma.html
(抱歉,如果您已经链接到那里)
编辑: (解决有问题的其他评论)
你有一个真正的牛肉,因为文档不清楚 ngMockE2E
不能在端到端测试设置的客户端(即业力/ Jasmine )端使用。像你解释的那样去解释事物并不是没有道理的,但这并不能改变解释是错误的事实。
如果在应用程序的服务器端而不是客户端使用时得到指示,ngMockE2E 将通过请求。这意味着您仍然可以通过某些难以模拟为预设响应的请求。我所说的客户端和服务器端的意思是在端到端测试中有两个端点。您有由标准应用服务器提供服务的要测试的应用程序,并且您有驱动应用程序的测试代码,该代码通常在 Karma 或另一个测试运行程序中执行,它使用标准 HTTP 请求与正在执行的应用程序进行通信另一个过程。
如果您查看文档以及如何设置 ngMockE2E
你会注意到没有提到 Jasmine,并且说明是关于如何在真正的 Angular 应用程序中进行设置的:
myAppDev = angular.module('myAppDev', ['myApp', 'ngMockE2E']);
myAppDev.run(function($httpBackend) {
phones = [{name: 'phone1'}, {name: 'phone2'}];
// returns the current list of phones
$httpBackend.whenGET('/phones').respond(phones);
// adds a new phone to the phones array
$httpBackend.whenPOST('/phones').respond(function(method, url, data) {
phones.push(angular.fromJson(data));
});
$httpBackend.whenGET(/^\/templates\//).passThrough();
//...
});
angular.mock.module('ngMockE2E')
然后设置
$httpBackend.whenGET()
在
beforeEach()
而不是在
module.run()
.
ngMidwayTester
我将您链接到,我相信这实际上与
ngMockE2E
兼容.本质上
ngMidwayTester
替换
angular.mock.module()
和
inject()
有它自己的实现。所以你可以像这样使用它:
beforeEach(function(){
tester = ngMidwayTester('app', 'ngMockE2E');
$http = tester.inject('$http');
$httpBackend = tester.inject('$httpBackend');
$rootScope = tester.inject('$rootScope');
});
angular.mock.module()
时总是包含该模块)。使用
ngMidwayTester
时,事情应该完全按照您希望的方式工作。 .
关于angularjs - E2E 模拟 $httpBackend 对我来说实际上并没有通过,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20864764/
在阅读了$httpBackend的AngularJS文档后,我还是不太清楚$httpBackend.expect和$httpBackend.when之间的区别,因为两者都是函数模拟 http 请求。
$httpBackend.whenGET('/restpath/api/v1/books') .respond({// some data}); 我收到以下错误 Error: Unexpected r
经过太多时间后,我终其一生都无法让这个示例正常工作。我正在关注 Ben Lesh 的 excellent guides在 Angular 中模拟 $http 请求,但由于某种原因,服务请求未发送。 我
我在开发 Feed (RSS) 应用程序时正在使用 AngularJS 单元测试。 Feed 可以获取远程 rss 数据并对其进行解析并保存解析的项目。为了测试 rss 获取,我使用 $httpBac
我有包含单元测试的 AngularJS 应用程序。我在检查用户身份验证的应用程序的 .run 部分中又添加了一个 http 请求。现在大约 60% 的测试失败了,因为他们发现了“意外的 http 请求
我有 Angular (1.2.x) 单元测试,我正在使用 ngMock。我的项目有一个依赖于 sinon.fakeServer 的夹具系统。对于我的单元测试,我更愿意使用它而不是 $httpBack
在我看来,我有加载动画,该动画一直显示到我收到来自 API 的响应。 //Displayed before we've received API response Loading ... //Disp
我刚刚开始通过 Jasmine 在 AngularJS 中编写我的第一个单元测试。 不知何故,我仍然不明白为什么我应该模拟 $httpBackend。为了弄清楚我还不清楚的地方,我会写一个小例子: 想
我正在尝试将 url 与正则表达式匹配。但是下面的正则表达式不匹配。 $httpBackend.whenGET('/^rest\/find-reservations\?.*/)').respond(f
whenGET 不是函数,但是当我输出 proxy 时var 我清楚地看到函数在那里 { when: [Function], whenGET: [Function], whenPUT:
我遇到的情况是有很多模拟的 http 请求。在进行 Angular 上传时,我的情况发生了一些可疑的事情。它总是抛出 status:200 success 和 html 完整正文响应。 下面是我的 A
我正在尝试测试我的程序是否正确处理从 http 请求中收到的错误消息,但我不知道如何使用 $httpBackend 来模拟它。鉴于以下情况: $httpBackend.expectGET(path).
我正在使用 HttpBackend 来模拟我的 Angular 应用程序正在进行的某些调用的一些 Http 响应。 但是,当我运行测试时,我收到错误“意外请求:[object Object] 未定义”
我正在尝试围绕我的 Angular 项目构建一些 jasmine 单元测试。我遇到了一种情况,我不确定如何最好地解决。 我使用了一个响应拦截器,它能够在确定错误是 401 错误时重试请求。它将调用更新
我刚刚开始深入研究 AngularJS 的一些测试,但我不能说我完全理解它。我想在我的工厂中测试 REST API 方法,但我只是遇到错误。不知道我做错了什么。谁能帮帮我? 我的工厂: 'use st
我有这个 URL 可以匹配: $httpBackend.whenGET('/api/alerts/1121212156/0/4/0').repond(someObject) 问题是 112121215
我正在使用 Karma 对我的 AngularJS 应用程序进行单元测试,并使用 $HttpBackend 对后端进行 stub 。不知何故,flush() 方法似乎并没有解决我的所有请求,因为 Co
我正在开发一个 Angular 应用程序。我的应用程序运行时只有很少的 Controller 和服务。现在我想开始对服务和 Controller 进行单元测试。但是不知道我做错了什么,我什至无法为一项
我正在尝试为我正在使用 Angular JS 构建的应用程序模拟后端。 我有以下代码来模拟成功的登录请求: // Login $httpBackend.when('PUT','/v1/token/',
我有一个 $resource 用于处理实体的 crud http 请求。它包含在我的自定义服务中,目前不添加任何功能,所以不要介意它 - 它只是旧的普通 $resource: app.factory(
我是一名优秀的程序员,十分优秀!