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

Unified Diff: runtime/observatory/tests/service/file_service_test.dart

Issue 1326703004: Add resource metadata for open files. (Closed) Base URL: https://github.com/dart-lang/sdk.git@master
Patch Set: address comments Created 5 years, 3 months 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | sdk/lib/io/file_impl.dart » ('j') | sdk/lib/io/file_impl.dart » ('J')
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: runtime/observatory/tests/service/file_service_test.dart
diff --git a/runtime/observatory/tests/service/file_service_test.dart b/runtime/observatory/tests/service/file_service_test.dart
new file mode 100644
index 0000000000000000000000000000000000000000..dbb8e530e7b73e3d719d6d051fc2531f7974f938
--- /dev/null
+++ b/runtime/observatory/tests/service/file_service_test.dart
@@ -0,0 +1,101 @@
+// Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file
+// for details. All rights reserved. Use of this source code is governed by a
+// BSD-style license that can be found in the LICENSE file.
+
+import 'dart:async';
+import 'dart:convert';
+import 'dart:developer';
+import 'dart:io' as io;
+import 'package:observatory/service_io.dart';
+import 'package:unittest/unittest.dart';
+import 'test_helper.dart';
+
+Future setupFiles() async {
+ var dir = await io.Directory.systemTemp.createTemp('file_service');
+ var writingFile;
+ var readingFile;
+
+ void closeDown() {
+ if (writingFile != null) {
+ writingFile.closeSync();
+ }
+ if (readingFile != null) {
+ readingFile.closeSync();
+ }
+ dir.deleteSync(recursive: true);
+ }
+
+ Future<ServiceExtensionResponse> cleanup(ignored_a, ignored_b) {
+ closeDown();
+ var result = JSON.encode({'type' : 'foobar'});
+ return new Future.value(new ServiceExtensionResponse.result(result));
+ }
+
+ Future<ServiceExtensionResponse> setup(ignored_a, ignored_b) async {
+ try {
+ var filePath = dir.path + io.Platform.pathSeparator + "file";
+ var f = new io.File(filePath);
+ writingFile = await f.open(mode: io.FileMode.WRITE);
+ await writingFile.writeByte(42);
+ await writingFile.writeByte(42);
+ await writingFile.writeByte(42);
+
+ var file = new io.File.fromUri(io.Platform.script);
+ readingFile = await file.open();
+ await readingFile.readByte();
+ await readingFile.readByte();
+ await readingFile.readByte();
+ await readingFile.readByte();
+ await readingFile.readByte();
+
+ // The utility functions should close the files after them, so we
+ // don't expect the calls below to result in open files.
+ var writeTemp = dir.path + io.Platform.pathSeparator + "other_file";
+ var utilFile = new io.File(writeTemp);
+ await utilFile.writeAsString('foobar');
+ var readTemp = new io.File(writeTemp);
+ var result = await readTemp.readAsString();
+ expect(result, equals('foobar'));
+
+ } catch (e) {
+ closeDown();
+ throw e;
+ }
+ var result = JSON.encode({'type' : 'foobar'});
+ return new Future.value(new ServiceExtensionResponse.result(result));
+ }
+ registerExtension('__cleanup', cleanup);
+ registerExtension('__setup', setup);
+}
+
+var fileTests = [
+ (Isolate isolate) async {
+ await isolate.invokeRpcNoUpgrade('__setup', {});
+ try {
+ var result = await isolate.invokeRpcNoUpgrade('__getOpenFiles', {});
+ expect(result['type'], equals('_openfiles'));
+
+ expect(result['data'].length, equals(2));
+ var writing = await isolate.invokeRpcNoUpgrade(
+ '__getFileByID', { 'id' : result['data'][0]['id'] });
+
+ expect(writing['total_read'], equals(0));
+ expect(writing['read_count'], equals(0));
+ expect(writing['write_count'], equals(3));
+ expect(writing['total_written'], equals(3));
+
+ var reading = await isolate.invokeRpcNoUpgrade(
+ '__getFileByID', { 'id' : result['data'][1]['id'] });
+
+
+ expect(reading['total_read'], equals(5));
+ expect(reading['read_count'], equals(5));
+ expect(reading['write_count'], equals(0));
+ expect(reading['total_written'], equals(0));
+ } finally {
+ await isolate.invokeRpcNoUpgrade('__cleanup', {});
+ }
+ },
+];
+
+main(args) async => runIsolateTests(args, fileTests, testeeBefore:setupFiles);
« no previous file with comments | « no previous file | sdk/lib/io/file_impl.dart » ('j') | sdk/lib/io/file_impl.dart » ('J')

Powered by Google App Engine
This is Rietveld 408576698