如何在 Flutter 集成测试中最好地存根/模拟 rest API 调用

Posted

技术标签:

【中文标题】如何在 Flutter 集成测试中最好地存根/模拟 rest API 调用【英文标题】:How best to stub/mock rest API calls in Flutter Integration tests 【发布时间】:2019-08-04 05:11:48 【问题描述】:

我有一个 Flutter 应用程序,它会在用户登录后显示数据。 我有单元和小部件测试,现在想编写我的第一个Integration/端到端测试来测试用户登录并查看数据的整个“快乐路径”工作流程。

当应用程序调用登录 API (GET login_api_path) 时,我想返回一些预定义的 JSON 以显示在屏幕上的内容,而不是向服务器发出真正的请求。

这是一个明智的方法吗?如果是,最好的方法是什么?我发现的大多数资源都是专门用于单元测试的。

【问题讨论】:

【参考方案1】:

这是我采用的方法:

创建一个使用 Dart http MockClient 的模拟客户端:

import 'package:http/testing.dart';
import 'package:http/http.dart';

MockClient integrationTestMockClient = MockClient((request) async 
  switch (request.url.toString()) 
    case 'https://staging.company.com/api/customer/123':
      return Response('"customer": "123", "name": "Jane Jimmy"', 200);
    case 'https://staging.company.com/api/customer/155':
      return Response('"customer": "155", "name": "Gregor"', 200);
  

现在,当您在集成测试中启动应用程序时,您需要将模拟客户端传递到您的应用程序中,例如test_driver/app.dart

import 'mock_client.dart';

void main() async 
  enableFlutterDriverExtension();
  final app = await initializeApp(
    integrationMockClient,
  );
  runApp(app);

您可能需要重构非测试代码,以便在应用启动时注入客户端。测试时可以是真实客户端,也可以是模拟客户端。

import 'package:http/http.dart';

void main() => initializeApp(Client());

【讨论】:

以上是关于如何在 Flutter 集成测试中最好地存根/模拟 rest API 调用的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 Typhoon 为集成测试注入虚假、存根或模拟依赖项

如何模拟/存根 Flutter 平台通道/插件?

如何在集成测试中模拟 BLoC

创建存根 bigquery 表

扩展特征的单元测试类 - 我如何在特征中模拟和存根方法?

如何在颤振集成测试中模拟 http 请求?