Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(224)

Issue 36933002: All isolate tests running on vm (Closed)

Created:
7 years, 2 months ago by Lasse Reichstein Nielsen
Modified:
7 years, 1 month ago
Reviewers:
floitsch
Visibility:
Public.

Description

All isolate tests running on vm

Patch Set 1 #

Total comments: 38

Patch Set 2 : Addressed review comments. #

Unified diffs Side-by-side diffs Delta from patch set Stats (+460 lines, -1556 lines) Patch
M runtime/lib/isolate_patch.dart View 1 chunk +4 lines, -1 line 0 comments Download
D tests/isolate/count_stream_test.dart View 1 chunk +0 lines, -46 lines 0 comments Download
M tests/isolate/count_test.dart View 1 1 chunk +34 lines, -28 lines 0 comments Download
D tests/isolate/cross_isolate_message_stream_test.dart View 1 chunk +0 lines, -112 lines 0 comments Download
M tests/isolate/cross_isolate_message_test.dart View 1 1 chunk +38 lines, -40 lines 0 comments Download
D tests/isolate/global_error_handler2_test.dart View 1 chunk +0 lines, -45 lines 0 comments Download
D tests/isolate/global_error_handler_stream2_test.dart View 1 chunk +0 lines, -53 lines 0 comments Download
D tests/isolate/global_error_handler_stream_test.dart View 1 chunk +0 lines, -47 lines 0 comments Download
D tests/isolate/global_error_handler_test.dart View 1 chunk +0 lines, -43 lines 0 comments Download
D tests/isolate/illegal_msg_stream_test.dart View 1 chunk +0 lines, -38 lines 0 comments Download
M tests/isolate/illegal_msg_test.dart View 1 1 chunk +27 lines, -19 lines 0 comments Download
D tests/isolate/isolate_complex_messages_stream_test.dart View 1 chunk +0 lines, -78 lines 0 comments Download
M tests/isolate/isolate_complex_messages_test.dart View 1 1 chunk +27 lines, -15 lines 0 comments Download
D tests/isolate/mandel_isolate_stream_test.dart View 1 chunk +0 lines, -155 lines 0 comments Download
M tests/isolate/mandel_isolate_test.dart View 1 3 chunks +29 lines, -16 lines 0 comments Download
M tests/isolate/message2_test.dart View 1 chunk +20 lines, -13 lines 0 comments Download
D tests/isolate/message_stream2_test.dart View 1 chunk +0 lines, -76 lines 0 comments Download
D tests/isolate/message_stream_test.dart View 1 chunk +0 lines, -144 lines 0 comments Download
M tests/isolate/message_test.dart View 2 chunks +51 lines, -41 lines 0 comments Download
M tests/isolate/mint_maker_test.dart View 1 3 chunks +70 lines, -153 lines 0 comments Download
M tests/isolate/nested_spawn2_test.dart View 1 2 chunks +33 lines, -33 lines 0 comments Download
D tests/isolate/nested_spawn_stream2_test.dart View 1 chunk +0 lines, -80 lines 0 comments Download
D tests/isolate/nested_spawn_stream_test.dart View 1 chunk +0 lines, -61 lines 0 comments Download
M tests/isolate/nested_spawn_test.dart View 1 chunk +13 lines, -21 lines 0 comments Download
M tests/isolate/port_test.dart View 3 chunks +21 lines, -21 lines 0 comments Download
M tests/isolate/request_reply_test.dart View 1 chunk +15 lines, -15 lines 0 comments Download
M tests/isolate/spawn_function_custom_class_test.dart View 1 1 chunk +6 lines, -8 lines 0 comments Download
M tests/isolate/spawn_function_test.dart View 1 1 chunk +6 lines, -6 lines 0 comments Download
M tests/isolate/spawn_uri_child_isolate.dart View 1 chunk +1 line, -1 line 0 comments Download
M tests/isolate/spawn_uri_multi_test.dart View 2 chunks +2 lines, -2 lines 0 comments Download
M tests/isolate/spawn_uri_nested_child1_vm_isolate.dart View 1 chunk +6 lines, -4 lines 0 comments Download
M tests/isolate/spawn_uri_nested_child2_vm_isolate.dart View 1 chunk +1 line, -1 line 0 comments Download
M tests/isolate/spawn_uri_nested_vm_test.dart View 1 chunk +3 lines, -2 lines 0 comments Download
M tests/isolate/spawn_uri_test.dart View 1 chunk +2 lines, -2 lines 0 comments Download
M tests/isolate/spawn_uri_vm_test.dart View 1 chunk +2 lines, -2 lines 0 comments Download
M tests/isolate/stacktrace_message_test.dart View 1 chunk +15 lines, -13 lines 0 comments Download
D tests/isolate/stream_mangling_test.dart View 1 chunk +0 lines, -103 lines 0 comments Download
M tests/isolate/unresolved_ports_test.dart View 2 chunks +34 lines, -18 lines 0 comments Download

Messages

Total messages: 3 (0 generated)
Lasse Reichstein Nielsen
Ready for comments or to be imported into your patch.
7 years, 2 months ago (2013-10-23 10:08:21 UTC) #1
floitsch
LGTM with lots of minor nits. More important: - unresolved_ports_test looks broken. - illegal_msg_test.dart seems ...
7 years, 2 months ago (2013-10-23 13:33:24 UTC) #2
Lasse Reichstein Nielsen
7 years, 2 months ago (2013-10-24 10:26:01 UTC) #3
Addressed some comments. Didn't check unresolved ports test.

https://codereview.chromium.org/36933002/diff/1/tests/isolate/count_test.dart
File tests/isolate/count_test.dart (right):

https://codereview.chromium.org/36933002/diff/1/tests/isolate/count_test.dart...
tests/isolate/count_test.dart:14: print("iso: $message");
All removed.

https://codereview.chromium.org/36933002/diff/1/tests/isolate/cross_isolate_m...
File tests/isolate/cross_isolate_message_test.dart (right):

https://codereview.chromium.org/36933002/diff/1/tests/isolate/cross_isolate_m...
tests/isolate/cross_isolate_message_test.dart:30: local.close();
On 2013/10/23 13:33:24, floitsch wrote:
> you can drop the close. "first" already closes.

Done.

https://codereview.chromium.org/36933002/diff/1/tests/isolate/cross_isolate_m...
tests/isolate/cross_isolate_message_test.dart:44: print(msg[0]);
On 2013/10/23 13:33:24, floitsch wrote:
> debug print.

Done.

https://codereview.chromium.org/36933002/diff/1/tests/isolate/illegal_msg_tes...
File tests/isolate/illegal_msg_test.dart (right):

https://codereview.chromium.org/36933002/diff/1/tests/isolate/illegal_msg_tes...
tests/isolate/illegal_msg_test.dart:15: port.list((msg) {
This is a typo, so this code doesn't run either (which is expected, sending the
message should fail in "snd.send" below, so we never reach the isolate).

https://codereview.chromium.org/36933002/diff/1/tests/isolate/illegal_msg_tes...
tests/isolate/illegal_msg_test.dart:27: asyncEnd();
It never is if the test succeeds. The expected behavior is to catch the
exception. Only if we successfully sends the bad message will the isolate be
used at all, ditto the else-branch below.

Moved asyncEnd to end of function, so async ranges overlap.

https://codereview.chromium.org/36933002/diff/1/tests/isolate/illegal_msg_tes...
tests/isolate/illegal_msg_test.dart:37: asyncStart();
Now overlaps.

https://codereview.chromium.org/36933002/diff/1/tests/isolate/isolate_complex...
File tests/isolate/isolate_complex_messages_test.dart (right):

https://codereview.chromium.org/36933002/diff/1/tests/isolate/isolate_complex...
tests/isolate/isolate_complex_messages_test.dart:30: local.close();
Done.

https://codereview.chromium.org/36933002/diff/1/tests/isolate/mandel_isolate_...
File tests/isolate/mandel_isolate_test.dart (right):

https://codereview.chromium.org/36933002/diff/1/tests/isolate/mandel_isolate_...
tests/isolate/mandel_isolate_test.dart:99: Future isolateStart =
Isolate.spawn(processLines, reply.sendPort);
I just thought the line-breaks looked better this way.
It looks artificial to split up reply.first.then by returning reply.first.

I've tried a different rewrite.

https://codereview.chromium.org/36933002/diff/1/tests/isolate/mandel_isolate_...
tests/isolate/mandel_isolate_test.dart:109: _port.send([y, reply.sendPort]);
I actually consider that the wrong order.
The safest order should be:
- Create port 
- set up listeners on port 
- reveal port to someone else.

Revealing the port before setting up the listeners will work because the stream
is buffering, but it still feels a little wrong.

I can understand the send-request/handle-reply sequencing as well, and I've not
been consistent since both versions work, so I'll change it.

https://codereview.chromium.org/36933002/diff/1/tests/isolate/mint_maker_test...
File tests/isolate/mint_maker_test.dart (right):

https://codereview.chromium.org/36933002/diff/1/tests/isolate/mint_maker_test...
tests/isolate/mint_maker_test.dart:48: _mint.send([balance, reply.sendPort]);
Ok, but I don't necessarily agree that it's better.

https://codereview.chromium.org/36933002/diff/1/tests/isolate/mint_maker_test...
tests/isolate/mint_maker_test.dart:111: ReceivePort reply = new ReceivePort();
On 2013/10/23 13:33:24, floitsch wrote:
> Create a sendReceive helper method.

Done.

https://codereview.chromium.org/36933002/diff/1/tests/isolate/nested_spawn2_t...
File tests/isolate/nested_spawn2_test.dart (right):

https://codereview.chromium.org/36933002/diff/1/tests/isolate/nested_spawn2_t...
tests/isolate/nested_spawn2_test.dart:20: init.send(port.sendPort);
On 2013/10/23 13:33:24, floitsch wrote:
> move send before port.first.

Done.

https://codereview.chromium.org/36933002/diff/1/tests/isolate/nested_spawn2_t...
tests/isolate/nested_spawn2_test.dart:34: print("-$msg");
On 2013/10/23 13:33:24, floitsch wrote:
> debug print.

Done.

https://codereview.chromium.org/36933002/diff/1/tests/isolate/request_reply_t...
File tests/isolate/request_reply_test.dart (right):

https://codereview.chromium.org/36933002/diff/1/tests/isolate/request_reply_t...
tests/isolate/request_reply_test.dart:24: Isolate.spawn(entry, init.sendPort);
The test name suggested a two-way message communication, so I wanted messages
sent in both directions.

https://codereview.chromium.org/36933002/diff/1/tests/isolate/spawn_function_...
File tests/isolate/spawn_function_custom_class_test.dart (right):

https://codereview.chromium.org/36933002/diff/1/tests/isolate/spawn_function_...
tests/isolate/spawn_function_custom_class_test.dart:34: Isolate.spawn(child,
['hi', port.sendPort]);
On 2013/10/23 13:33:24, floitsch wrote:
> I prefer the sending before the listening.

Done.

https://codereview.chromium.org/36933002/diff/1/tests/isolate/spawn_function_...
File tests/isolate/spawn_function_test.dart (right):

https://codereview.chromium.org/36933002/diff/1/tests/isolate/spawn_function_...
tests/isolate/spawn_function_test.dart:24: Isolate.spawn(child, ['hi',
port.sendPort]);
If I could put it on one line, I'd have done:
  var port = new ReceivePort()..listen(() {
    ...
  });
  Isolate.spawn(...)

But done.

https://codereview.chromium.org/36933002/diff/1/tests/isolate/unresolved_port...
File tests/isolate/unresolved_ports_test.dart (right):

https://codereview.chromium.org/36933002/diff/1/tests/isolate/unresolved_port...
tests/isolate/unresolved_ports_test.dart:27:
spawnFunction(bobIsolate).then((bob) {
Confusingly, the spawnFunction is a new function I declared below.
I works similar to the original spawnFunction in that it returns a SendPort (but
in a Future).

Powered by Google App Engine
This is Rietveld 408576698