Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #142 from kuhnroyal/fix/should-update-model-rebuild
Account for existing _forceLastValidStreamState when rebuilding
- Loading branch information
Showing
4 changed files
with
169 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
name: Build | ||
|
||
on: | ||
push: | ||
branches: | ||
- master | ||
- develop | ||
pull_request: | ||
|
||
jobs: | ||
test: | ||
name: Run tests | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v3 | ||
- uses: subosito/flutter-action@v2 | ||
with: | ||
channel: stable | ||
- run: flutter pub get | ||
- run: flutter test |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,4 @@ | ||
@Skip('Requires precise timing') | ||
import 'dart:async'; | ||
|
||
import "package:async_redux/async_redux.dart"; | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,141 @@ | ||
import "package:async_redux/async_redux.dart"; | ||
import "package:flutter/material.dart"; | ||
import "package:flutter_test/flutter_test.dart"; | ||
|
||
void main() { | ||
group(StoreConnector, () { | ||
// TODO shouldUpdateModel does not currently work with converter | ||
testWidgets( | ||
"shouldUpdateModel.converter", | ||
(tester) async { | ||
final storeTester = StoreTester<int>(initialState: 0); | ||
|
||
await tester.pumpWidget(StoreProvider<int>( | ||
store: storeTester.store, | ||
child: MaterialApp( | ||
home: StoreConnector<int, int>( | ||
converter: (store) => store.state, | ||
shouldUpdateModel: (state) => state % 2 == 0, | ||
builder: (context, value) { | ||
return Text(value.toString()); | ||
}, | ||
), | ||
), | ||
)); | ||
|
||
expect(find.text("0"), findsOneWidget); | ||
|
||
await storeTester.dispatchState(1); | ||
await tester.pumpAndSettle(); | ||
expect(find.text("0"), findsOneWidget); | ||
|
||
await storeTester.dispatchState(2); | ||
await tester.pumpAndSettle(); | ||
expect(find.text("2"), findsOneWidget); | ||
}, | ||
skip: true, | ||
); | ||
|
||
testWidgets( | ||
"shouldUpdateModel.vm", | ||
(tester) async { | ||
final storeTester = StoreTester<int>(initialState: 0); | ||
|
||
await tester.pumpWidget(StoreProvider<int>( | ||
store: storeTester.store, | ||
child: _TestWidget(), | ||
)); | ||
|
||
expect(find.text("0"), findsOneWidget); | ||
|
||
await storeTester.dispatchState(1); | ||
await tester.pumpAndSettle(); | ||
expect(find.text("0"), findsOneWidget); | ||
|
||
await storeTester.dispatchState(2); | ||
await tester.pumpAndSettle(); | ||
expect(find.text("2"), findsOneWidget); | ||
}, | ||
); | ||
|
||
testWidgets( | ||
"shouldUpdateModel.vm with external rebuild", | ||
(tester) async { | ||
final storeTester = StoreTester<int>(initialState: 0); | ||
|
||
await tester.pumpWidget(StoreProvider<int>( | ||
store: storeTester.store, | ||
child: _TestWidget(), | ||
)); | ||
|
||
expect(find.text("0"), findsOneWidget); | ||
|
||
storeTester.dispatchState(1); | ||
await tester.pump(); | ||
await tester.pump(); | ||
expect(find.text("0"), findsOneWidget); | ||
|
||
tester.firstState<_TestWidgetState>(find.byType(_TestWidget)).forceRebuild(); | ||
await tester.pump(); | ||
await tester.pump(); | ||
expect(find.text("0"), findsOneWidget); | ||
}, | ||
); | ||
}); | ||
} | ||
|
||
class _TestWidget extends StatefulWidget { | ||
_TestWidget({ | ||
Key? key, | ||
}) : super(key: key); | ||
|
||
@override | ||
State<_TestWidget> createState() => _TestWidgetState(); | ||
} | ||
|
||
class _TestWidgetState extends State<_TestWidget> { | ||
void forceRebuild() => setState(() {}); | ||
|
||
@override | ||
Widget build(BuildContext context) { | ||
return MaterialApp( | ||
home: _TestContent(key: const ValueKey("tester")), | ||
); | ||
} | ||
} | ||
|
||
class _TestContent extends StatelessWidget { | ||
_TestContent({ | ||
Key? key, | ||
}) : super(key: key); | ||
|
||
@override | ||
Widget build(BuildContext context) { | ||
return StoreConnector<int, ViewModel>( | ||
vm: () => Factory(this), | ||
shouldUpdateModel: (state) => state % 2 == 0, | ||
builder: (context, vm) { | ||
return Text(vm.counter.toString()); | ||
}, | ||
); | ||
} | ||
} | ||
|
||
class Factory extends VmFactory<int, _TestContent> { | ||
Factory(widget) : super(widget); | ||
|
||
@override | ||
ViewModel fromStore() { | ||
return ViewModel( | ||
counter: state, | ||
); | ||
} | ||
} | ||
|
||
class ViewModel extends Vm { | ||
final int counter; | ||
|
||
ViewModel({ | ||
required this.counter, | ||
}) : super(equals: [counter]); | ||
} |