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

Side by Side Diff: samples/sample_extension/test/sample_extension_script_snapshot_test.dart

Issue 2475523002: Reload native extensions when starting from a snapshot. (Closed)
Patch Set: Use temp directory for snapshot Created 4 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 // 4 //
5 // Dart test program for testing native extensions. 5 // Dart test program for testing native extensions.
6 6
7 import 'dart:async'; 7 import 'dart:async';
8 import 'dart:io'; 8 import 'dart:io';
9 import 'dart:isolate'; 9 import 'dart:isolate';
10 10
(...skipping 20 matching lines...) Expand all
31 return join(buildDirectory, 'lib.target', 'libsample_extension.so'); 31 return join(buildDirectory, 'lib.target', 'libsample_extension.so');
32 case 'macos': 32 case 'macos':
33 return join(buildDirectory, 'libsample_extension.dylib'); 33 return join(buildDirectory, 'libsample_extension.dylib');
34 case 'windows': 34 case 'windows':
35 return join(buildDirectory, 'sample_extension.dll'); 35 return join(buildDirectory, 'sample_extension.dll');
36 default: 36 default:
37 Expect.fail('Unknown operating system ${Platform.operatingSystem}'); 37 Expect.fail('Unknown operating system ${Platform.operatingSystem}');
38 } 38 }
39 } 39 }
40 40
41 void main() { 41 void main() async {
42 String buildDirectory = dirname(Platform.executable); 42 String buildDirectory = dirname(Platform.executable);
43 Directory tempDirectory = 43 Directory tempDirectory =
44 Directory.systemTemp.createTempSync('sample_extension_'); 44 Directory.systemTemp.createTempSync('sample_extension_');
45 String testDirectory = tempDirectory.path; 45 try {
46 String sourceDirectory = Platform.script.resolve('..').toFilePath(); 46 String testDirectory = tempDirectory.path;
47 String sourceDirectory = Platform.script.resolve('..').toFilePath();
47 48
48 // Copy sample_extension shared library, sample_extension dart files and 49 // Copy sample_extension shared library, sample_extension dart files and
49 // sample_extension tests to the temporary test directory. 50 // sample_extension tests to the temporary test directory.
50 copyFileToDirectory(getNativeLibraryPath(buildDirectory), testDirectory) 51 await copyFileToDirectory(getNativeLibraryPath(buildDirectory),
51 .then((_) => Future.forEach(['sample_synchronous_extension.dart', 52 testDirectory);
52 'sample_asynchronous_extension.dart', 53 for (var file in ['sample_synchronous_extension.dart',
53 'test_sample_synchronous_extension.dart', 54 'sample_asynchronous_extension.dart',
54 'test_sample_asynchronous_extension.dart'], 55 'test_sample_synchronous_extension.dart',
55 (file) => copyFileToDirectory(join(sourceDirectory, file), testDirectory) 56 'test_sample_asynchronous_extension.dart']) {
56 )) 57 await copyFileToDirectory(join(sourceDirectory, file), testDirectory);
58 }
57 59
58 .then((_) => Future.forEach(['test_sample_synchronous_extension.dart', 60 for (var test in ['test_sample_synchronous_extension.dart',
59 'test_sample_asynchronous_extension.dart'], 61 'test_sample_asynchronous_extension.dart']) {
60 (test) => Process.run(Platform.executable, [join(testDirectory, test)]) 62 String script = join(testDirectory, test);
61 .then((ProcessResult result) { 63 String snapshot = join(testDirectory, "$test.snapshot");
64 ProcessResult result = await Process.run(Platform.executable,
Cutch 2016/11/03 17:45:34 the only difference between this file and the prev
65 ['--snapshot=$snapshot',
66 script]);
62 if (result.exitCode != 0) { 67 if (result.exitCode != 0) {
63 print('Failing test: ${join(sourceDirectory, test)}'); 68 print('Failing test: ${join(sourceDirectory, test)}');
64 print('Failing process stdout: ${result.stdout}'); 69 print('Failing process stdout: ${result.stdout}');
65 print('Failing process stderr: ${result.stderr}'); 70 print('Failing process stderr: ${result.stderr}');
66 print('End failing process stderr'); 71 print('End failing process stderr');
67 Expect.fail('Test failed with exit code ${result.exitCode}'); 72 Expect.fail('Test failed with exit code ${result.exitCode}');
68 } 73 }
69 }) 74
70 )) 75 result = await Process.run(Platform.executable,
71 .whenComplete(() => tempDirectory.deleteSync(recursive: true)); 76 [snapshot]);
77 if (result.exitCode != 0) {
78 print('Failing test: ${join(sourceDirectory, test)}');
79 print('Failing process stdout: ${result.stdout}');
80 print('Failing process stderr: ${result.stderr}');
81 print('End failing process stderr');
82 Expect.fail('Test failed with exit code ${result.exitCode}');
83 }
84 }
85 } finally {
86 await tempDirectory.deleteSync(recursive: true);
87 }
72 } 88 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698