2017-02-22 13:13:21 -05:00
|
|
|
/* tslint:disable */
|
|
|
|
// #docregion routestuff
|
2020-07-31 15:43:18 -04:00
|
|
|
import {SpyLocation} from '@angular/common/testing';
|
|
|
|
import {NO_ERRORS_SCHEMA} from '@angular/core';
|
|
|
|
import {ComponentFixture, TestBed, waitForAsync} from '@angular/core/testing';
|
|
|
|
import {ActivatedRoute} from '@angular/router';
|
|
|
|
import {Observable, of} from 'rxjs';
|
2017-02-22 13:13:21 -05:00
|
|
|
|
2020-07-31 15:43:18 -04:00
|
|
|
import {Phone, PhoneData} from '../core/phone/phone.service';
|
|
|
|
|
|
|
|
import {PhoneListComponent} from './phone-list.component';
|
2017-02-22 13:13:21 -05:00
|
|
|
|
|
|
|
// #enddocregion routestuff
|
|
|
|
|
|
|
|
class ActivatedRouteMock {
|
|
|
|
constructor(public snapshot: any) {}
|
|
|
|
}
|
|
|
|
|
|
|
|
class MockPhone {
|
|
|
|
query(): Observable<PhoneData[]> {
|
2018-06-20 07:01:23 -04:00
|
|
|
return of([
|
2020-07-31 15:43:18 -04:00
|
|
|
{name: 'Nexus S', snippet: '', images: []}, {name: 'Motorola DROID', snippet: '', images: []}
|
2017-02-22 13:13:21 -05:00
|
|
|
]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
let fixture: ComponentFixture<PhoneListComponent>;
|
|
|
|
|
|
|
|
describe('PhoneList', () => {
|
|
|
|
// #docregion routestuff
|
|
|
|
|
2020-07-31 15:43:18 -04:00
|
|
|
beforeEach(waitForAsync(() => {
|
|
|
|
TestBed
|
|
|
|
.configureTestingModule({
|
|
|
|
declarations: [PhoneListComponent],
|
|
|
|
providers: [
|
|
|
|
{provide: ActivatedRoute, useValue: new ActivatedRouteMock({params: {'phoneId': 1}})},
|
|
|
|
{provide: Location, useClass: SpyLocation},
|
|
|
|
{provide: Phone, useClass: MockPhone},
|
|
|
|
],
|
|
|
|
schemas: [NO_ERRORS_SCHEMA]
|
|
|
|
})
|
|
|
|
.compileComponents();
|
2017-02-22 13:13:21 -05:00
|
|
|
}));
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
fixture = TestBed.createComponent(PhoneListComponent);
|
|
|
|
});
|
|
|
|
// #enddocregion routestuff
|
|
|
|
|
|
|
|
it('should create "phones" model with 2 phones fetched from xhr', () => {
|
|
|
|
fixture.detectChanges();
|
|
|
|
let compiled = fixture.debugElement.nativeElement;
|
|
|
|
expect(compiled.querySelectorAll('.phone-list-item').length).toBe(2);
|
2020-07-31 15:43:18 -04:00
|
|
|
expect(compiled.querySelector('.phone-list-item:nth-child(1)').textContent)
|
|
|
|
.toContain('Motorola DROID');
|
|
|
|
expect(compiled.querySelector('.phone-list-item:nth-child(2)').textContent)
|
|
|
|
.toContain('Nexus S');
|
2017-02-22 13:13:21 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
xit('should set the default value of orderProp model', () => {
|
|
|
|
fixture.detectChanges();
|
|
|
|
let compiled = fixture.debugElement.nativeElement;
|
2020-07-31 15:43:18 -04:00
|
|
|
expect(compiled.querySelector('select option:last-child').selected).toBe(true);
|
2017-02-22 13:13:21 -05:00
|
|
|
});
|
|
|
|
});
|