| // Copyright (c) 2016, 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:convert'; |
| import 'package:observatory_2/service_io.dart'; |
| import 'package:test/test.dart'; |
| import 'test_helper.dart'; |
| |
| var tests = <VMTest>[ |
| (VM vm) async { |
| var result = await vm.invokeRpcNoUpgrade('_listDevFS', {}); |
| expect(result['type'], equals('FileSystemList')); |
| expect(result['fsNames'].toString(), equals("[]")); |
| |
| var params = {'fsName': 'alpha'}; |
| result = await vm.invokeRpcNoUpgrade('_createDevFS', params); |
| expect(result['type'], equals('FileSystem')); |
| expect(result['name'], equals('alpha')); |
| expect(result['uri'], isA<String>()); |
| |
| result = await vm.invokeRpcNoUpgrade('_listDevFS', {}); |
| expect(result['type'], equals('FileSystemList')); |
| expect(result['fsNames'].toString(), equals('[alpha]')); |
| |
| bool caughtException; |
| try { |
| await vm.invokeRpcNoUpgrade('_createDevFS', params); |
| expect(false, isTrue, reason: 'Unreachable'); |
| } on ServerRpcException catch (e) { |
| caughtException = true; |
| expect(e.code, equals(ServerRpcException.kFileSystemAlreadyExists)); |
| expect(e.message, "_createDevFS: file system 'alpha' already exists"); |
| } |
| expect(caughtException, isTrue); |
| |
| result = await vm.invokeRpcNoUpgrade('_deleteDevFS', params); |
| expect(result['type'], equals('Success')); |
| |
| result = await vm.invokeRpcNoUpgrade('_listDevFS', {}); |
| expect(result['type'], equals('FileSystemList')); |
| expect(result['fsNames'].toString(), equals("[]")); |
| |
| caughtException = false; |
| try { |
| await vm.invokeRpcNoUpgrade('_deleteDevFS', params); |
| expect(false, isTrue, reason: 'Unreachable'); |
| } on ServerRpcException catch (e) { |
| caughtException = true; |
| expect(e.code, equals(ServerRpcException.kFileSystemDoesNotExist)); |
| expect(e.message, "_deleteDevFS: file system 'alpha' does not exist"); |
| } |
| expect(caughtException, isTrue); |
| }, |
| (VM vm) async { |
| var fsId = 'banana'; |
| var filePath = '/foo/bar.dat'; |
| var fileContents = base64Encode(utf8.encode('fileContents')); |
| |
| var result; |
| // Create DevFS. |
| result = await vm.invokeRpcNoUpgrade('_createDevFS', {'fsName': fsId}); |
| expect(result['type'], equals('FileSystem')); |
| expect(result['name'], equals(fsId)); |
| expect(result['uri'], isA<String>()); |
| |
| bool caughtException = false; |
| try { |
| await vm.invokeRpcNoUpgrade('_readDevFSFile', { |
| 'fsName': fsId, |
| 'path': filePath, |
| }); |
| expect(false, isTrue, reason: 'Unreachable'); |
| } on ServerRpcException catch (e) { |
| caughtException = true; |
| expect(e.code, equals(ServerRpcException.kFileDoesNotExist)); |
| expect(e.message, startsWith("_readDevFSFile: FileSystemException: ")); |
| } |
| expect(caughtException, isTrue); |
| |
| // Write a file. |
| result = await vm.invokeRpcNoUpgrade('_writeDevFSFile', |
| {'fsName': fsId, 'path': filePath, 'fileContents': fileContents}); |
| expect(result['type'], equals('Success')); |
| |
| // Read the file back. |
| result = await vm.invokeRpcNoUpgrade('_readDevFSFile', { |
| 'fsName': fsId, |
| 'path': filePath, |
| }); |
| expect(result['type'], equals('FSFile')); |
| expect(result['fileContents'], equals(fileContents)); |
| |
| // The leading '/' is optional. |
| result = await vm.invokeRpcNoUpgrade('_readDevFSFile', { |
| 'fsName': fsId, |
| 'path': filePath.substring(1), |
| }); |
| expect(result['type'], equals('FSFile')); |
| expect(result['fileContents'], equals(fileContents)); |
| |
| // Read a file outside of the fs. |
| caughtException = false; |
| try { |
| await vm.invokeRpcNoUpgrade('_readDevFSFile', { |
| 'fsName': fsId, |
| 'path': '../foo', |
| }); |
| expect(false, isTrue, reason: 'Unreachable'); |
| } on ServerRpcException catch (e) { |
| caughtException = true; |
| expect(e.code, equals(ServerRpcException.kInvalidParams)); |
| expect(e.message, "_readDevFSFile: invalid 'path' parameter: ../foo"); |
| } |
| expect(caughtException, isTrue); |
| |
| // Write a set of files. |
| result = await vm.invokeRpcNoUpgrade('_writeDevFSFiles', { |
| 'fsName': fsId, |
| 'files': [ |
| ['/a', base64Encode(utf8.encode('a_contents'))], |
| ['/b', base64Encode(utf8.encode('b_contents'))] |
| ] |
| }); |
| expect(result['type'], equals('Success')); |
| |
| // Read one of the files back. |
| result = await vm.invokeRpcNoUpgrade('_readDevFSFile', { |
| 'fsName': fsId, |
| 'path': '/b', |
| }); |
| expect(result['type'], equals('FSFile')); |
| expect(result['fileContents'], |
| equals(base64Encode(utf8.encode('b_contents')))); |
| |
| // List all the files in the file system. |
| result = await vm.invokeRpcNoUpgrade('_listDevFSFiles', { |
| 'fsName': fsId, |
| }); |
| expect(result['type'], equals('FSFileList')); |
| expect(result['files'].length, equals(3)); |
| |
| // Delete DevFS. |
| result = await vm.invokeRpcNoUpgrade('_deleteDevFS', { |
| 'fsName': fsId, |
| }); |
| expect(result['type'], equals('Success')); |
| }, |
| ]; |
| |
| main(args) async => runVMTests(args, tests); |