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
8b162b59
Commit
8b162b59
authored
Sep 23, 2015
by
Adam Barth
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add tests for MultiChildRenderWidget
parent
436fb0ee
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
400 additions
and
72 deletions
+400
-72
basic.dart
packages/flutter/lib/src/fn3/basic.dart
+3
-3
framework.dart
packages/flutter/lib/src/fn3/framework.dart
+44
-23
multichild_test.dart
packages/unit/test/fn3/multichild_test.dart
+290
-0
stateful_component_test.dart
packages/unit/test/fn3/stateful_component_test.dart
+5
-46
test_widgets.dart
packages/unit/test/fn3/test_widgets.dart
+58
-0
No files found.
packages/flutter/lib/src/fn3/basic.dart
View file @
8b162b59
...
@@ -775,7 +775,7 @@ class ImageListenerState extends ComponentState<ImageListener> {
...
@@ -775,7 +775,7 @@ class ImageListenerState extends ComponentState<ImageListener> {
}
}
}
}
Widget
build
()
{
Widget
build
(
BuildContext
context
)
{
return
new
Image
(
return
new
Image
(
image:
_resolvedImage
,
image:
_resolvedImage
,
width:
config
.
width
,
width:
config
.
width
,
...
@@ -805,7 +805,7 @@ class NetworkImage extends StatelessComponent {
...
@@ -805,7 +805,7 @@ class NetworkImage extends StatelessComponent {
final
ImageFit
fit
;
final
ImageFit
fit
;
final
ImageRepeat
repeat
;
final
ImageRepeat
repeat
;
Widget
build
()
{
Widget
build
(
BuildContext
context
)
{
return
new
ImageListener
(
return
new
ImageListener
(
image:
imageCache
.
load
(
src
),
image:
imageCache
.
load
(
src
),
width:
width
,
width:
width
,
...
@@ -837,7 +837,7 @@ class AssetImage extends StatelessComponent {
...
@@ -837,7 +837,7 @@ class AssetImage extends StatelessComponent {
final
ImageFit
fit
;
final
ImageFit
fit
;
final
ImageRepeat
repeat
;
final
ImageRepeat
repeat
;
Widget
build
()
{
Widget
build
(
BuildContext
context
)
{
return
new
ImageListener
(
return
new
ImageListener
(
image:
bundle
.
loadImage
(
name
),
image:
bundle
.
loadImage
(
name
),
width:
width
,
width:
width
,
...
...
packages/flutter/lib/src/fn3/framework.dart
View file @
8b162b59
...
@@ -271,11 +271,11 @@ abstract class Element<T extends Widget> implements BuildContext {
...
@@ -271,11 +271,11 @@ abstract class Element<T extends Widget> implements BuildContext {
/// Calls the argument for each descendant, depth-first pre-order.
/// Calls the argument for each descendant, depth-first pre-order.
void
visitDescendants
(
ElementVisitor
visitor
)
{
void
visitDescendants
(
ElementVisitor
visitor
)
{
void
walk
(
Element
element
)
{
void
visit
(
Element
element
)
{
visitor
(
element
);
visitor
(
element
);
element
.
visitChildren
(
walk
);
element
.
visitChildren
(
visit
);
}
}
visitChildren
(
walk
);
visitChildren
(
visit
);
}
}
Element
_updateChild
(
Element
child
,
Widget
newWidget
,
dynamic
slot
)
{
Element
_updateChild
(
Element
child
,
Widget
newWidget
,
dynamic
slot
)
{
...
@@ -301,17 +301,20 @@ abstract class Element<T extends Widget> implements BuildContext {
...
@@ -301,17 +301,20 @@ abstract class Element<T extends Widget> implements BuildContext {
// The _updateChild() method returns the new child, if it had to create one,
// The _updateChild() method returns the new child, if it had to create one,
// or the child that was passed in, if it just had to update the child, or
// or the child that was passed in, if it just had to update the child, or
// null, if it removed the child and did not replace it.
// null, if it removed the child and did not replace it.
assert
(
slot
!=
null
);
if
(
newWidget
==
null
)
{
if
(
newWidget
==
null
)
{
if
(
child
!=
null
)
if
(
child
!=
null
)
_detachChild
(
child
);
_detachChild
(
child
);
return
null
;
return
null
;
}
}
if
(
child
!=
null
)
{
if
(
child
!=
null
)
{
assert
(
child
.
_slot
==
slot
);
if
(
child
.
_widget
==
newWidget
)
{
if
(
child
.
_widget
==
newWidget
)
if
(
child
.
_slot
!=
slot
)
updateSlotForChild
(
child
,
slot
);
return
child
;
return
child
;
}
if
(
_canUpdate
(
child
.
_widget
,
newWidget
))
{
if
(
_canUpdate
(
child
.
_widget
,
newWidget
))
{
if
(
child
.
_slot
!=
slot
)
updateSlotForChild
(
child
,
slot
);
child
.
update
(
newWidget
);
child
.
update
(
newWidget
);
assert
(
child
.
_widget
==
newWidget
);
assert
(
child
.
_widget
==
newWidget
);
return
child
;
return
child
;
...
@@ -334,7 +337,6 @@ abstract class Element<T extends Widget> implements BuildContext {
...
@@ -334,7 +337,6 @@ abstract class Element<T extends Widget> implements BuildContext {
assert
(
_parent
==
null
);
assert
(
_parent
==
null
);
assert
(
parent
==
null
||
parent
.
_debugLifecycleState
==
_ElementLifecycle
.
mounted
);
assert
(
parent
==
null
||
parent
.
_debugLifecycleState
==
_ElementLifecycle
.
mounted
);
assert
(
_slot
==
null
);
assert
(
_slot
==
null
);
assert
(
slot
!=
null
);
assert
(
_depth
==
null
);
assert
(
_depth
==
null
);
_parent
=
parent
;
_parent
=
parent
;
_slot
=
slot
;
_slot
=
slot
;
...
@@ -347,7 +349,6 @@ abstract class Element<T extends Widget> implements BuildContext {
...
@@ -347,7 +349,6 @@ abstract class Element<T extends Widget> implements BuildContext {
assert
(
_debugLifecycleState
==
_ElementLifecycle
.
mounted
);
assert
(
_debugLifecycleState
==
_ElementLifecycle
.
mounted
);
assert
(
_widget
!=
null
);
assert
(
_widget
!=
null
);
assert
(
newWidget
!=
null
);
assert
(
newWidget
!=
null
);
assert
(
_slot
!=
null
);
assert
(
_depth
!=
null
);
assert
(
_depth
!=
null
);
assert
(
_canUpdate
(
_widget
,
newWidget
));
assert
(
_canUpdate
(
_widget
,
newWidget
));
_widget
=
newWidget
;
_widget
=
newWidget
;
...
@@ -360,14 +361,12 @@ abstract class Element<T extends Widget> implements BuildContext {
...
@@ -360,14 +361,12 @@ abstract class Element<T extends Widget> implements BuildContext {
assert
(
_debugLifecycleState
==
_ElementLifecycle
.
mounted
);
assert
(
_debugLifecycleState
==
_ElementLifecycle
.
mounted
);
assert
(
child
!=
null
);
assert
(
child
!=
null
);
assert
(
child
.
_parent
==
this
);
assert
(
child
.
_parent
==
this
);
void
visit
(
Element
element
)
{
void
move
(
Element
element
)
{
element
.
_updateSlot
(
slot
);
child
.
_updateSlot
(
slot
);
if
(
element
is
!
RenderObjectElement
)
if
(
child
is
!
RenderObjectElement
)
element
.
visitChildren
(
visit
);
child
.
visitChildren
(
move
);
}
}
visit
(
child
);
move
(
child
);
}
}
void
_updateSlot
(
dynamic
slot
)
{
void
_updateSlot
(
dynamic
slot
)
{
...
@@ -375,9 +374,7 @@ abstract class Element<T extends Widget> implements BuildContext {
...
@@ -375,9 +374,7 @@ abstract class Element<T extends Widget> implements BuildContext {
assert
(
_widget
!=
null
);
assert
(
_widget
!=
null
);
assert
(
_parent
!=
null
);
assert
(
_parent
!=
null
);
assert
(
_parent
.
_debugLifecycleState
==
_ElementLifecycle
.
mounted
);
assert
(
_parent
.
_debugLifecycleState
==
_ElementLifecycle
.
mounted
);
assert
(
_slot
!=
null
);
assert
(
_depth
!=
null
);
assert
(
slot
!=
null
);
assert
(
_depth
==
null
);
_slot
=
slot
;
_slot
=
slot
;
}
}
...
@@ -665,6 +662,13 @@ abstract class RenderObjectElement<T extends RenderObjectWidget> extends Element
...
@@ -665,6 +662,13 @@ abstract class RenderObjectElement<T extends RenderObjectWidget> extends Element
parentData
.
applyParentData
(
renderObject
);
parentData
.
applyParentData
(
renderObject
);
}
}
void
_updateSlot
(
dynamic
slot
)
{
assert
(
_slot
!=
slot
);
super
.
_updateSlot
(
slot
);
assert
(
_slot
==
slot
);
_ancestorRenderObjectElement
.
moveChildRenderObject
(
renderObject
,
_slot
);
}
void
detachRenderObject
()
{
void
detachRenderObject
()
{
if
(
_ancestorRenderObjectElement
!=
null
)
{
if
(
_ancestorRenderObjectElement
!=
null
)
{
_ancestorRenderObjectElement
.
removeChildRenderObject
(
renderObject
);
_ancestorRenderObjectElement
.
removeChildRenderObject
(
renderObject
);
...
@@ -673,7 +677,7 @@ abstract class RenderObjectElement<T extends RenderObjectWidget> extends Element
...
@@ -673,7 +677,7 @@ abstract class RenderObjectElement<T extends RenderObjectWidget> extends Element
}
}
void
insertChildRenderObject
(
RenderObject
child
,
dynamic
slot
);
void
insertChildRenderObject
(
RenderObject
child
,
dynamic
slot
);
void
moveChildRenderObject
(
RenderObject
child
,
dynamic
slot
);
void
removeChildRenderObject
(
RenderObject
child
);
void
removeChildRenderObject
(
RenderObject
child
);
}
}
...
@@ -685,6 +689,10 @@ class LeafRenderObjectElement<T extends RenderObjectWidget> extends RenderObject
...
@@ -685,6 +689,10 @@ class LeafRenderObjectElement<T extends RenderObjectWidget> extends RenderObject
assert
(
false
);
assert
(
false
);
}
}
void
moveChildRenderObject
(
RenderObject
child
,
dynamic
slot
)
{
assert
(
false
);
}
void
removeChildRenderObject
(
RenderObject
child
)
{
void
removeChildRenderObject
(
RenderObject
child
)
{
assert
(
false
);
assert
(
false
);
}
}
...
@@ -720,6 +728,10 @@ class OneChildRenderObjectElement<T extends OneChildRenderObjectWidget> extends
...
@@ -720,6 +728,10 @@ class OneChildRenderObjectElement<T extends OneChildRenderObjectWidget> extends
assert
(
renderObject
==
this
.
renderObject
);
// TODO(ianh): Remove this once the analyzer is cleverer
assert
(
renderObject
==
this
.
renderObject
);
// TODO(ianh): Remove this once the analyzer is cleverer
}
}
void
moveChildRenderObject
(
RenderObject
child
,
dynamic
slot
)
{
assert
(
false
);
}
void
removeChildRenderObject
(
RenderObject
child
)
{
void
removeChildRenderObject
(
RenderObject
child
)
{
final
renderObject
=
this
.
renderObject
;
// TODO(ianh): Remove this once the analyzer is cleverer
final
renderObject
=
this
.
renderObject
;
// TODO(ianh): Remove this once the analyzer is cleverer
assert
(
renderObject
is
RenderObjectWithChildMixin
);
assert
(
renderObject
is
RenderObjectWithChildMixin
);
...
@@ -739,13 +751,20 @@ class MultiChildRenderObjectElement<T extends MultiChildRenderObjectWidget> exte
...
@@ -739,13 +751,20 @@ class MultiChildRenderObjectElement<T extends MultiChildRenderObjectWidget> exte
void
insertChildRenderObject
(
RenderObject
child
,
Element
slot
)
{
void
insertChildRenderObject
(
RenderObject
child
,
Element
slot
)
{
final
renderObject
=
this
.
renderObject
;
// TODO(ianh): Remove this once the analyzer is cleverer
final
renderObject
=
this
.
renderObject
;
// TODO(ianh): Remove this once the analyzer is cleverer
RenderObject
nextSibling
=
slot
.
_descendantRenderObject
;
RenderObject
nextSibling
=
slot
?.
_descendantRenderObject
;
assert
(
nextSibling
==
null
||
nextSibling
is
RenderObject
);
assert
(
renderObject
is
ContainerRenderObjectMixin
);
assert
(
renderObject
is
ContainerRenderObjectMixin
);
renderObject
.
add
(
child
,
before:
nextSibling
);
renderObject
.
add
(
child
,
before:
nextSibling
);
assert
(
renderObject
==
this
.
renderObject
);
// TODO(ianh): Remove this once the analyzer is cleverer
assert
(
renderObject
==
this
.
renderObject
);
// TODO(ianh): Remove this once the analyzer is cleverer
}
}
void
moveChildRenderObject
(
RenderObject
child
,
dynamic
slot
)
{
final
renderObject
=
this
.
renderObject
;
// TODO(ianh): Remove this once the analyzer is cleverer
RenderObject
nextSibling
=
slot
?.
_descendantRenderObject
;
assert
(
renderObject
is
ContainerRenderObjectMixin
);
renderObject
.
move
(
child
,
before:
nextSibling
);
assert
(
renderObject
==
this
.
renderObject
);
// TODO(ianh): Remove this once the analyzer is cleverer
}
void
removeChildRenderObject
(
RenderObject
child
)
{
void
removeChildRenderObject
(
RenderObject
child
)
{
final
renderObject
=
this
.
renderObject
;
// TODO(ianh): Remove this once the analyzer is cleverer
final
renderObject
=
this
.
renderObject
;
// TODO(ianh): Remove this once the analyzer is cleverer
assert
(
renderObject
is
ContainerRenderObjectMixin
);
assert
(
renderObject
is
ContainerRenderObjectMixin
);
...
@@ -777,7 +796,7 @@ class MultiChildRenderObjectElement<T extends MultiChildRenderObjectWidget> exte
...
@@ -777,7 +796,7 @@ class MultiChildRenderObjectElement<T extends MultiChildRenderObjectWidget> exte
super
.
mount
(
parent
,
slot
);
super
.
mount
(
parent
,
slot
);
_children
=
new
List
<
Element
>(
_widget
.
children
.
length
);
_children
=
new
List
<
Element
>(
_widget
.
children
.
length
);
Element
previousChild
;
Element
previousChild
;
for
(
int
i
=
0
;
i
<
_children
.
length
;
++
i
)
{
for
(
int
i
=
_children
.
length
-
1
;
i
>=
0
;
--
i
)
{
Element
newChild
=
_widget
.
children
[
i
].
createElement
();
Element
newChild
=
_widget
.
children
[
i
].
createElement
();
newChild
.
mount
(
this
,
previousChild
);
newChild
.
mount
(
this
,
previousChild
);
assert
(
newChild
.
_debugLifecycleState
==
_ElementLifecycle
.
mounted
);
assert
(
newChild
.
_debugLifecycleState
==
_ElementLifecycle
.
mounted
);
...
@@ -874,6 +893,8 @@ class MultiChildRenderObjectElement<T extends MultiChildRenderObjectWidget> exte
...
@@ -874,6 +893,8 @@ class MultiChildRenderObjectElement<T extends MultiChildRenderObjectWidget> exte
assert
(
oldChild
.
_debugLifecycleState
==
_ElementLifecycle
.
mounted
);
assert
(
oldChild
.
_debugLifecycleState
==
_ElementLifecycle
.
mounted
);
if
(
oldChild
.
_widget
.
key
!=
null
)
if
(
oldChild
.
_widget
.
key
!=
null
)
oldKeyedChildren
[
oldChild
.
_widget
.
key
]
=
oldChild
;
oldKeyedChildren
[
oldChild
.
_widget
.
key
]
=
oldChild
;
else
_detachChild
(
oldChild
);
oldChildrenBottom
-=
1
;
oldChildrenBottom
-=
1
;
}
}
}
}
...
@@ -926,7 +947,7 @@ class MultiChildRenderObjectElement<T extends MultiChildRenderObjectWidget> exte
...
@@ -926,7 +947,7 @@ class MultiChildRenderObjectElement<T extends MultiChildRenderObjectWidget> exte
// clean up any of the remaining middle nodes from the old list
// clean up any of the remaining middle nodes from the old list
if
(
haveOldNodes
&&
!
oldKeyedChildren
.
isEmpty
)
{
if
(
haveOldNodes
&&
!
oldKeyedChildren
.
isEmpty
)
{
for
(
Element
oldChild
in
oldKeyedChildren
.
values
)
for
(
Element
oldChild
in
oldKeyedChildren
.
values
)
oldChild
.
unmount
(
);
_detachChild
(
oldChild
);
}
}
assert
(
renderObject
==
this
.
renderObject
);
// TODO(ianh): Remove this once the analyzer is cleverer
assert
(
renderObject
==
this
.
renderObject
);
// TODO(ianh): Remove this once the analyzer is cleverer
...
...
packages/unit/test/fn3/multichild_test.dart
0 → 100644
View file @
8b162b59
import
'package:sky/rendering.dart'
;
import
'package:sky/src/fn3.dart'
;
import
'package:test/test.dart'
;
import
'test_widgets.dart'
;
import
'widget_tester.dart'
;
void
checkTree
(
WidgetTester
tester
,
List
<
BoxDecoration
>
expectedDecorations
)
{
MultiChildRenderObjectElement
element
=
tester
.
findElement
((
element
)
=>
element
is
MultiChildRenderObjectElement
);
expect
(
element
,
isNotNull
);
expect
(
element
.
renderObject
is
RenderStack
,
isTrue
);
RenderStack
renderObject
=
element
.
renderObject
;
try
{
RenderObject
child
=
renderObject
.
firstChild
;
for
(
BoxDecoration
decoration
in
expectedDecorations
)
{
expect
(
child
is
RenderDecoratedBox
,
isTrue
);
RenderDecoratedBox
decoratedBox
=
child
;
expect
(
decoratedBox
.
decoration
,
equals
(
decoration
));
child
=
decoratedBox
.
parentData
.
nextSibling
;
}
expect
(
child
,
isNull
);
}
catch
(
e
)
{
print
(
renderObject
.
toStringDeep
());
rethrow
;
}
}
void
main
(
)
{
test
(
'MultiChildRenderObjectElement control test'
,
()
{
WidgetTester
tester
=
new
WidgetTester
();
tester
.
pumpFrame
(
new
Stack
([
new
DecoratedBox
(
decoration:
kBoxDecorationA
),
new
DecoratedBox
(
decoration:
kBoxDecorationB
),
new
DecoratedBox
(
decoration:
kBoxDecorationC
),
])
);
checkTree
(
tester
,
[
kBoxDecorationA
,
kBoxDecorationB
,
kBoxDecorationC
]);
tester
.
pumpFrame
(
new
Stack
([
new
DecoratedBox
(
decoration:
kBoxDecorationA
),
new
DecoratedBox
(
decoration:
kBoxDecorationC
),
])
);
checkTree
(
tester
,
[
kBoxDecorationA
,
kBoxDecorationC
]);
tester
.
pumpFrame
(
new
Stack
([
new
DecoratedBox
(
decoration:
kBoxDecorationA
),
new
DecoratedBox
(
key:
new
Key
(
'b'
),
decoration:
kBoxDecorationB
),
new
DecoratedBox
(
decoration:
kBoxDecorationC
),
])
);
checkTree
(
tester
,
[
kBoxDecorationA
,
kBoxDecorationB
,
kBoxDecorationC
]);
tester
.
pumpFrame
(
new
Stack
([
new
DecoratedBox
(
key:
new
Key
(
'b'
),
decoration:
kBoxDecorationB
),
new
DecoratedBox
(
decoration:
kBoxDecorationC
),
new
DecoratedBox
(
key:
new
Key
(
'a'
),
decoration:
kBoxDecorationA
),
])
);
checkTree
(
tester
,
[
kBoxDecorationB
,
kBoxDecorationC
,
kBoxDecorationA
]);
tester
.
pumpFrame
(
new
Stack
([
new
DecoratedBox
(
key:
new
Key
(
'a'
),
decoration:
kBoxDecorationA
),
new
DecoratedBox
(
decoration:
kBoxDecorationC
),
new
DecoratedBox
(
key:
new
Key
(
'b'
),
decoration:
kBoxDecorationB
),
])
);
checkTree
(
tester
,
[
kBoxDecorationA
,
kBoxDecorationC
,
kBoxDecorationB
]);
tester
.
pumpFrame
(
new
Stack
([
new
DecoratedBox
(
decoration:
kBoxDecorationC
),
])
);
checkTree
(
tester
,
[
kBoxDecorationC
]);
tester
.
pumpFrame
(
new
Stack
([])
);
checkTree
(
tester
,
[]);
});
test
(
'MultiChildRenderObjectElement with stateless components'
,
()
{
WidgetTester
tester
=
new
WidgetTester
();
tester
.
pumpFrame
(
new
Stack
([
new
DecoratedBox
(
decoration:
kBoxDecorationA
),
new
DecoratedBox
(
decoration:
kBoxDecorationB
),
new
DecoratedBox
(
decoration:
kBoxDecorationC
),
])
);
checkTree
(
tester
,
[
kBoxDecorationA
,
kBoxDecorationB
,
kBoxDecorationC
]);
tester
.
pumpFrame
(
new
Stack
([
new
DecoratedBox
(
decoration:
kBoxDecorationA
),
new
Container
(
child:
new
DecoratedBox
(
decoration:
kBoxDecorationB
)
),
new
DecoratedBox
(
decoration:
kBoxDecorationC
),
])
);
checkTree
(
tester
,
[
kBoxDecorationA
,
kBoxDecorationB
,
kBoxDecorationC
]);
tester
.
pumpFrame
(
new
Stack
([
new
DecoratedBox
(
decoration:
kBoxDecorationA
),
new
Container
(
child:
new
Container
(
child:
new
DecoratedBox
(
decoration:
kBoxDecorationB
)
)
),
new
DecoratedBox
(
decoration:
kBoxDecorationC
),
])
);
checkTree
(
tester
,
[
kBoxDecorationA
,
kBoxDecorationB
,
kBoxDecorationC
]);
tester
.
pumpFrame
(
new
Stack
([
new
Container
(
child:
new
Container
(
child:
new
DecoratedBox
(
decoration:
kBoxDecorationB
)
)
),
new
Container
(
child:
new
DecoratedBox
(
decoration:
kBoxDecorationA
)
),
new
DecoratedBox
(
decoration:
kBoxDecorationC
),
])
);
checkTree
(
tester
,
[
kBoxDecorationB
,
kBoxDecorationA
,
kBoxDecorationC
]);
tester
.
pumpFrame
(
new
Stack
([
new
Container
(
child:
new
DecoratedBox
(
decoration:
kBoxDecorationB
)
),
new
Container
(
child:
new
DecoratedBox
(
decoration:
kBoxDecorationA
)
),
new
DecoratedBox
(
decoration:
kBoxDecorationC
),
])
);
checkTree
(
tester
,
[
kBoxDecorationB
,
kBoxDecorationA
,
kBoxDecorationC
]);
tester
.
pumpFrame
(
new
Stack
([
new
Container
(
key:
new
Key
(
'b'
),
child:
new
DecoratedBox
(
decoration:
kBoxDecorationB
)
),
new
Container
(
key:
new
Key
(
'a'
),
child:
new
DecoratedBox
(
decoration:
kBoxDecorationA
)
),
])
);
checkTree
(
tester
,
[
kBoxDecorationB
,
kBoxDecorationA
]);
tester
.
pumpFrame
(
new
Stack
([
new
Container
(
key:
new
Key
(
'a'
),
child:
new
DecoratedBox
(
decoration:
kBoxDecorationA
)
),
new
Container
(
key:
new
Key
(
'b'
),
child:
new
DecoratedBox
(
decoration:
kBoxDecorationB
)
),
])
);
checkTree
(
tester
,
[
kBoxDecorationA
,
kBoxDecorationB
]);
tester
.
pumpFrame
(
new
Stack
([
])
);
checkTree
(
tester
,
[]);
});
test
(
'MultiChildRenderObjectElement with stateful components'
,
()
{
WidgetTester
tester
=
new
WidgetTester
();
tester
.
pumpFrame
(
new
Stack
([
new
DecoratedBox
(
decoration:
kBoxDecorationA
),
new
DecoratedBox
(
decoration:
kBoxDecorationB
),
])
);
checkTree
(
tester
,
[
kBoxDecorationA
,
kBoxDecorationB
]);
tester
.
pumpFrame
(
new
Stack
([
new
FlipComponent
(
left:
new
DecoratedBox
(
decoration:
kBoxDecorationA
),
right:
new
DecoratedBox
(
decoration:
kBoxDecorationB
)
),
new
DecoratedBox
(
decoration:
kBoxDecorationC
),
])
);
checkTree
(
tester
,
[
kBoxDecorationA
,
kBoxDecorationC
]);
flipStatefulComponent
(
tester
);
tester
.
pumpFrameWithoutChange
();
checkTree
(
tester
,
[
kBoxDecorationB
,
kBoxDecorationC
]);
tester
.
pumpFrame
(
new
Stack
([
new
FlipComponent
(
left:
new
DecoratedBox
(
decoration:
kBoxDecorationA
),
right:
new
DecoratedBox
(
decoration:
kBoxDecorationB
)
),
])
);
checkTree
(
tester
,
[
kBoxDecorationB
]);
flipStatefulComponent
(
tester
);
tester
.
pumpFrameWithoutChange
();
checkTree
(
tester
,
[
kBoxDecorationA
]);
tester
.
pumpFrame
(
new
Stack
([
new
FlipComponent
(
key:
new
Key
(
'flip'
),
left:
new
DecoratedBox
(
decoration:
kBoxDecorationA
),
right:
new
DecoratedBox
(
decoration:
kBoxDecorationB
)
),
])
);
tester
.
pumpFrame
(
new
Stack
([
new
DecoratedBox
(
key:
new
Key
(
'c'
),
decoration:
kBoxDecorationC
),
new
FlipComponent
(
key:
new
Key
(
'flip'
),
left:
new
DecoratedBox
(
decoration:
kBoxDecorationA
),
right:
new
DecoratedBox
(
decoration:
kBoxDecorationB
)
),
])
);
checkTree
(
tester
,
[
kBoxDecorationC
,
kBoxDecorationA
]);
flipStatefulComponent
(
tester
);
tester
.
pumpFrameWithoutChange
();
checkTree
(
tester
,
[
kBoxDecorationC
,
kBoxDecorationB
]);
tester
.
pumpFrame
(
new
Stack
([
new
FlipComponent
(
key:
new
Key
(
'flip'
),
left:
new
DecoratedBox
(
decoration:
kBoxDecorationA
),
right:
new
DecoratedBox
(
decoration:
kBoxDecorationB
)
),
new
DecoratedBox
(
key:
new
Key
(
'c'
),
decoration:
kBoxDecorationC
),
])
);
checkTree
(
tester
,
[
kBoxDecorationB
,
kBoxDecorationC
]);
});
}
packages/unit/test/fn3/stateful_component_test.dart
View file @
8b162b59
...
@@ -3,48 +3,7 @@ import 'package:sky/src/fn3.dart';
...
@@ -3,48 +3,7 @@ import 'package:sky/src/fn3.dart';
import
'package:test/test.dart'
;
import
'package:test/test.dart'
;
import
'widget_tester.dart'
;
import
'widget_tester.dart'
;
import
'test_widgets.dart'
;
class
TestComponentConfig
extends
StatefulComponent
{
TestComponentConfig
({
this
.
left
,
this
.
right
});
final
Widget
left
;
final
Widget
right
;
TestComponentState
createState
()
=>
new
TestComponentState
(
this
);
}
class
TestComponentState
extends
ComponentState
<
TestComponentConfig
>
{
TestComponentState
(
TestComponentConfig
config
):
super
(
config
);
bool
_showLeft
=
true
;
void
flip
()
{
setState
(()
{
_showLeft
=
!
_showLeft
;
});
}
Widget
build
(
BuildContext
context
)
{
return
_showLeft
?
config
.
left
:
config
.
right
;
}
}
final
BoxDecoration
kBoxDecorationA
=
new
BoxDecoration
();
final
BoxDecoration
kBoxDecorationB
=
new
BoxDecoration
();
class
TestBuildCounter
extends
StatelessComponent
{
static
int
buildCount
=
0
;
Widget
build
(
BuildContext
context
)
{
++
buildCount
;
return
new
DecoratedBox
(
decoration:
kBoxDecorationA
);
}
}
void
flipStatefulComponent
(
WidgetTester
tester
)
{
StatefulComponentElement
stateElement
=
tester
.
findElement
((
element
)
=>
element
is
StatefulComponentElement
);
(
stateElement
.
state
as
TestComponentState
).
flip
();
}
void
main
(
)
{
void
main
(
)
{
test
(
'Stateful component smoke test'
,
()
{
test
(
'Stateful component smoke test'
,
()
{
...
@@ -60,7 +19,7 @@ void main() {
...
@@ -60,7 +19,7 @@ void main() {
}
}
tester
.
pumpFrame
(
tester
.
pumpFrame
(
new
TestComponentConfig
(
new
FlipComponent
(
left:
new
DecoratedBox
(
decoration:
kBoxDecorationA
),
left:
new
DecoratedBox
(
decoration:
kBoxDecorationA
),
right:
new
DecoratedBox
(
decoration:
kBoxDecorationB
)
right:
new
DecoratedBox
(
decoration:
kBoxDecorationB
)
)
)
...
@@ -69,7 +28,7 @@ void main() {
...
@@ -69,7 +28,7 @@ void main() {
checkTree
(
kBoxDecorationA
);
checkTree
(
kBoxDecorationA
);
tester
.
pumpFrame
(
tester
.
pumpFrame
(
new
TestComponentConfig
(
new
FlipComponent
(
left:
new
DecoratedBox
(
decoration:
kBoxDecorationB
),
left:
new
DecoratedBox
(
decoration:
kBoxDecorationB
),
right:
new
DecoratedBox
(
decoration:
kBoxDecorationA
)
right:
new
DecoratedBox
(
decoration:
kBoxDecorationA
)
)
)
...
@@ -84,7 +43,7 @@ void main() {
...
@@ -84,7 +43,7 @@ void main() {
checkTree
(
kBoxDecorationA
);
checkTree
(
kBoxDecorationA
);
tester
.
pumpFrame
(
tester
.
pumpFrame
(
new
TestComponentConfig
(
new
FlipComponent
(
left:
new
DecoratedBox
(
decoration:
kBoxDecorationA
),
left:
new
DecoratedBox
(
decoration:
kBoxDecorationA
),
right:
new
DecoratedBox
(
decoration:
kBoxDecorationB
)
right:
new
DecoratedBox
(
decoration:
kBoxDecorationB
)
)
)
...
@@ -97,7 +56,7 @@ void main() {
...
@@ -97,7 +56,7 @@ void main() {
test
(
'Don
\'
t rebuild subcomponents'
,
()
{
test
(
'Don
\'
t rebuild subcomponents'
,
()
{
WidgetTester
tester
=
new
WidgetTester
();
WidgetTester
tester
=
new
WidgetTester
();
tester
.
pumpFrame
(
tester
.
pumpFrame
(
new
TestComponentConfig
(
new
FlipComponent
(
left:
new
TestBuildCounter
(),
left:
new
TestBuildCounter
(),
right:
new
DecoratedBox
(
decoration:
kBoxDecorationB
)
right:
new
DecoratedBox
(
decoration:
kBoxDecorationB
)
)
)
...
...
packages/unit/test/fn3/test_widgets.dart
0 → 100644
View file @
8b162b59
import
'package:sky/src/fn3.dart'
;
import
'package:test/test.dart'
;
import
'widget_tester.dart'
;
final
BoxDecoration
kBoxDecorationA
=
new
BoxDecoration
(
backgroundColor:
const
Color
(
0xFFFF0000
)
);
final
BoxDecoration
kBoxDecorationB
=
new
BoxDecoration
(
backgroundColor:
const
Color
(
0xFF00FF00
)
);
final
BoxDecoration
kBoxDecorationC
=
new
BoxDecoration
(
backgroundColor:
const
Color
(
0xFF0000FF
)
);
class
FlipComponent
extends
StatefulComponent
{
FlipComponent
({
Key
key
,
this
.
left
,
this
.
right
})
:
super
(
key:
key
);
final
Widget
left
;
final
Widget
right
;
FlipComponentState
createState
()
=>
new
FlipComponentState
(
this
);
}
class
FlipComponentState
extends
ComponentState
<
FlipComponent
>
{
FlipComponentState
(
FlipComponent
config
):
super
(
config
);
bool
_showLeft
=
true
;
void
flip
()
{
setState
(()
{
_showLeft
=
!
_showLeft
;
});
}
Widget
build
(
BuildContext
context
)
{
return
_showLeft
?
config
.
left
:
config
.
right
;
}
}
class
TestBuildCounter
extends
StatelessComponent
{
static
int
buildCount
=
0
;
Widget
build
(
BuildContext
context
)
{
++
buildCount
;
return
new
DecoratedBox
(
decoration:
kBoxDecorationA
);
}
}
void
flipStatefulComponent
(
WidgetTester
tester
)
{
StatefulComponentElement
stateElement
=
tester
.
findElement
((
element
)
=>
element
is
StatefulComponentElement
);
expect
(
stateElement
,
isNotNull
);
expect
(
stateElement
.
state
is
FlipComponentState
,
isTrue
);
FlipComponentState
state
=
stateElement
.
state
;
state
.
flip
();
}
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