 Chromium Code Reviews
 Chromium Code Reviews| Index: pkg/analysis_server/test/protocol_test.dart | 
| diff --git a/pkg/analysis_server/test/protocol_test.dart b/pkg/analysis_server/test/protocol_test.dart | 
| index 1ae493fc8b518121755113dbee0d28af448bdcd7..72d7d55be0b39c1ab3eaa090a56053d210cc78a6 100644 | 
| --- a/pkg/analysis_server/test/protocol_test.dart | 
| +++ b/pkg/analysis_server/test/protocol_test.dart | 
| @@ -26,13 +26,26 @@ main() { | 
| test('fromJson_invalidMethod', RequestTest.fromJson_invalidMethod); | 
| test('fromJson_invalidParams', RequestTest.fromJson_invalidParams); | 
| test('fromJson_withParams', RequestTest.fromJson_withParams); | 
| + test('toBool', RequestTest.toBool); | 
| + test('toInt', RequestTest.toInt); | 
| test('toJson', RequestTest.toJson); | 
| test('toJson_withParams', RequestTest.toJson_withParams); | 
| }); | 
| + group('RequestError', () { | 
| + test('create', RequestErrorTest.create); | 
| + test('create_methodNotFound', RequestErrorTest.create_methodNotFound); | 
| + test('create_invalidParameters', RequestErrorTest.create_invalidParameters); | 
| + test('create_invalidRequest', RequestErrorTest.create_invalidRequest); | 
| + test('create_internalError', RequestErrorTest.create_internalError); | 
| + test('create_parseError', RequestErrorTest.create_parseError); | 
| + test('fromJson', RequestErrorTest.fromJson); | 
| + test('toJson', RequestErrorTest.toJson); | 
| + }); | 
| group('Response', () { | 
| test('create_contextDoesNotExist', ResponseTest.create_contextDoesNotExist); | 
| test('create_invalidRequestFormat', ResponseTest.create_invalidRequestFormat); | 
| test('create_missingRequiredParameter', ResponseTest.create_missingRequiredParameter); | 
| + test('create_unknownAnalysisOption', ResponseTest.create_unknownAnalysisOption); | 
| test('create_unknownRequest', ResponseTest.create_unknownRequest); | 
| test('setResult', ResponseTest.setResult); | 
| test('fromJson', ResponseTest.fromJson); | 
| @@ -108,7 +121,7 @@ class RequestTest { | 
| static void getRequiredParameter_undefined() { | 
| String name = 'name'; | 
| Request request = new Request('0', ''); | 
| - expect(() => request.getRequiredParameter(name), throwsA(new isInstanceOf<RequestFailure>())); | 
| + expect(() => request.getRequiredParameter(name), _throwsRequestFailure); | 
| } | 
| static void fromJson() { | 
| @@ -147,6 +160,23 @@ class RequestTest { | 
| expect(request.getParameter('foo'), equals('bar')); | 
| } | 
| + static void toBool() { | 
| + Request request = new Request('0', ''); | 
| + expect(request.toBool(true), isTrue); | 
| + expect(request.toBool(false), isFalse); | 
| + expect(request.toBool('true'), isTrue); | 
| + expect(request.toBool('false'), isFalse); | 
| 
Brian Wilkerson
2014/04/07 18:51:48
Might be good to add a test for a string that is n
 
scheglov
2014/04/07 19:01:41
Done.
 | 
| + expect(() => request.toBool(42), _throwsRequestFailure); | 
| + } | 
| + | 
| + static void toInt() { | 
| + Request request = new Request('0', ''); | 
| + expect(request.toInt(1), equals(1)); | 
| + expect(request.toInt('2'), equals(2)); | 
| + expect(() => request.toInt('xxx'), _throwsRequestFailure); | 
| + expect(() => request.toInt(request), _throwsRequestFailure); | 
| + } | 
| + | 
| static void toJson() { | 
| Request request = new Request('one', 'aMethod'); | 
| expect(request.toJson(), equals({ | 
| @@ -166,6 +196,65 @@ class RequestTest { | 
| } | 
| } | 
| +class RequestErrorTest { | 
| + static void create() { | 
| + RequestError error = new RequestError(42, 'msg'); | 
| + expect(error.code, 42); | 
| + expect(error.message, "msg"); | 
| + expect(error.toJson(), equals({ | 
| + RequestError.CODE: 42, | 
| + RequestError.MESSAGE: "msg" | 
| + })); | 
| + } | 
| + static void create_parseError() { | 
| 
Brian Wilkerson
2014/04/07 18:51:48
nit: We should probably be consistent with spacing
 
scheglov
2014/04/07 19:01:41
Agree, we need to put an empty line between member
 | 
| + RequestError error = new RequestError.parseError(); | 
| + expect(error.code, RequestError.CODE_PARSE_ERROR); | 
| + expect(error.message, "Parse error"); | 
| + } | 
| + static void create_methodNotFound() { | 
| + RequestError error = new RequestError.methodNotFound(); | 
| + expect(error.code, RequestError.CODE_METHOD_NOT_FOUND); | 
| + expect(error.message, "Method not found"); | 
| + } | 
| + static void create_invalidParameters() { | 
| + RequestError error = new RequestError.invalidParameters(); | 
| + expect(error.code, RequestError.CODE_INVALID_PARAMS); | 
| + expect(error.message, "Invalid parameters"); | 
| + } | 
| + static void create_invalidRequest() { | 
| + RequestError error = new RequestError.invalidRequest(); | 
| + expect(error.code, RequestError.CODE_INVALID_REQUEST); | 
| + expect(error.message, "Invalid request"); | 
| + } | 
| + static void create_internalError() { | 
| + RequestError error = new RequestError.internalError(); | 
| + expect(error.code, RequestError.CODE_INTERNAL_ERROR); | 
| + expect(error.message, "Internal error"); | 
| + } | 
| + static void fromJson() { | 
| + var json = { | 
| + RequestError.CODE: RequestError.CODE_PARSE_ERROR, | 
| + RequestError.MESSAGE: 'foo', | 
| + RequestError.DATA: {'ints': [1, 2, 3]} | 
| + }; | 
| + RequestError error = new RequestError.fromJson(json); | 
| + expect(error.code, RequestError.CODE_PARSE_ERROR); | 
| + expect(error.message, "foo"); | 
| + expect(error.data['ints'], [1, 2, 3]); | 
| + expect(error.getData('ints'), [1, 2, 3]); | 
| + } | 
| + static void toJson() { | 
| + RequestError error = new RequestError(0, 'msg'); | 
| + error.setData('answer', 42); | 
| + error.setData('question', 'unknown'); | 
| + expect(error.toJson(), { | 
| + RequestError.CODE: 0, | 
| + RequestError.MESSAGE: 'msg', | 
| + RequestError.DATA: {'answer': 42, 'question': 'unknown'} | 
| + }); | 
| + } | 
| +} | 
| + | 
| class ResponseTest { | 
| static void create_contextDoesNotExist() { | 
| Response response = new Response.contextDoesNotExist(new Request('0', '')); | 
| @@ -197,13 +286,23 @@ class ResponseTest { | 
| })); | 
| } | 
| + static void create_unknownAnalysisOption() { | 
| + Response response = new Response.unknownAnalysisOption(new Request('0', ''), 'x'); | 
| + expect(response.id, equals('0')); | 
| + expect(response.error, isNotNull); | 
| + expect(response.toJson(), equals({ | 
| + Response.ID: '0', | 
| + Response.ERROR: {'code': -6, 'message': 'Unknown analysis option: "x"'} | 
| + })); | 
| + } | 
| + | 
| static void create_unknownRequest() { | 
| Response response = new Response.unknownRequest(new Request('0', '')); | 
| expect(response.id, equals('0')); | 
| expect(response.error, isNotNull); | 
| expect(response.toJson(), equals({ | 
| Response.ID: '0', | 
| - Response.ERROR: {'code': -7, 'message': 'Unknown request'} | 
| + Response.ERROR: {'code': -7, 'message': 'Unknown request'} | 
| })); | 
| } | 
| @@ -212,6 +311,7 @@ class ResponseTest { | 
| String resultValue = 'value'; | 
| Response response = new Response('0'); | 
| response.setResult(resultName, resultValue); | 
| + expect(response.getResult(resultName), same(resultValue)); | 
| expect(response.toJson(), equals({ | 
| Response.ID: '0', | 
| Response.ERROR: null, | 
| @@ -247,3 +347,5 @@ class ResponseTest { | 
| expect(result['foo'], equals('bar')); | 
| } | 
| } | 
| + | 
| +Matcher _throwsRequestFailure = throwsA(new isInstanceOf<RequestFailure>()); |