带有输入的材料芯片的角单元测试

时间:2019-11-01 12:23:13

标签: angular unit-testing angular-material

我正在尝试对mat-chips元素进行单元测试,当前出现一个错误:无法绑定到'matChipInputFor',因为它不是'input'的已知属性。目前,“角度材质”页面尚未提供示例的单元测试。我使用过的示例在https://material.angular.io/components/chips/overview

中有介绍

如何在给定输入的单元测试中添加该属性,例如matChipInputFor?

模板

<mat-form-field class="example-chip-list">
  <mat-chip-list #chipList aria-label="Fruit selection">
    <mat-chip *ngFor="let fruit of fruits" [selectable]="selectable"
             [removable]="removable" (removed)="remove(fruit)">
      {{fruit.name}}
      <mat-icon matChipRemove *ngIf="removable">cancel</mat-icon>
    </mat-chip>
    <input placeholder="New fruit..."
           [matChipInputFor]="chipList"
           [matChipInputSeparatorKeyCodes]="separatorKeysCodes"
           [matChipInputAddOnBlur]="addOnBlur"
           (matChipInputTokenEnd)="add($event)">
  </mat-chip-list>
</mat-form-field>

控制器

import {Component} from '@angular/core';
import {FormBuilder, FormGroup} from '@angular/forms';
import {MatChipInputEvent} from '@angular/material/chips';
import {COMMA, ENTER} from '@angular/cdk/keycodes';

export interface Fruit {
  name: string;
}

@Component({
  selector: 'app-home',
  templateUrl: './home.component.html',
  styleUrls: ['./home.component.css']
})
export class HomeComponent {
  //required for the kitchen sink form
  options: FormGroup;
  visible = true;
  selectable = true;
  removable = true;
  addOnBlur = true;

  constructor(fb: FormBuilder) {
    this.options = fb.group({
      hideRequired: false,
      floatLabel: 'auto',
    });
  }

  readonly separatorKeysCodes: number[] = [ENTER, COMMA];
  fruits: Fruit[] = [
    {name: 'Lemon'},
    {name: 'Lime'},
    {name: 'Apple'},
  ];

  add(event: MatChipInputEvent): void {
    const input = event.input;
    const value = event.value;

    // Add our fruit
    if ((value || '').trim()) {
      this.fruits.push({name: value.trim()});
    }

    // Reset the input value
    if (input) {
      input.value = '';
    }
  }

  remove(fruit: Fruit): void {
    const index = this.fruits.indexOf(fruit);

    if (index >= 0) {
      this.fruits.splice(index, 1);
    }
  }
}

单元测试(模板具有更多元素)

import { ComponentFixture, TestBed } from '@angular/core/testing';
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
import { GivenComponent } from './given.component';
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
import { ObserversModule } from '@angular/cdk/observers'; 
import { OverlayModule } from '@angular/cdk/overlay';

//Material imports
import { 
  MatCard,
  MatRadioButton,
  MatRadioGroup,
  MatIcon,
  MatChip,
  MatChipList,
  MatCheckbox,
  MatSlideToggle,
  MatRippleModule,
  MatTabsModule,
  MatDialogModule,
  MatSelectModule,
  MatInputModule
} from '@angular/material';

describe('GivenComponent', () => {
  let component: GivenComponent;
  let fixture: ComponentFixture<GivenComponent>;

  beforeEach(() => {
    TestBed.configureTestingModule({
      imports: [
        FormsModule,
        ReactiveFormsModule,
        BrowserAnimationsModule,
        ObserversModule, 
        MatRippleModule,
        OverlayModule,
        MatTabsModule,
        MatDialogModule,
        MatSelectModule,
        MatInputModule
      ],
      declarations: [
        GivenComponent,
        MatCard,
        MatRadioButton,
        MatRadioGroup,
        MatIcon,
        MatChip,
        MatChipList,
        MatCheckbox,
        MatSlideToggle
      ]
    });
    fixture = TestBed.createComponent(GivenComponent);
    component = fixture.componentInstance;
    fixture.detectChanges();
  });

  it('should create', () => {
    expect(component).toBeDefined();
  });
});

1 个答案:

答案 0 :(得分:0)

您需要导入提供此指令的MatChipsModule

https://material.angular.io/components/chips/api