加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

如何为打开模态的Angular5 HttpInterceptor编写单元测试?

发布时间:2020-12-17 17:11:23 所属栏目:安全 来源:网络整理
导读:我的拦截器是: @Injectable()export class ErrorInterceptor implements HttpInterceptor { constructor(private _ngbModal: NgbModal) {} intercept(request: HttpRequestany,next: HttpHandler): ObservableHttpEventany { return next.handle(request) .
我的拦截器是:

@Injectable()
export class ErrorInterceptor implements HttpInterceptor {
  constructor(private _ngbModal: NgbModal) {}

  intercept(request: HttpRequest<any>,next: HttpHandler): Observable<HttpEvent<any>> {
    return next.handle(request)
    .catch((err) => {
      let componentInstance = this._ngbModal.open(ErrormodalComponent,{size: 'sm',backdrop: 'static' }).componentInstance

      switch(err.status) {
        case 401:
          componentInstance["message"] = "User session lost,please logout and log back in."
          break;
        case 404:
          componentInstance["message"] = "API Route Not found"
          break;
        default:
          componentInstance["message"] = "API Currently Unavailable. Please try again."
          break;


      }
      return Observable.throw(err);
    })
  }
}

我想编写一个测试,检查模式是否已根据状态使用适当的消息打开.

谢谢

解决方法

我会嘲笑_ngbModal并使用open方法并返回一个组件实例并检查componentInstance上的消息键.

由于_ngbModal是第三方并已经过测试,因此需要实际测试模态.

希望这可以帮助.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读