[geary/wip/781488-aliyun-greeting-error: 2/6] Assorted async test case fixes.
- From: Michael Gratton <mjog src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [geary/wip/781488-aliyun-greeting-error: 2/6] Assorted async test case fixes.
- Date: Mon, 30 Oct 2017 06:21:51 +0000 (UTC)
commit 9df93216b8404dc1ae407ca6da71d2eaebebb01c
Author: Michael James Gratton <mike vee net>
Date: Mon Oct 30 11:53:18 2017 +1100
Assorted async test case fixes.
* test/testcase.vala (TestCase): Make the test case's main loop
accessible to subclasses so they are using the same one we are.
(TestCase::async_result): Use GLib main context rather than GTK+ main
loop so that test cases with async methods work even when GTK+ not
present.
(TestCase::async_complete): Ensure the main loop is woken when an async
test completes so the test case doesn't block if it loses the race with
async_result();
test/testcase.vala | 7 ++++++-
1 files changed, 6 insertions(+), 1 deletions(-)
---
diff --git a/test/testcase.vala b/test/testcase.vala
index 291ead9..bb94df4 100644
--- a/test/testcase.vala
+++ b/test/testcase.vala
@@ -24,6 +24,8 @@
public abstract class Gee.TestCase : Object {
+ protected MainContext main_loop = MainContext.default();
+
private GLib.TestSuite suite;
private Adaptor[] adaptors = new Adaptor[0];
private AsyncQueue<AsyncResult> async_results = new AsyncQueue<AsyncResult>();
@@ -56,12 +58,15 @@ public abstract class Gee.TestCase : Object {
protected void async_complete(AsyncResult result) {
this.async_results.push(result);
+ // notify the loop so that if async_result() has already been
+ // called, that method won't block
+ this.main_loop.wakeup();
}
protected AsyncResult async_result() {
AsyncResult? result = null;
while (result == null) {
- Gtk.main_iteration();
+ this.main_loop.iteration(true);
result = this.async_results.try_pop();
}
return result;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]