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
522d19e2
Unverified
Commit
522d19e2
authored
Aug 06, 2020
by
Ian Hickson
Committed by
GitHub
Aug 06, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Unskip the bidi semantics test. (#62823)
parent
209e3e9f
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
49 additions
and
34 deletions
+49
-34
text_test.dart
packages/flutter/test/widgets/text_test.dart
+25
-20
platform.dart
packages/flutter_test/lib/src/platform.dart
+24
-14
No files found.
packages/flutter/test/widgets/text_test.dart
View file @
522d19e2
...
@@ -506,6 +506,13 @@ void main() {
...
@@ -506,6 +506,13 @@ void main() {
);
);
// The expected visual order of the text is:
// The expected visual order of the text is:
// hello world RIS OD you OD WOH YOB good bye
// hello world RIS OD you OD WOH YOB good bye
// There are five unique text areas, they are, in visual order but
// showing the logical text:
// [hello world][SIR][HOW DO you DO][BOY][good bye]
// The direction of each varies based on the first bit of that area.
// The presence of the bidi formatting characters in the text is a
// bit dubious, but that's what we do currently, and it's not really
// clear what the perfect behavior would be...
final
TestSemantics
expectedSemantics
=
TestSemantics
.
root
(
final
TestSemantics
expectedSemantics
=
TestSemantics
.
root
(
children:
<
TestSemantics
>[
children:
<
TestSemantics
>[
TestSemantics
.
rootChild
(
TestSemantics
.
rootChild
(
...
@@ -513,33 +520,31 @@ void main() {
...
@@ -513,33 +520,31 @@ void main() {
children:
<
TestSemantics
>[
children:
<
TestSemantics
>[
TestSemantics
(
TestSemantics
(
rect:
const
Rect
.
fromLTRB
(-
4.0
,
-
4.0
,
480.0
,
18.0
),
rect:
const
Rect
.
fromLTRB
(-
4.0
,
-
4.0
,
480.0
,
18.0
),
label:
'hello world '
,
label:
'hello world
${Unicode.RLE}${Unicode.RLO}
'
,
textDirection:
TextDirection
.
ltr
,
// text direction is declared as LTR.
textDirection:
TextDirection
.
ltr
,
),
),
TestSemantics
(
TestSemantics
(
rect:
const
Rect
.
fromLTRB
(
150.0
,
-
4.0
,
200.0
,
18.0
),
rect:
const
Rect
.
fromLTRB
(
416.0
,
-
4.0
,
466.0
,
18.0
),
label:
'RIS'
,
label:
'BOY'
,
textDirection:
TextDirection
.
rtl
,
// in the last string we switched to RTL using RLE.
textDirection:
TextDirection
.
rtl
,
actions:
<
SemanticsAction
>[
SemanticsAction
.
tap
],
actions:
<
SemanticsAction
>[
SemanticsAction
.
longPress
],
flags:
<
SemanticsFlag
>[
SemanticsFlag
.
isLink
],
),
),
TestSemantics
(
TestSemantics
(
rect:
const
Rect
.
fromLTRB
(
192.0
,
-
4.0
,
424.0
,
18.0
),
rect:
const
Rect
.
fromLTRB
(
192.0
,
-
4.0
,
424.0
,
18.0
),
label:
'
OD you OD WOH '
,
// Still RTL.
label:
'
HOW DO
${Unicode.PDF}
you
${Unicode.RLO}
DO '
,
textDirection:
TextDirection
.
rtl
,
textDirection:
TextDirection
.
rtl
,
),
),
TestSemantics
(
TestSemantics
(
rect:
const
Rect
.
fromLTRB
(
416.0
,
-
4.0
,
466.0
,
18.0
),
rect:
const
Rect
.
fromLTRB
(
150.0
,
-
4.0
,
200.0
,
18.0
),
label:
'YOB'
,
label:
'SIR'
,
textDirection:
TextDirection
.
rtl
,
// Still RTL.
textDirection:
TextDirection
.
rtl
,
actions:
<
SemanticsAction
>[
actions:
<
SemanticsAction
>[
SemanticsAction
.
tap
],
SemanticsAction
.
longPress
,
flags:
<
SemanticsFlag
>[
SemanticsFlag
.
isLink
],
],
),
),
TestSemantics
(
TestSemantics
(
rect:
const
Rect
.
fromLTRB
(
472.0
,
-
4.0
,
606.0
,
18.0
),
rect:
const
Rect
.
fromLTRB
(
472.0
,
-
4.0
,
606.0
,
18.0
),
label:
' good bye'
,
label:
'
${Unicode.PDF}${Unicode.PDF}
good bye'
,
textDirection:
TextDirection
.
rtl
,
// Begin as RTL but pop to LTR.
textDirection:
TextDirection
.
rtl
,
),
),
],
],
),
),
...
@@ -554,7 +559,7 @@ void main() {
...
@@ -554,7 +559,7 @@ void main() {
),
),
);
);
semantics
.
dispose
();
semantics
.
dispose
();
},
skip:
true
);
// https://github.com/flutter/flutter/issues/20891
},
skip:
isBrowser
);
// https://github.com/flutter/flutter/issues/62945
testWidgets
(
'TapGesture recognizers contribute link semantics'
,
(
WidgetTester
tester
)
async
{
testWidgets
(
'TapGesture recognizers contribute link semantics'
,
(
WidgetTester
tester
)
async
{
final
SemanticsTester
semantics
=
SemanticsTester
(
tester
);
final
SemanticsTester
semantics
=
SemanticsTester
(
tester
);
...
@@ -862,7 +867,7 @@ void main() {
...
@@ -862,7 +867,7 @@ void main() {
final
Size
textSizeLongestLine
=
tester
.
getSize
(
find
.
byType
(
Text
));
final
Size
textSizeLongestLine
=
tester
.
getSize
(
find
.
byType
(
Text
));
expect
(
textSizeLongestLine
.
width
,
equals
(
630.0
));
expect
(
textSizeLongestLine
.
width
,
equals
(
630.0
));
expect
(
textSizeLongestLine
.
height
,
equals
(
fontHeight
*
2
));
expect
(
textSizeLongestLine
.
height
,
equals
(
fontHeight
*
2
));
},
skip:
isBrowser
);
// https://github.com/flutter/flutter/issues/44020
},
skip:
isBrowser
);
// https://github.com/flutter/flutter/issues/44020
testWidgets
(
'textWidthBasis with textAlign still obeys parent alignment'
,
(
WidgetTester
tester
)
async
{
testWidgets
(
'textWidthBasis with textAlign still obeys parent alignment'
,
(
WidgetTester
tester
)
async
{
await
tester
.
pumpWidget
(
await
tester
.
pumpWidget
(
...
@@ -912,7 +917,7 @@ void main() {
...
@@ -912,7 +917,7 @@ void main() {
expect
(
tester
.
getSize
(
find
.
text
(
'RIGHT ALIGNED, PARENT'
)).
width
,
lessThan
(
width
));
expect
(
tester
.
getSize
(
find
.
text
(
'RIGHT ALIGNED, PARENT'
)).
width
,
lessThan
(
width
));
expect
(
tester
.
getSize
(
find
.
text
(
'LEFT ALIGNED, LONGEST LINE'
)).
width
,
lessThan
(
width
));
expect
(
tester
.
getSize
(
find
.
text
(
'LEFT ALIGNED, LONGEST LINE'
)).
width
,
lessThan
(
width
));
expect
(
tester
.
getSize
(
find
.
text
(
'RIGHT ALIGNED, LONGEST LINE'
)).
width
,
equals
(
width
));
expect
(
tester
.
getSize
(
find
.
text
(
'RIGHT ALIGNED, LONGEST LINE'
)).
width
,
equals
(
width
));
},
skip:
isBrowser
);
// https://github.com/flutter/flutter/issues/44020
},
skip:
isBrowser
);
// https://github.com/flutter/flutter/issues/44020
testWidgets
(
testWidgets
(
'textWidthBasis.longestLine confines the width of the paragraph '
'textWidthBasis.longestLine confines the width of the paragraph '
...
@@ -944,7 +949,7 @@ void main() {
...
@@ -944,7 +949,7 @@ void main() {
throw
'paragraph.width (
${paragraph.width}
) >= 400'
;
throw
'paragraph.width (
${paragraph.width}
) >= 400'
;
return
true
;
return
true
;
}));
}));
},
skip:
isBrowser
);
// https://github.com/flutter/flutter/issues/44020
},
skip:
isBrowser
);
// https://github.com/flutter/flutter/issues/44020
testWidgets
(
'Paragraph.getBoxesForRange returns nothing when selection range is zero length'
,
(
WidgetTester
tester
)
async
{
testWidgets
(
'Paragraph.getBoxesForRange returns nothing when selection range is zero length'
,
(
WidgetTester
tester
)
async
{
final
ui
.
ParagraphBuilder
builder
=
ui
.
ParagraphBuilder
(
ui
.
ParagraphStyle
());
final
ui
.
ParagraphBuilder
builder
=
ui
.
ParagraphBuilder
(
ui
.
ParagraphStyle
());
...
...
packages/flutter_test/lib/src/platform.dart
View file @
522d19e2
...
@@ -4,16 +4,23 @@
...
@@ -4,16 +4,23 @@
import
'dart:io'
;
import
'dart:io'
;
// Whether the current dart code is running in an environment that was compiled
/// Whether the test is running in a web browser compiled to JavaScript.
// to JavaScript.
///
const
bool
_kIsCompiledToJavaScript
=
identical
(
0
,
0.0
);
/// See also:
///
/// * [kIsWeb], the equivalent constant in the `foundation` library.
const
bool
isBrowser
=
identical
(
0
,
0.0
);
/// Whether the test is running on the Windows operating system.
/// Whether the test is running on the Windows operating system.
///
///
/// This does not include test compiled to JavaScript running in a browser on
/// This does not include test
s
compiled to JavaScript running in a browser on
/// the Windows operating system.
/// the Windows operating system.
///
/// See also:
///
/// * [isBrowser], which reports true for tests running in browsers.
bool
get
isWindows
{
bool
get
isWindows
{
if
(
_kIsCompiledToJavaScript
)
{
if
(
isBrowser
)
{
return
false
;
return
false
;
}
}
return
Platform
.
isWindows
;
return
Platform
.
isWindows
;
...
@@ -21,10 +28,14 @@ bool get isWindows {
...
@@ -21,10 +28,14 @@ bool get isWindows {
/// Whether the test is running on the macOS operating system.
/// Whether the test is running on the macOS operating system.
///
///
/// This does not include test compiled to JavaScript running in a browser on
/// This does not include test
s
compiled to JavaScript running in a browser on
/// the macOS operating system.
/// the macOS operating system.
///
/// See also:
///
/// * [isBrowser], which reports true for tests running in browsers.
bool
get
isMacOS
{
bool
get
isMacOS
{
if
(
_kIsCompiledToJavaScript
)
{
if
(
isBrowser
)
{
return
false
;
return
false
;
}
}
return
Platform
.
isMacOS
;
return
Platform
.
isMacOS
;
...
@@ -32,16 +43,15 @@ bool get isMacOS {
...
@@ -32,16 +43,15 @@ bool get isMacOS {
/// Whether the test is running on the Linux operating system.
/// Whether the test is running on the Linux operating system.
///
///
/// This does not include test compiled to JavaScript running in a browser on
/// This does not include test
s
compiled to JavaScript running in a browser on
/// the Linux operating system.
/// the Linux operating system.
///
/// See also:
///
/// * [isBrowser], which reports true for tests running in browsers.
bool
get
isLinux
{
bool
get
isLinux
{
if
(
_kIsCompiledToJavaScript
)
{
if
(
isBrowser
)
{
return
false
;
return
false
;
}
}
return
Platform
.
isLinux
;
return
Platform
.
isLinux
;
}
}
/// Whether the test is running in a web browser compiled to JavaScript.
bool
get
isBrowser
{
return
_kIsCompiledToJavaScript
;
}
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