微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

角度测试,socket.io“NullInjectorError:WrappedSocket 没有提供者”

如何解决角度测试,socket.io“NullInjectorError:WrappedSocket 没有提供者”

我正在 angular 上运行测试,但它们对我使用 ngx-socket-io 的套接字服务失败了。它适用于开发,只是不适用于测试。它没有正确创建组件。

Test failure

我的 service.spec.ts

import { Testbed } from '@angular/core/testing';
import { SocketService } from './socket.service';

describe('SocketService',() => {
  let service: SocketService;

  beforeEach(() => {
    Testbed.configureTestingModule({
    });
    service = Testbed.inject(SocketService);
  });

  it('should be created',() => {
    expect(service).toBeTruthy();
  });
});

我的服务

import { Injectable } from '@angular/core';
import {Socket} from 'ngx-socket-io';

@Injectable({
  providedIn: 'root'
})
export class SocketService {
  constructor(private socket: Socket) { }

  getD1Data() {
    return this.createObserver('d1');
  }

  private createObserver(event: string) {
    return this.socket.fromEvent(event);
  }

我已经尝试添加提供程序 [WrappedSocket] 老实说这是一个自动修复选项,但这导致了更多错误

import {WrappedSocket} from 'ngx-socket-io/src/socket-io.service';

describe('SocketService',() => {
  let service: SocketService;

  beforeEach(() => {
    Testbed.configureTestingModule({
      providers: [WrappedSocket]
    });
    service = Testbed.inject(SocketService);
  });


Error: ./src/app/modules/socket.service.spec.ts
Module not found: Error: Can't resolve 'ngx-socket-io/src/socket-io.service' in 'C:\Users\catha\project - copy\src\app\modules'

我实际上不确定它怎么可能不存在,因为它是一个自动填充。

关于如何解决这个问题的任何想法?我尝试了一系列提供者 [Socket],[SocketIOModule] 但似乎没有任何效果

解决方法

我们必须使用 config 类型的对象 SocketIoConfig 配置 SocketIOModule。

... //imports

const config: SocketIoConfig = { url: 'http://localhost:YOUR_PORT' };

describe('SocketService',() => {
  let service: SocketService;

  beforeEach(() => {
    TestBed.configureTestingModule({
      imports: [ SocketIOModule.forRoot(config) ],providers: [ SocketService ]
    });
    service = TestBed.inject(SocketService);
  });

  it('should be created',() => {
    expect(service).toBeTruthy();
  });
});

希望这会有所帮助!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。