【问题标题】:ui.bootstrap breaks my unit tests with unexpected results error?ui.bootstrap 因意外结果错误而破坏了我的单元测试?
【发布时间】:2015-07-21 07:04:48
【问题描述】:

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

这是我的测试文件:

'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 来搭建项目

【问题讨论】:

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


    【解决方案1】:

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

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

    把它放在beforeEachit 部分。

    【讨论】:

    • 我收到以下错误消息:错误:意外请求:POST localhost:3000/login 预期 GET views/login.html
    • 谢谢我修复了它 $httpBackend.expectGET 而我使用 $httpBackend.whenGET 并且它解决了问题
    猜你喜欢
    • 2015-02-27
    • 1970-01-01
    • 2011-08-04
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-02-04
    相关资源
    最近更新 更多