javascript - ui.bootstrap 破坏了我的单元测试并出现意外结果错误?

标签 javascript angularjs unit-testing karma-jasmine ui.bootstrap

在 Controller 中,我使用 ui.bootstrap 在我的页面上实现分页,安装 ui.bootstrap 后,我在单元测试中收到以下错误消息

After using ui.bootstrap I got following error message

这是我的测试文件:

'use strict';

describe('LoginCtrl', function () {

  beforeEach(module('taxihomeFrontendApp'));

  var LoginCtrl,
    scope;

  var $httpBackend = {};

  beforeEach(inject(function ($controller, $rootScope, _$httpBackend_) {
    scope = $rootScope.$new();
    LoginCtrl = $controller('LoginCtrl', {
      $scope: scope
    });
    $httpBackend = _$httpBackend_;
  }));

  afterEach(function () {
    $httpBackend.verifyNoOutstandingExpectation();
    $httpBackend.verifyNoOutstandingRequest();
  });

  it('should fail authentication', function(){
    var credentials = {'username':'badDriver', 'password':'1234'};
    $httpBackend.
      whenPOST('http://localhost:3000/login', credentials).
      respond(403, {error: 'not allowed'});
    scope.credentials = {
      username: 'badDriver',
      password: '1234'
    };
    scope.login(scope.credentials);
    $httpBackend.flush();
    expect(scope.error).toEqual('Something went wrong not allowed');
  });

});

我的 Karma 配置

// Karma configuration
// http://karma-runner.github.io/0.12/config/configuration-file.html
// Generated on 2015-04-23 using
// generator-karma 0.9.0

module.exports = function(config) {
  'use strict';

  config.set({
    // enable / disable watching file and executing tests whenever any file changes
    autoWatch: true,

    // base path, that will be used to resolve files and exclude
    basePath: '../',

    // testing framework to use (jasmine/mocha/qunit/...)
    frameworks: ['jasmine'],

    // list of files / patterns to load in the browser
    files: [
      // bower:js
      'bower_components/jquery/dist/jquery.js',
      'bower_components/angular/angular.js',
      'bower_components/angular-bootstrap/ui-bootstrap-tpls.js',
      'bower_components/bootstrap/dist/js/bootstrap.js',
      'bower_components/angular-animate/angular-animate.js',
      'bower_components/angular-cookies/angular-cookies.js',
      'bower_components/angular-resource/angular-resource.js',
      'bower_components/angular-route/angular-route.js',
      'bower_components/angular-sanitize/angular-sanitize.js',
      'bower_components/angular-touch/angular-touch.js',
      'bower_components/angular-mocks/angular-mocks.js',
      // endbower
      'app/scripts/**/*.js',
      'test/mock/**/*.js',
      'test/spec/**/*.js'
    ],

    // list of files / patterns to exclude
    exclude: [
    ],

    // web server port
    port: 8080,

    // Start these browsers, currently available:
    // - Chrome
    // - ChromeCanary
    // - Firefox
    // - Opera
    // - Safari (only Mac)
    // - PhantomJS
    // - IE (only Windows)
    browsers: [
      'PhantomJS'
    ],

    // Which plugins to enable
    plugins: [
      'karma-phantomjs-launcher',
      'karma-jasmine'
    ],

    // Continuous Integration mode
    // if true, it capture browsers, run tests and exit
    singleRun: false,

    colors: true,

    // level of logging
    // possible values: LOG_DISABLE || LOG_ERROR || LOG_WARN || LOG_INFO || LOG_DEBUG
    logLevel: config.LOG_INFO,

    // Uncomment the following lines if you are using grunt's server to run the tests
    // proxies: {
    //   '/': 'http://localhost:9000/'
    // },
    // URL root prevent conflicts with the site root
    // urlRoot: '_karma_'
  });
};

我使用 yo Angular 来搭建项目

最佳答案

您还需要模拟模板文件的 GET 请求:

$httpBackend.expectGET('views/login.html').respond('<div>something</div>');

将其放在 beforeEach 中的 it 部分中。

关于javascript - ui.bootstrap 破坏了我的单元测试并出现意外结果错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30156447/

相关文章:

c# - 像在 WebOperationContext 中一样在模拟 WebOperationContext 中执行 CreateTextResponse(...)

javascript - 在 React js 中将字符串转换为 HTML 代码

javascript - 使用 momentjs 检查日期是否与格式匹配

javascript - 这种服务声明方法有什么区别?

angularjs - 使用嵌套指令时,ng-click 在第一次使用 $compile 后停止工作

java - JUnit 断言 null - 使用 stub 和模拟

java - 是否有任何适用于 Java 的假文件系统框架?

javascript - 如何向 d3.js 饼图或圆环图添加阴影

javascript - 如何在网页中加载 Electron 窗口?

angularjs - $on 只在一个 Controller 上被调用