0

variable from service is coming as undefined

Below is my ts file

ngOnInit() {

        this.serviceElectionForm.form = this.formBuilder.group({});

     /****
         * commenting below, if condition,  doesnt cause any error in spec file
         */
        if (this.registerService.submitReg.isAdminFlow) {
          this.companyDesignationForm.form = this.formBuilder.group({});
        }


        this.userAuthenticationForm.form = this.formBuilder.group({});
        this.roleDesignationForm.form = this.formBuilder.group({});

      }

below is my spec file

fdescribe('RegisterComponent', () => {
  let component: RegisterComponent;
  let fixture: ComponentFixture<RegisterComponent>;



  const MockRegisterService = {
    isAdminFlow: true,
  }

  beforeEach(async(() => {
    TestBed.configureTestingModule({
      declarations: [
        RegisterComponent,

      ],
      imports: [
        AngularMaterialsGlobalModule,
        RouterTestingModule,
        ReactiveFormsModule,
        NoopAnimationsModule,
        HttpClientTestingModule
      ],
      providers: [
        { provide: RegisterService, useValue: MockRegisterService },
        CookieService
      ]
    }).compileComponents();
  }));

  describe('Base instantiation and component creation', () => {

    beforeEach(() => {
      fixture = TestBed.createComponent(RegisterComponent);
      component = fixture.componentInstance;
      fixture.detectChanges();
    });

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

The error which I am getting is

typeError: Cannot read property 'isAdminFlow' of undefined TypeError: Cannot read property 'isAdminFlow' of undefined at RegisterComponent../src/app/pages/registration/register.component.ts.RegisterComponent.ngOnInit

4

1 回答 1

0

试试这个,您的服务期望submitReg在该属性所在的内部有一个名为的属性isAdminFlow

const MockRegisterService = {
    submitReg:{
     isAdminFlow: true,
    }
  }
于 2019-06-18T16:49:34.960 回答