Angular 7测试依赖于私有方法的公共方法

路博斯

我正在使用angular 7.1和Jasmine测试我的组件。我正在尝试编写一些测试,但这对我来说似乎太多了。

我正在尝试测试的简化课程:

import { HttpClient } from '@angular/common/http';

@Component({
  selector: 'a',
  templateUrl: './a.html',
  styleUrls: ['./a.scss']
}
export class A implements OnInit {
  constructor(private http: HttpClient) {}
  private privateState: State;
  public publicState: State2;      

  ngOnInit() {
      this.http.get(this.GetUrl()).subscribe((x) => {
      this.privateState = x['whatever'];
    });
  }

  private hiddenComplexFunction() {
    this.publicState = this.privateState.something;
  }

  public testedFunction() {
    //someComplex Code
    this.hiddenComplexFunction();
  }
}

我尝试过的

  • 我试图像这样设置私有变量,A.['privateState']但是没有用
  • 我尝试使用SpyOn http get,但是在必须设置私有属性时遇到了同样的问题
  • 我尝试使用HttpClientTestingModule,但与上一点存在相同的问题
  • 最后,我尝试通过以下方式对privateState进行保护和测试:

    import { HttpClientTestingModule } from '@angular/common/http/testing';
    import { async, ComponentFixture, TestBed } from '@angular/core/testing';
    
    class AMock extends A {
      ngOnInit() {
        //privateState is now protected
        this.privateState = mockedState;
      }
    }
    describe('A', () => {
      let component: AMock;
      let fixture: ComponentFixture<AMock>;
    
      beforeEach(async(() => {
        TestBed.configureTestingModule({
          imports: [HttpClientTestingModule],
          declarations: [AMock]
        })
          .compileComponents().catch();
      }));
    
      beforeEach(() => {
        fixture = TestBed.createComponent(AMock);
        component = fixture.componentInstance;
      });
    
      it('testedFunction should set up public state correctly', () => {
        component.testedFunction();
    
        expect(component.publicState).toEqual(mockedState.something);
      });
    

    最后一点不起作用,并返回错误,因为在运行ng test命令后无法读取未定义的属性“ testedFunction”

我不知道哪种方法是测试此方法的正确方法。我知道我可以hiddenComplexFunction公开,我所有的问题都会消失,而且我不喜欢这样的事实,由于测试,我必须更改访问修饰符(如模拟示例中那样,从私有更改为受保护,这对我来说似乎完全不对)。

杰森·伍兹(Jason Woods)

您的问题有很多事情,因此,我将从我容易看到的事情开始。

我们可以从您的核心组件代码开始。在您的testingFunction()中,调用this.hiddenComplexFunction()。您需要函数的实例版本,因此需要向其添加““ this。”“。完全合适,而且您也不想直接测试私有功能/私有属性。

接下来,我猜你想要这个代码

this.state = x['whatever'];

设置您的privateState,而不是state

this.privateState = x['whatever'];

接下来,您不需要在您的AMock类上模拟A,测试装配将为您完成。请尝试以下类似方法作为开始。我在这里没有的是州代码。我真正要做的就是摆脱您的AMock并将其替换为实际的组件,并建立一个测试状态(并且可能会建立状态较差,我可能会补充。哈!)。我在下面处理HTTP数据,这与您通过查看代码猜测的状态有关。

import { HttpClientTestingModule } from '@angular/common/http/testing';
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { A } from './zing.component';  // this should point to your component

// get rid of this, not needed
// class AMock extends A {
//   ngOnInit() {
//     //privateState is now protected
//     let privateState = mockedState;
//   }
// }

describe('A', () => {
  let component: A;  // changed from AMock to A
  let fixture: ComponentFixture<A>; // changed from AMock to A

  let mockedState = {something: 'yelp'}; // build your expected state here

  beforeEach(async(() => {
    TestBed.configureTestingModule({
      imports: [HttpClientTestingModule],
      declarations: [A] // changed from AMock to A
    })
      .compileComponents().catch();
  }));

  beforeEach(() => {
    fixture = TestBed.createComponent(A); // changed from AMock to A
    component = fixture.componentInstance;
  });

  it('testedFunction should set up public state correctly', () => {
    component.testedFunction();

    expect(component.publicState).toEqual(mockedState.something);
  });
});

最后,对于HTTP模拟,您可以使用HttpTestingController将一些数据刷新到您的组件。

在描述块中-

let backend: HttpTestingController;

在每个之前-

backend = TestBed.get(HttpTestingController);

在您的IT声明中-

backend.expectOne(expectedURL).flush(mockedState);

backend.verify();

如果有帮助或遇到其他错误,请告诉我们您能走多远。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

如何使用依赖项测试Angular 6服务,该依赖项使用私有方法/属性修改公共方法/属性的输出

如何使用Jasmine为私有方法编写Angular / TypeScript的单元测试

如何测试依赖于包含 BehaviorSubject 的服务的 Angular 组件?

Angular:如何使私有方法进入代码覆盖范围?

如何测试具有私有方法依赖项的公共函数?

为什么angular的依赖注入需要私有或公共工作?

私有方法优于公共方法

依赖于Angular / Ionic模块中的ModalController导致服务“无法解析所有参数”

继承私有方法和公共

Python 公共和私有方法

有哪些方法可以测试依赖于静态方法的方法?

如何使元素依赖于Angular中的数据属性?

HTML 输入验证(Angular)依赖于其他字段

单元测试Angular服务,该服务依赖于另一个使用InjectionToken的服务

如何对一个依赖于其注册回调的Angular服务进行单元测试?

我应该测试私有方法还是仅测试公共方法?

单元测试依赖于StreamReader读取文件的方法

如何测试依赖于环境变量的Rust方法?

使用RSpec测试依赖于外部Cassandra调用的方法

因果报应测试指令说angular.element没有方法``隐藏''

在Raku中测试私有方法

在Groovy中测试私有方法

在JestJS中测试私有方法

Angular组件中的“私有”和“公共”

如何对测试私有方法并依次调用Web服务方法的公共方法进行单元测试

将公共方法转换为私有方法

在私有方法中模拟公共方法

Angular2-测试是否已调用注入的私有服务方法

Nunit 测试 - 测试被公共方法调用的私有方法代码的一部分