Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in
Toggle navigation
F
Front-End
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
abdullh.alsoleman
Front-End
Commits
185bc093
Unverified
Commit
185bc093
authored
Feb 03, 2022
by
chunhtai
Committed by
GitHub
Feb 03, 2022
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix RouterObserver didPop is not called when reverseTransitionDuratio… (#97171)
parent
2787eb02
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
77 additions
and
14 deletions
+77
-14
navigator.dart
packages/flutter/lib/src/widgets/navigator.dart
+9
-5
navigator_test.dart
packages/flutter/test/widgets/navigator_test.dart
+68
-9
No files found.
packages/flutter/lib/src/widgets/navigator.dart
View file @
185bc093
...
@@ -5023,11 +5023,15 @@ class NavigatorState extends State<Navigator> with TickerProviderStateMixin, Res
...
@@ -5023,11 +5023,15 @@ class NavigatorState extends State<Navigator> with TickerProviderStateMixin, Res
bool
?
wasDebugLocked
;
bool
?
wasDebugLocked
;
assert
(()
{
wasDebugLocked
=
_debugLocked
;
_debugLocked
=
true
;
return
true
;
}());
assert
(()
{
wasDebugLocked
=
_debugLocked
;
_debugLocked
=
true
;
return
true
;
}());
assert
(
_history
.
where
(
_RouteEntry
.
isRoutePredicate
(
route
)).
length
==
1
);
assert
(
_history
.
where
(
_RouteEntry
.
isRoutePredicate
(
route
)).
length
==
1
);
final
_RouteEntry
entry
=
_history
.
firstWhere
(
_RouteEntry
.
isRoutePredicate
(
route
));
final
int
index
=
_history
.
indexWhere
(
_RouteEntry
.
isRoutePredicate
(
route
));
// For page-based route, the didPop can be called on any life cycle above
final
_RouteEntry
entry
=
_history
[
index
];
// pop.
// For page-based route with zero transition, the finalizeRoute can be
assert
(
entry
.
currentState
==
_RouteLifecycle
.
popping
||
// called on any life cycle above pop.
(
entry
.
hasPage
&&
entry
.
currentState
.
index
<
_RouteLifecycle
.
pop
.
index
));
if
(
entry
.
hasPage
&&
entry
.
currentState
.
index
<
_RouteLifecycle
.
pop
.
index
)
{
_observedRouteDeletions
.
add
(
_NavigatorPopObservation
(
route
,
_getRouteBefore
(
index
-
1
,
_RouteEntry
.
willBePresentPredicate
)?.
route
));
}
else
{
assert
(
entry
.
currentState
==
_RouteLifecycle
.
popping
);
}
entry
.
finalize
();
entry
.
finalize
();
// finalizeRoute can be called during _flushHistoryUpdates if a pop
// finalizeRoute can be called during _flushHistoryUpdates if a pop
// finishes synchronously.
// finishes synchronously.
...
...
packages/flutter/test/widgets/navigator_test.dart
View file @
185bc093
...
@@ -183,6 +183,47 @@ void main() {
...
@@ -183,6 +183,47 @@ void main() {
expect
(
'
$exception
'
,
startsWith
(
'Navigator operation requested with a context'
));
expect
(
'
$exception
'
,
startsWith
(
'Navigator operation requested with a context'
));
});
});
testWidgets
(
'Zero transition page-based route correctly notifies observers when it is popped'
,
(
WidgetTester
tester
)
async
{
final
List
<
Page
<
void
>>
pages
=
<
Page
<
void
>>[
const
ZeroTransitionPage
(
name:
'Page 1'
),
const
ZeroTransitionPage
(
name:
'Page 2'
),
];
final
List
<
NavigatorObservation
>
observations
=
<
NavigatorObservation
>[];
final
TestObserver
observer
=
TestObserver
()
..
onPopped
=
(
Route
<
dynamic
>?
route
,
Route
<
dynamic
>?
previousRoute
)
{
observations
.
add
(
NavigatorObservation
(
current:
route
?.
settings
.
name
,
previous:
previousRoute
?.
settings
.
name
,
operation:
'pop'
,
),
);
};
final
GlobalKey
<
NavigatorState
>
navigator
=
GlobalKey
<
NavigatorState
>();
await
tester
.
pumpWidget
(
Directionality
(
textDirection:
TextDirection
.
ltr
,
child:
Navigator
(
key:
navigator
,
pages:
pages
,
observers:
<
NavigatorObserver
>[
observer
],
onPopPage:
(
Route
<
dynamic
>
route
,
dynamic
result
)
{
pages
.
removeLast
();
return
route
.
didPop
(
result
);
},
),
),
);
navigator
.
currentState
!.
pop
();
await
tester
.
pump
();
expect
(
observations
.
length
,
1
);
expect
(
observations
[
0
].
current
,
'Page 2'
);
expect
(
observations
[
0
].
previous
,
'Page 1'
);
});
testWidgets
(
'Navigator.of rootNavigator finds root Navigator'
,
(
WidgetTester
tester
)
async
{
testWidgets
(
'Navigator.of rootNavigator finds root Navigator'
,
(
WidgetTester
tester
)
async
{
await
tester
.
pumpWidget
(
MaterialApp
(
await
tester
.
pumpWidget
(
MaterialApp
(
home:
Material
(
home:
Material
(
...
@@ -3941,6 +3982,22 @@ class AlwaysRemoveTransitionDelegate extends TransitionDelegate<void> {
...
@@ -3941,6 +3982,22 @@ class AlwaysRemoveTransitionDelegate extends TransitionDelegate<void> {
}
}
}
}
class
ZeroTransitionPage
extends
Page
<
void
>
{
const
ZeroTransitionPage
({
LocalKey
?
key
,
Object
?
arguments
,
required
String
name
,
})
:
super
(
key:
key
,
name:
name
,
arguments:
arguments
);
@override
Route
<
void
>
createRoute
(
BuildContext
context
)
{
return
NoAnimationPageRoute
(
settings:
this
,
pageBuilder:
(
BuildContext
context
)
=>
Text
(
name
!),
);
}
}
class
TestPage
extends
Page
<
void
>
{
class
TestPage
extends
Page
<
void
>
{
const
TestPage
({
const
TestPage
({
LocalKey
?
key
,
LocalKey
?
key
,
...
@@ -3958,15 +4015,17 @@ class TestPage extends Page<void> {
...
@@ -3958,15 +4015,17 @@ class TestPage extends Page<void> {
}
}
class
NoAnimationPageRoute
extends
PageRouteBuilder
<
void
>
{
class
NoAnimationPageRoute
extends
PageRouteBuilder
<
void
>
{
NoAnimationPageRoute
({
required
WidgetBuilder
pageBuilder
})
NoAnimationPageRoute
({
:
super
(
pageBuilder:
(
BuildContext
context
,
__
,
___
)
{
RouteSettings
?
settings
,
return
pageBuilder
(
context
);
required
WidgetBuilder
pageBuilder
});
})
:
super
(
settings:
settings
,
@override
transitionDuration:
Duration
.
zero
,
AnimationController
createAnimationController
()
{
reverseTransitionDuration:
Duration
.
zero
,
return
super
.
createAnimationController
()..
value
=
1.0
;
pageBuilder:
(
BuildContext
context
,
__
,
___
)
{
}
return
pageBuilder
(
context
);
}
);
}
}
class
StatefulTestWidget
extends
StatefulWidget
{
class
StatefulTestWidget
extends
StatefulWidget
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment