使用Karma测试非平凡的AngularJS应用程序

时间:2013-05-31 07:14:13

标签: apache angularjs jasmine karma-runner angular-scenario

我一直在尝试为我一直在开发的应用程序设置测试套件。该应用程序在本地托管,大多数帐户工作正常。我试图通过AngularJS网站和Karma网站上的说明设置业力,几乎我找到的其他网站,但我一直都会遇到同样的错误。

这是我的conf:

urlRoot = '/karma/';
frameworks = ['ng-scenario'];
files = [
  ANGULAR_SCENARIO,
  ANGULAR_SCENARIO_ADAPTER,
  'spec/e2e/*.spec.js'
];
browsers = [
  'Firefox',
];
proxies = {
  '/': 'http://localhost/web/',
};
port = 9876;
singleRun = false;
junitReporter = {
  outputFile: 'logs/e2e.xml',
};
logLevel = LOG_DEBUG;

一个示例规范:

describe('login test', function() {

  it('should login', function(){
    browser().navigateTo('/');
    if(browser().window().path() != '/'){
      expect(element('[ng-model="username"]').count()).toBeGreaterThan(0);
      input('username').enter('username');
      input('password').enter('password');
      element('#submit').click();
      sleep(3);
    }
    expect(browser().window().path()).toEqual('/');
  });

  it('should logout', function(){
    element('#quit').click();
    element('quit_dialog').click();
    sleep(1);
  });
});

当我通过角度场景在html文件中运行测试时,它工作正常,全部为绿色。当我通过业力运行它时,我得到以下错误:

Error: Permission denied to access property 'angular'

我怀疑这是一个跨域问题,但为什么呢?如果是这样,我该如何解决?

注意:我的应用程序会将某人从基本网址重定向到登录页面。我假设业力可以处理重定向。

编辑:我克隆了angular-seed并且没有动过它(除了更改代理网址之外),这很好。

1 个答案:

答案 0 :(得分:1)

当整页重新加载时,Karma失去了“钩子”。

我目前使用的最佳解决方案是手动导航到该页面。

例如,如果您从“/ login”开始并登录,这会导致页面重定向到“/ home”,Karma将失去钩子。因此,在您登录后,您需要通过手动加载页面来重新获得挂钩,例如:

browser().navigate("/login");
//Do login
element("submitButton").click();
//Page gets redirected to /home after successful login, Karma loses hook
browser().navigate("/home"); //Manually navigate to page to regain hook

这有点像黑客,但这是我所知道的最佳方式。