Apollo GraphQL模拟分段数据
创始人
2024-09-09 03:30:20
0

要在Apollo GraphQL中模拟分段数据,可以使用MockLinkInMemoryCache。这样可以在应用程序开发的早期阶段模拟数据,并且可以与后端API解耦。

先安装所需的依赖:

npm install apollo-link apollo-link-http apollo-link-schema apollo-cache-inmemory graphql-tools graphql

然后创建一个mocked schema和数据源文件(例如mocks.js):

const { ApolloServer, gql } = require('apollo-server');
const { makeExecutableSchema } = require('graphql-tools');

// 定义模拟数据
const books = [
  { id: '1', title: 'Book 1', author: 'Author 1' },
  { id: '2', title: 'Book 2', author: 'Author 2' },
  { id: '3', title: 'Book 3', author: 'Author 3' },
];

// 定义schema
const typeDefs = gql`
  type Book {
    id: ID!
    title: String!
    author: String!
  }

  type Query {
    books(offset: Int!, limit: Int!): [Book!]!
  }
`;

// 定义解析器
const resolvers = {
  Query: {
    books: (_, { offset, limit }) => books.slice(offset, offset + limit),
  },
};

// 创建schema
const schema = makeExecutableSchema({
  typeDefs,
  resolvers,
});

// 创建ApolloServer
const server = new ApolloServer({ schema });

// 启动服务器
server.listen().then(({ url }) => {
  console.log(`Server ready at ${url}`);
});

接下来,在应用程序中使用mocked schema和数据源。例如,如果使用React和Apollo Client:

import React from 'react';
import { ApolloProvider, ApolloClient, InMemoryCache } from '@apollo/client';
import { MockLink } from '@apollo/client/testing';

import { mocks } from './mocks';

// 创建mocked link
const link = new MockLink(mocks);

// 创建Apollo Client
const client = new ApolloClient({
  cache: new InMemoryCache(),
  link,
});

// 使用Apollo Provider包装根组件
const App = () => (
  
    {/* 应用程序内容 */}
  
);

最后,在测试中使用mocked schema和数据源。例如,如果使用Jest进行测试:

import { ApolloClient, InMemoryCache } from '@apollo/client';
import { MockLink } from '@apollo/client/testing';

import { mocks } from './mocks';

// 创建mocked link
const link = new MockLink(mocks);

// 创建Apollo Client
const client = new ApolloClient({
  cache: new InMemoryCache(),
  link,
});

// 在测试中使用client进行查询
test('should return mocked books', () => {
  const response = await client.query({
    query: gql`
      query GetBooks {
        books(offset: 0, limit: 10) {
          id
          title
          author
        }
      }
    `,
  });

  // 检查返回的模拟数据
  expect(response.data.books).toEqual([
    { id: '1', title: 'Book 1', author: 'Author 1' },
    { id: '2', title: 'Book 2', author: 'Author 2' },
    { id: '3', title: 'Book 3', author: 'Author 3' },
  ]);
});

这样,你就可以在Apollo GraphQL中模拟分段数据了。通过使用MockLinkInMemoryCache,你可以在应用程序开发的早期阶段模拟数据,并且可以与后端API解耦。

相关内容

热门资讯

实测必看!aapoker教程(... 相信很多朋友都在电脑上玩过aapoker教程吧,但是很多朋友都在抱怨用电脑玩起来不方便。为此小编给大...
玩家必备教程(aapoker俱... 1、玩家必备教程(aapoker俱乐部)外挂透明挂辅助神器(透视)德州ai机器人(有挂方略)-哔哩哔...
透视透明!德扑之星入池率(We... 透视透明!德扑之星入池率(WePoke)外挂透明挂辅助APP(透视)安装教程(有挂方法)-哔哩哔哩;...
推荐几款新版(德扑之星刷数据)... 推荐几款新版(德扑之星刷数据)外挂透明挂辅助机制(辅助挂)透视辅助(有挂秘籍)-哔哩哔哩;亲们利用一...
透视系统!微扑克稳赢(WepO... 透视系统!微扑克稳赢(WepOke)外挂透明挂辅助机制(透视)2024新版总结(有挂攻略)-哔哩哔哩...
分享一款(aapoker能玩)... 分享一款(aapoker能玩)外挂透明挂辅助插件(辅助挂)其实是真的有挂(2020已更新)(哔哩哔哩...
我来教教你!德州ai软件(we... 我来教教你!德州ai软件(wePOKE)外挂透明挂辅助工具(透视)爆料教程(有挂秘籍)-哔哩哔哩是一...
实操分享(WPK内置)外挂透明... 实操分享(WPK内置)外挂透明挂辅助挂(透视)软件透明挂(发现有挂)-哔哩哔哩1、不需要AI权限,帮...
透视好牌(wepOKE)外挂透... 透视好牌(wepOKE)外挂透明挂辅助软件(辅助挂)辅助透视(有挂技术)-哔哩哔哩;玩家在wepOK...
2分钟细说(德扑ai机器人)外... 德扑ai机器人新手教程相关信息汇总(需添加指定薇757446909获取下载链接);2分钟细说(德扑a...