13

いくつかのアクションを実行する前に、単純な javascript 確認を使用するAngularjsアプリケーションがあります。

コントローラ:

function TokenController($scope) {
  $scope.token = 'sampleToken';

  $scope.newToken = function() {
    if (confirm("Are you sure you want to change the token?") == true) {
      $scope.token = 'modifiedToken';
    }
  };
}

意見:

<div id="tokenDiv">
  Token:{{token}} <button ng-click="newToken()">New Token</button>
</div>

ここで、トークンがビューで正しく置き換えられていることを確認するためのエンド ツー エンド テストが必要です。javascript.confirm()テストの実行を停止しないように、呼び出しを傍受するにはどうすればよいですか?

テスト:

it('should be able to generate new token', function () {
   var oldValues = element('#tokenDiv').text();
   element('button[ng-click="newToken()"]').click(); // Here the javascript confirm box pops up.
   expect(element('#tokenDiv').text()).not.toBe(oldValues);
});

これまでのところ、window.confirm関数を再定義しようとしましたが、実際の呼び出しは未定義であると不平を言っています。

また、Jasmine スパイをセットアップしたかったwindow.confirmのですが、次の構文spyOn(window, 'confirm');では、スパイできないというエラーが表示されnullます。

そのようなテストを機能させるにはどうすればよいですか?

4

3 に答える 3

29

別のオプションは、スパイを直接作成し、自動的に返すことtrueです:

//Jasmine 2.0
spyOn(window, 'confirm').and.callFake(function () {
     return true;
});

//Jasmine 1.3
spyOn(window, 'confirm').andCallFake(function () {
     return true;
});
于 2014-08-29T14:09:39.380 に答える
13

E2E テスト

このプロジェクトに相談してください: https://github.com/katranci/Angular-E2E-W​​indow-Dialog-Commands

単体テスト

ダイアログ ボックス用のサービスを作成する場合、単体テストでそのサービスをモックして、コードをテスト可能にすることができます。

コントローラ

function TokenController($scope, modalDialog) {
  $scope.token = 'sampleToken';

  $scope.newToken = function() {
    if (modalDialog.confirm("Are you sure you want to change the token?") == true) {
      $scope.token = 'modifiedToken';
    }
  };
}

モーダル ダイアログ サービス

yourApp.factory('modalDialog', ['$window', function($window) {
    return {
        confirm: function(message) {
            return $window.confirm(message);
        }
    }
}]);

modalDialogMock

function modalDialogMock() {
    this.confirmResult;

    this.confirm = function() {
        return this.confirmResult;
    }

    this.confirmTrue = function() {
        this.confirmResult = true;
    }

    this.confirmFalse = function() {
        this.confirmResult = false;
    }
}

テスト

var scope;
var modalDialog;

beforeEach(module('yourApp'));

beforeEach(inject(function($rootScope, $controller) {
    scope = $rootScope.$new();
    modalDialog = new modalDialogMock();
    var ctrl = $controller('TokenController', {$scope: scope, modalDialog: modalDialog});
}));

it('should be able to generate new token', function () {
   modalDialog.confirmTrue();

   scope.newToken();
   expect(scope.token).toBe('modifiedToken');
});
于 2013-05-08T11:53:31.210 に答える
7

単体テストでは、次のように $window オブジェクトをモックできます。

あなたのテスト:

beforeEach(function() {
    module('myAppName');

    inject(function($rootScope, $injector) {
        $controller = $injector.get('$controller');
        $scope = $rootScope.$new();
        var windowMock = { confirm: function(msg) { return true } }
        $controller('UsersCtrl', { $scope: $scope, $window: windowMock });
    });
});

あなたのコントローラー:

myAppName.controller('UsersCtrl', function($scope, $window) {
    $scope.delete = function() {
        var answer = $window.confirm('Delete?');
        if (answer) {
             // doing something
        }
    }
});
于 2013-09-27T11:21:47.060 に答える