当角色应用程序准备就绪时,Angular-scenario可以正常运行。使用requirejs或其他AMD lib时不是这种情况。如何在角度场景中添加对AMD的支持?
答案 0 :(得分:9)
您需要做的是覆盖默认的帧加载行为,并在应用程序准备就绪时发出新事件。
第一件事是在angular应用程序中添加以下行以及angular.bootstrap调用。角度场景需要此数据。
angular.bootstrap(document, ['app']);
var html = document.getElementsByTagName('html')[0];
html.setAttribute('ng-app', 'app');
html.dataset.ngApp = 'app';
if (top !== window) {
top.postMessage({
type: 'loadamd'
}, '*');
}
接下来,在您的e2e跑步者中,您必须包含这些行。如果它是一个外部脚本,它必须在angular-scenario之后加载,并且必须在DOM准备好之前解析它:
/**
* Hack to support amd with angular-scenario
*/
(function() {
var setUpAndRun = angular.scenario.setUpAndRun;
angular.scenario.setUpAndRun = function(config) {
if (config.useamd) {
amdSupport();
}
return setUpAndRun.apply(this, arguments);
};
function amdSupport() {
var getFrame_ = angular.scenario.Application.prototype.getFrame_;
/**
* This function should be added to angular-scenario to support amd. It overrides the load behavior to wait from
* the inner amd frame to be ready.
*/
angular.scenario.Application.prototype.getFrame_ = function() {
var frame = getFrame_.apply(this, arguments);
var load = frame.load;
frame.load = function(fn) {
if (typeof fn === 'function') {
angular.element(window).bind('message', function(e) {
if (e.data && e.source === frame.prop('contentWindow') && e.data.type === 'loadamd') {
fn.call(frame, e);
}
});
return this;
}
return load.apply(this, arguments);
}
return frame;
};
}
})();
最后,要启用amd配置,必须将属性ng-useamd添加到angular-scenario的脚本标记中。
<script type="text/javascript" src="lib/angular-1.0.3/angular-scenario.js" ng-autotest ng-useamd></script>
你现在准备好了
使用angular-scenario v1.0.3 测试
答案 1 :(得分:4)
上述答案在我的情景中部分失败(Angular 1.1.4,新鲜的Karma)。 在调试视图中,它运行正常,在正常的概述页面中失败了。我注意到了一个额外的嵌套。
我将代码更改为已测试应用程序的父iframe消息。
if (top !== window) {
window.parent.postMessage({
type: 'loadamd'
}, '*');
}
答案 2 :(得分:1)
接受的答案绝对正确,但遗憾的是您必须将该代码放入您的页面。
所以,如果它有所帮助,我为业力创建了一个预处理器来注入“修复”。作为试运行的一部分。
代码:https://github.com/tapmantwo/karma-ng-bootstrap-fix-preprocessor npm:https://www.npmjs.org/package/karma-ng-bootstrap-fix-preprocessor
注意,这仅适用于通过业力提供文件的情况。如果你代理他们,他们不会通过预处理器。所以,作为一种替代方案,我有一个ng-scenario的分支,它做了类似的事情,允许手动引导的站点运行;
https://github.com/tapmantwo/karma-ng-scenario
这不是节点模块,所以你必须手动设置它,但它更好(恕我直言)有这样的东西而不是感染生产代码只是为了得到测试通过。