Chromium Code Reviews| 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..d892e6c06bcbe9604a131327287f35a2f2eef181 |
| --- /dev/null |
| +++ b/runtime/observatory/tests/service/file_service_test.dart |
| @@ -0,0 +1,102 @@ |
| +// 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 = [ |
| + // Initial. |
|
Søren Gjesse
2015/09/08 07:55:54
Not sure what that comment means.
ricow1
2015/09/08 09:26:38
I am not completely sure either :-)
|
| + (Isolate isolate) async { |
| + await isolate.invokeRpcNoUpgrade('__setup', {}); |
| + try { |
| + var result = await isolate.invokeRpcNoUpgrade('__getOpenFiles', {}); |
| + expect(result['type'], equals('_openfiles')); |
| + print(result); |
|
Søren Gjesse
2015/09/08 07:55:54
Debug print.
ricow1
2015/09/08 09:26:38
Done.
|
| + |
| + 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); |