角度2ユニットテスト(ジャスミン)におけるキー押下イベントをシミュレートすることができません。ここIフィルタテキストとして使用される入力データを取得するためのディレクティブを使用してい
ディレクティブで私hostlistenerです:
@HostListener('input', ['$event.target.value'])
public onChangeFilter(event: any): void {
console.log('input event fired, value: ' + event);
this.columnFiltering.filterString = event;
this.filterChanged.emit({filtering: this.columnFiltering});
}
このコードは完璧に働いている、私は同じユニットテストすることができません。
私は値を確認するために私のユニットテストでは、filterChanged持つEventEmitterに加入しています。
私は値を変更するにはKeyPressイベントをシミュレートしてみましたし、また設定値の属性を試してみました。これらのどれも私のために働いていません。ここ
は私のspecファイルである:
describe('Table View',() => {
let fixture: ComponentFixture<any>;
let context: TableComponent;
beforeEach(() => {
TestBed.configureTestingModule({
providers: [
TableComponent,
],
imports: [TableModule],
});
fixture = TestBed.createComponent(TableComponent);
context = fixture.componentInstance;
});
it('should allow filter',() => {
const element = fixture.nativeElement;
context.config = config;
fixture.detectChanges();
let tableChangeCount = 0;
let tableEvent: any;
context.tableChanged.subscribe((event: any) => {
tableChangeCount++;
tableEvent = event;
});
// Check if table exists
let inputElement = element.querySelectorAll('tr')[1].querySelector('input');
let e = new KeyboardEvent("keypress", {
key: "a",
bubbles: true,
cancelable: true,
});
inputElement.dispatchEvent(e);
});
});
私は値を設定してみました:
let attrs = inputElement.attributes;
inputElement.setAttribute('value', 'abc');
for (let i = attrs.length - 1; i >= 0; i--) {
// Attribute value is set correctly
if (attrs[i].name === 'value') {
console.log(attrs[i].name + "->" + attrs[i].value);
}
}
誰がどのように私はユニット同じことをテストすることができ、私を助けてくださいことはできますか?
を_ "ここに私のスペックファイルです: "_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _あなたが間違っていることを試してみるために、_ _ _ _ _ _ _ _ _ _ _ _ –
フルテストテストが追加されました。ボタンをクリックして並べ替えとリフレッシュを行いました。正しく動作しています。ここに貼り付けられました – Akanksha
あなたの期待はどこですか? –