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
586ab30c
Commit
586ab30c
authored
Feb 24, 2016
by
Yegor
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #2126 from yjbanov/sample-driver-test-waits
wait for text to change in the sample driver test
parents
ccc9a25a
d2c94990
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
64 additions
and
27 deletions
+64
-27
retry.dart
packages/flutter_driver/lib/src/retry.dart
+12
-1
retry_test.dart
packages/flutter_driver/test/retry_test.dart
+43
-22
e2e_test.dart.tmpl
packages/flutter_tools/templates/driver/e2e_test.dart.tmpl
+9
-4
No files found.
packages/flutter_driver/lib/src/retry.dart
View file @
586ab30c
...
@@ -19,7 +19,7 @@ Future<dynamic> retry(Action action, Duration timeout,
...
@@ -19,7 +19,7 @@ Future<dynamic> retry(Action action, Duration timeout,
assert
(
timeout
!=
null
);
assert
(
timeout
!=
null
);
assert
(
pauseBetweenRetries
!=
null
);
assert
(
pauseBetweenRetries
!=
null
);
Stopwatch
sw
=
new
Stopwatch
()..
start
();
Stopwatch
sw
=
stopwatchFactory
()..
start
();
dynamic
result
=
null
;
dynamic
result
=
null
;
dynamic
lastError
=
null
;
dynamic
lastError
=
null
;
dynamic
lastStackTrace
=
null
;
dynamic
lastStackTrace
=
null
;
...
@@ -43,3 +43,14 @@ Future<dynamic> retry(Action action, Duration timeout,
...
@@ -43,3 +43,14 @@ Future<dynamic> retry(Action action, Duration timeout,
else
else
return
new
Future
.
error
(
lastError
,
lastStackTrace
);
return
new
Future
.
error
(
lastError
,
lastStackTrace
);
}
}
/// A function that produces a [Stopwatch].
typedef
Stopwatch
StopwatchFactory
(
);
/// Restores [stopwatchFactory] to the default implementation.
void
restoreStopwatchFactory
(
)
{
stopwatchFactory
=
()
=>
new
Stopwatch
();
}
/// Used by [retry] as a source of [Stopwatch] implementation.
StopwatchFactory
stopwatchFactory
=
()
=>
new
Stopwatch
();
packages/flutter_driver/test/retry_test.dart
View file @
586ab30c
...
@@ -3,14 +3,29 @@
...
@@ -3,14 +3,29 @@
// found in the LICENSE file.
// found in the LICENSE file.
import
'package:test/test.dart'
;
import
'package:test/test.dart'
;
import
'package:quiver/time.dart'
;
import
'package:quiver/testing/async.dart'
;
import
'package:quiver/testing/async.dart'
;
import
'package:quiver/testing/time.dart'
;
import
'package:flutter_driver/src/retry.dart'
;
import
'package:flutter_driver/src/retry.dart'
;
main
()
{
main
()
{
group
(
'retry'
,
()
{
group
(
'retry'
,
()
{
FakeAsync
fakeAsync
;
setUp
(()
{
fakeAsync
=
new
FakeAsync
();
Clock
fakeClock
=
fakeAsync
.
getClock
(
new
DateTime
.
now
());
stopwatchFactory
=
()
{
return
new
FakeStopwatch
(
()
=>
fakeClock
.
now
().
millisecondsSinceEpoch
,
1000
);
};
});
test
(
'retries until succeeds'
,
()
{
test
(
'retries until succeeds'
,
()
{
new
FakeAsync
().
run
((
FakeAsync
fakeAsync
)
{
fakeAsync
.
run
((
_
)
{
int
retryCount
=
0
;
int
retryCount
=
0
;
expect
(
expect
(
...
@@ -37,28 +52,34 @@ main() {
...
@@ -37,28 +52,34 @@ main() {
});
});
test
(
'times out returning last error'
,
()
async
{
test
(
'times out returning last error'
,
()
async
{
bool
timedOut
=
false
;
fakeAsync
.
run
((
_
)
{
int
retryCount
=
0
;
bool
timedOut
=
false
;
dynamic
lastError
;
int
retryCount
=
0
;
dynamic
lastStackTrace
;
dynamic
lastError
;
dynamic
lastStackTrace
;
await
retry
(
retry
(
()
{
()
{
retryCount
++;
retryCount
++;
throw
'error'
;
throw
'error'
;
},
},
new
Duration
(
milliseconds:
9
),
new
Duration
(
milliseconds:
7
),
new
Duration
(
milliseconds:
2
)
new
Duration
(
milliseconds:
2
)
).
catchError
((
error
,
stackTrace
)
{
).
catchError
((
error
,
stackTrace
)
{
timedOut
=
true
;
timedOut
=
true
;
lastError
=
error
;
lastError
=
error
;
lastStackTrace
=
stackTrace
;
lastStackTrace
=
stackTrace
;
});
});
print
(
'before elapse'
);
fakeAsync
.
elapse
(
new
Duration
(
milliseconds:
10
));
print
(
'after elapse'
);
expect
(
timedOut
,
isTrue
);
expect
(
timedOut
,
isTrue
);
expect
(
lastError
,
'error'
);
expect
(
lastError
,
'error'
);
expect
(
lastStackTrace
,
isNotNull
);
expect
(
lastStackTrace
,
isNotNull
);
expect
(
retryCount
,
4
);
expect
(
retryCount
,
4
);
},
skip:
"Flaky. See https://github.com/flutter/flutter/issues/2133"
);
});
});
});
});
}
}
packages/flutter_tools/templates/driver/e2e_test.dart.tmpl
View file @
586ab30c
...
@@ -32,13 +32,18 @@ main() {
...
@@ -32,13 +32,18 @@ main() {
});
});
test('tap on the floating action button; verify counter', () async {
test('tap on the floating action button; verify counter', () async {
// Find floating action button (fab) to tap on
ObjectRef fab = await driver.findByValueKey('fab');
ObjectRef fab = await driver.findByValueKey('fab');
expect(fab, isNotNull);
expect(fab, isNotNull);
// Tap on the fab
await driver.tap(fab);
await driver.tap(fab);
ObjectRef counter = await driver.findByValueKey('counter');
expect(counter, isNotNull);
// Wait for text to change to the desired value
String text = await driver.getText(counter);
await driver.waitFor(() async {
expect(text, contains("Button tapped 1 times."));
ObjectRef counter = await driver.findByValueKey('counter');
return await driver.getText(counter);
}, contains("Button tapped 1 times."));
});
});
});
});
}
}
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