web-dev-qa-db-ja.com

環境全体にジャスミンマッチャーを追加する方法はありますか

ジャスミン仕様にマッチャーを追加する方法を示すドキュメントはたくさんあります(たとえば、 ここ )。

環境全体にマッチャーを追加する方法を見つけた人はいますか。仕様全体にcopypastaを使用せずに、すべてのテストで呼び出される便利なマッチャーのセットを作成したいと考えています。

現在、ソースのリバースエンジニアリングに取り組んでいますが、実際に試行された方法が存在する場合はそれを優先します。

35
Dancrumb

確かに、スペックスコープをまったく使用せずにbeforeEach()を呼び出し、そこにマッチャーを追加するだけです。

これにより、toBeOfTypeマッチャーがグローバルに追加されます。

beforeEach(function() {
  var matchers = {
    toBeOfType: function(typeString) {
      return typeof this.actual == typeString;
    }
  };

  this.addMatchers(matchers);
});

describe('Thing', function() {
  // matchers available here.
});

spec_helper.jsという名前のファイルを作成しました。カスタムマッチャーなど、残りのスペックスイートを実行する前にページにロードする必要があるものでいっぱいです。

48
Alex Wayne

これがジャスミン2.0以降のものです:

beforeEach(function(){
  jasmine.addMatchers({
    toEqualData: function() {
      return {
        compare: function(actual, expected) {
          return { pass: angular.equals(actual, expected) };
        }
      };
    }
  });
});

これはangularのangular.equalsを使用することに注意してください。

13
mikker

以前の回答に基づいて、angular-cliに対して次のセットアップを作成しました。マッチャーに外部モジュール(この場合はmoment.js)も必要です

この例では、equalityTesterを追加しましたが、カスタマーマッチャーで機能するはずです。

次の内容のファイル_src/spec_helper.ts_を作成します。

_// Import module
import { Moment } from 'moment';

export function initSpecHelper() {

  beforeEach(() => {
    // Add your matcher
    jasmine.addCustomEqualityTester((a: Moment, b: Moment) => {
      if (typeof a.isSame === 'function') {
        return a.isSame(b);
      }
    });
  });

}
_

次に、_src/test.ts_インポートでinitSpecHelper()関数を追加して実行します。 AngularのTestBedinitの前に配置しましたが、問題なく動作しているようです。

_import { initSpecHelper } from './spec_helper';

//...

// Prevent Karma from running prematurely.
__karma__.loaded = function () {};

// Init our own spec helper
initSpecHelper();

// First, initialize the Angular testing environment.
getTestBed().initTestEnvironment(
  BrowserDynamicTestingModule,
  platformBrowserDynamicTesting()
);

//...
_
0
Treur

編集:変更される可能性のある内部実装であるとは知りませんでした。自己責任。

jasmine.Expectation.addCoreMatchers(matchers)
0
Ganesh Sundar C