中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Jest如何測試GraphQL的實時查詢

發布時間:2024-08-27 21:33:51 來源:億速云 閱讀:81 作者:小樊 欄目:編程語言

要使用Jest測試GraphQL的實時查詢,你需要模擬WebSocket連接并在測試中發送和接收消息

  1. 首先,確保你已經安裝了以下依賴項:
npm install --save-dev jest @types/jest graphql-ws ws
  1. 創建一個__tests__文件夾來存放你的測試文件。

  2. __tests__文件夾中創建一個名為graphql-realtime.test.ts的文件,然后編寫以下代碼:

import { createServer } from 'http';
import { Server } from 'ws';
import { GraphQLSchema, GraphQLObjectType, GraphQLString } from 'graphql';
import { useServer } from 'graphql-ws/lib/use/ws';
import { SubscriptionServer } from 'subscriptions-transport-ws';
import { execute, subscribe } from 'graphql';
import { PubSub } from 'graphql-subscriptions';

// 創建一個簡單的GraphQL schema
const schema = new GraphQLSchema({
  query: new GraphQLObjectType({
    name: 'Query',
    fields: {
      message: {
        type: GraphQLString,
        resolve: () => 'Hello World!',
      },
    },
  }),
  subscription: new GraphQLObjectType({
    name: 'Subscription',
    fields: {
      message: {
        type: GraphQLString,
        subscribe: (_, __, { pubsub }) => pubsub.asyncIterator('MESSAGE'),
      },
    },
  }),
});

describe('GraphQL Realtime Query', () => {
  let httpServer;
  let wsServer;
  let pubsub;

  beforeEach(() => {
    httpServer = createServer();
    wsServer = new Server({ server: httpServer });
    pubsub = new PubSub();

    useServer(
      {
        schema,
        execute,
        subscribe,
        context: () => ({ pubsub }),
      },
      wsServer
    );

    httpServer.listen(4000);
  });

  afterEach(() => {
    if (httpServer) {
      httpServer.close();
    }
    if (wsServer) {
      wsServer.close();
    }
  });

  it('should receive realtime messages', async () => {
    // 創建一個WebSocket客戶端
    const client = new WebSocket('ws://localhost:4000/graphql');

    // 等待WebSocket連接建立
    await new Promise((resolve) => client.onopen = resolve);

    // 訂閱實時消息
    client.send(JSON.stringify({
      type: 'start',
      id: '1',
      payload: {
        query: `
          subscription {
            message
          }
        `,
      },
    }));

    // 發送實時消息
    pubsub.publish('MESSAGE', { message: 'Hello from realtime query!' });

    // 等待實時消息到達
    const response = await new Promise((resolve) => client.onmessage = resolve);

    // 斷言收到的消息
    expect(JSON.parse(response.data)).toEqual({
      type: 'data',
      id: '1',
      payload: { data: { message: 'Hello from realtime query!' } },
    });
  });
});

這個測試將創建一個GraphQL服務器,使用graphql-ws庫提供實時查詢支持,并通過WebSocket連接發送和接收實時消息。測試將訂閱實時消息,然后發布一條消息,最后檢查是否收到了正確的消息。

  1. 運行測試:
npx jest __tests__/graphql-realtime.test.ts

這個測試應該能夠成功通過,表明你已經成功地使用Jest測試了GraphQL的實時查詢。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

定州市| 收藏| 马山县| 莲花县| 阿鲁科尔沁旗| 高淳县| 汉沽区| 行唐县| 磴口县| 凭祥市| 海安县| 奉节县| 肇源县| 澳门| 黎平县| 容城县| 金乡县| 桐柏县| 同仁县| 星座| 四平市| 新野县| 孝昌县| 开阳县| 澎湖县| 万荣县| 垣曲县| 石楼县| 且末县| 昌图县| 罗山县| 昌平区| 垫江县| 延寿县| 城市| 利川市| 大悟县| 遵化市| 长沙市| 囊谦县| 贵定县|