我正在尝试为 Angular 应用程序设置单元/e2e 测试。按照 Protractor 网站上的说明和许多其他示例,我已经设置了它并能够运行测试,除非它们引用的是 Angular 对象。 这是我想要测试的示例 html 页面:
<!DOCTYPE html>
<html ng-app="app">
<head>
<script type="text/javascript" src="libraries/angular.js"></script>
<script type="text/javascript" src="libraries/angular-route.js"></script>
<script type="text/javascript" src="libraries/angular-touch.js"></script>
<script type="text/javascript" src="libraries/angular-sanitize.js"></script>
<script type="text/javascript" src="libraries/angular-mocks.js"></script>
.....
</head>
<body ng-controller="DefaultController">
...
测试:
describe('Logon page', function ()
{
beforeEach(function ()
{
browser.get('default.html');
angular.module("app");
});
it('should have a title', function ()
{
expect(browser.getTitle()).toEqual('Logon');
});
});
当我运行它时,我得到一个异常:“ReferenceEror: Angular 未定义”。 如果我删除行“angular.module(“app”);” - 效果很好。 通过查看 Protractor 的控制台输出,看起来 Protractor.waitForAngular() 在我尝试访问“Angular ”对象后在内部被调用。但据我了解 browser.get - 应该先加载它?
我使用 Angular 1.3.4 和 Protractor 1.4.0。
提前致谢。
最佳答案
为什么需要 angular.module("app");
部分?您在 Protractor 测试中编写的代码不会在浏览器中运行。它使用浏览器 API(通过 Selenium),但您无法直接访问正在测试的页面上的 Angular 模块或其他结构。
我认为您可能混淆了单元测试和端到端测试的概念。您需要 angular.module("app");
仅用于单元测试。
关于javascript - Protractor 找不到 Angular ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27269459/