10

我想嘲笑我的集团以测试我的观点。

例如,这是我的 Bloc:

class SearchBloc extends Bloc<SearchEvent, SearchState> {
  @override
  // TODO: implement initialState
  SearchState get initialState => SearchStateUninitialized();

  @override
  Stream<SearchState> mapEventToState(SearchState currentState, SearchEvent event) async* {
    if (event is UserWrites) {
      yield (SearchStateInitialized.success(objects);
    }
  }
}

这是观点:

class _SearchViewState extends State<SearchView> {
  final TextEditingController _filterController = new TextEditingController();

  @override
  void initState() {
    _filterController.addListener(() {
    widget._searchBloc.dispatch(FetchByName(_filterController.text));
     }
  }


 TextField buildAppBarTitle(BuildContext context) {
    return new TextField(
      key: Key("AppBarTextField"),
        controller: _filterController,
    );
  }

@override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(title: buildAppBarTitle(context),),
      body: buildBlocBuilder(),
    );
  }

BlocBuilder<SearchEvent, SearchState> buildBlocBuilder() {
    return BlocBuilder(
        bloc: widget._searchBloc,
        builder: (context, state) {
          if (state is SearchStateUninitialized) {
            return Container(
              key: Key("EmptyContainer"),
            );
          } 
            return buildInitializedView(state, context);
          }
        });

buildInitializedView(SearchStateInitialized state, BuildContext context) {
    if (state.objects.isEmpty) {
      return Center(child: Text("Nothing found"),);
    } else {
      return buildListOfCards();
    }
  }
    }

现在,这是我的测试:

testWidgets('Should find a card when the user searches for something', (WidgetTester tester) async {

  _searchView = new SearchView(_searchBloc);

    when(mockService.find( name: "a")).thenAnswer((_) =>
    [objects]);

    await tester.pumpWidget(generateApp(_searchView));
    await tester.enterText(find.byKey(Key("searchBar")), "a");
    await tester.pump();

    expect(find.byType(Card), findsOneWidget);
  });
}

如您所见,我只是想测试一下,当用户在搜索中写一些东西并且他正在寻找的对象存在时,应该显示一张卡片。

4

4 回答 4

3

如果我理解正确,您正在模拟 searchBloc 使用的某些服务。我个人尝试以一种方式设计应用程序,即应用程序仅依赖于一个 bloc,而 bloc 可能依赖于其他一些服务。然后当我想做一个小部件测试时,我只需要模拟这个块。您可以为此使用bloc_test包。

bloc_test 页面上有这个示例用于存根 counterBloc:

// Create a mock instance
final counterBloc = MockCounterBloc();

// Stub the bloc `Stream`
whenListen(counterBloc, Stream.fromIterable([0, 1, 2, 3]));

但是,我经常不需要存根 bloc 流并且发出状态就足够了,就像这样

when(counterBloc.state).thenAnswer((_) => CounterState(456));

希望这可以帮助。

于 2020-06-04T12:45:40.697 回答
0

看看David Anaya的一篇文章,它用“Bloc”和 mockito 处理单元测试。

他的例子的最后一个版本在这里

于 2019-04-02T14:22:46.193 回答
0

有时小部件需要一点时间来构建。尝试:

await tester.pumpWidget(generateApp(_searchView));
await tester.enterText(find.byKey(Key("searchBar")), "a");
await tester.pump(Duration(seconds: 1));

expect(find.byType(Card), findsOneWidget);
于 2020-02-25T09:05:56.803 回答
0

要模拟 bloc,您可以使用bloc_test 包

此外,您可以观看本教程,其中涵盖了 bloc 测试,包括 mock bloc 非常好。

于 2020-06-20T10:25:34.923 回答