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

Side by Side Diff: utils/tests/pub/pub_lish_test.dart

Issue 11348285: Work around issue 6984. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 8 years 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2012, 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 library pub_lish_test; 5 library pub_lish_test;
6 6
7 import 'dart:io'; 7 import 'dart:io';
8 import 'dart:json'; 8 import 'dart:json';
9 9
10 import 'test_pub.dart'; 10 import 'test_pub.dart';
11 import '../../../pkg/unittest/lib/unittest.dart'; 11 import '../../../pkg/unittest/lib/unittest.dart';
12 import '../../pub/io.dart'; 12 import '../../pub/io.dart';
13 13
14 void handleUploadForm(ScheduledServer server, [Map body]) { 14 void handleUploadForm(ScheduledServer server, [Map body]) {
15 server.handle('GET', '/packages/versions/new.json', (request, response) { 15 server.handle('GET', '/packages/versions/new.json', (request, response) {
16 return server.url.transform((url) { 16 return server.url.chain((url) {
17 expect(request.headers.value('authorization'), 17 expect(request.headers.value('authorization'),
18 equals('Bearer access token')); 18 equals('Bearer access token'));
19 19
20 if (body == null) { 20 if (body == null) {
21 body = { 21 body = {
22 'url': url.resolve('/upload').toString(), 22 'url': url.resolve('/upload').toString(),
23 'fields': { 23 'fields': {
24 'field1': 'value1', 24 'field1': 'value1',
25 'field2': 'value2' 25 'field2': 'value2'
26 } 26 }
27 }; 27 };
28 } 28 }
29 29
30 response.headers.contentType = new ContentType("application", "json"); 30 response.headers.contentType = new ContentType("application", "json");
31 response.outputStream.writeString(JSON.stringify(body)); 31 response.outputStream.writeString(JSON.stringify(body));
32 response.outputStream.close(); 32 return closeHttpResponse(request, response);
33 }); 33 });
34 }); 34 });
35 } 35 }
36 36
37 void handleUpload(ScheduledServer server) { 37 void handleUpload(ScheduledServer server) {
38 server.handle('POST', '/upload', (request, response) { 38 server.handle('POST', '/upload', (request, response) {
39 // TODO(nweiz): Once a multipart/form-data parser in Dart exists, validate 39 // TODO(nweiz): Once a multipart/form-data parser in Dart exists, validate
40 // that the request body is correctly formatted. See issue 6952. 40 // that the request body is correctly formatted. See issue 6952.
41 return server.url.transform((url) { 41 return server.url.chain((url) {
42 response.statusCode = 302; 42 response.statusCode = 302;
43 response.headers.set('location', url.resolve('/create').toString()); 43 response.headers.set('location', url.resolve('/create').toString());
44 response.outputStream.close(); 44 return closeHttpResponse(request, response);
45 }); 45 });
46 }); 46 });
47 } 47 }
48 48
49 main() { 49 main() {
50 setUp(() => dir(appPath, [libPubspec("test_pkg", "1.0.0")]).scheduleCreate()); 50 setUp(() => dir(appPath, [libPubspec("test_pkg", "1.0.0")]).scheduleCreate());
51 51
52 test('archives and uploads a package', () { 52 test('archives and uploads a package', () {
53 var server = new ScheduledServer(); 53 var server = new ScheduledServer();
54 credentialsFile(server, 'access token').scheduleCreate(); 54 credentialsFile(server, 'access token').scheduleCreate();
55 var pub = startPubLish(server); 55 var pub = startPubLish(server);
56 handleUploadForm(server); 56 handleUploadForm(server);
57 handleUpload(server); 57 handleUpload(server);
58 58
59 server.handle('GET', '/create', (request, response) { 59 server.handle('GET', '/create', (request, response) {
60 response.outputStream.writeString(JSON.stringify({ 60 response.outputStream.writeString(JSON.stringify({
61 'success': {'message': 'Package test_pkg 1.0.0 uploaded!'} 61 'success': {'message': 'Package test_pkg 1.0.0 uploaded!'}
62 })); 62 }));
63 response.outputStream.close(); 63 return closeHttpResponse(request, response);
64 }); 64 });
65 65
66 expectLater(pub.nextLine(), equals('Package test_pkg 1.0.0 uploaded!')); 66 expectLater(pub.nextLine(), equals('Package test_pkg 1.0.0 uploaded!'));
67 pub.shouldExit(0); 67 pub.shouldExit(0);
68 68
69 run(); 69 run();
70 }); 70 });
71 71
72 // TODO(nweiz): Once a multipart/form-data parser in Dart exists, we should 72 // TODO(nweiz): Once a multipart/form-data parser in Dart exists, we should
73 // test that "pub lish" chooses the correct files to publish. 73 // test that "pub lish" chooses the correct files to publish.
74 74
75 // TODO(nweiz): Once issue 6813 is fixed, test that OAuth2 authentication 75 // TODO(nweiz): Once issue 6813 is fixed, test that OAuth2 authentication
76 // errors cause the client to try re-authenticating. 76 // errors cause the client to try re-authenticating.
77 77
78 test('upload form provides an error', () { 78 test('upload form provides an error', () {
79 var server = new ScheduledServer(); 79 var server = new ScheduledServer();
80 credentialsFile(server, 'access token').scheduleCreate(); 80 credentialsFile(server, 'access token').scheduleCreate();
81 var pub = startPubLish(server); 81 var pub = startPubLish(server);
82 82
83 server.handle('GET', '/packages/versions/new.json', (request, response) { 83 server.handle('GET', '/packages/versions/new.json', (request, response) {
84 response.statusCode = 400; 84 response.statusCode = 400;
85 response.outputStream.writeString(JSON.stringify({ 85 response.outputStream.writeString(JSON.stringify({
86 'error': {'message': 'your request sucked'} 86 'error': {'message': 'your request sucked'}
87 })); 87 }));
88 response.outputStream.close(); 88 return closeHttpResponse(request, response);
89 }); 89 });
90 90
91 expectLater(pub.nextErrLine(), equals('your request sucked')); 91 expectLater(pub.nextErrLine(), equals('your request sucked'));
92 pub.shouldExit(1); 92 pub.shouldExit(1);
93 93
94 run(); 94 run();
95 }); 95 });
96 96
97 test('upload form provides invalid JSON', () { 97 test('upload form provides invalid JSON', () {
98 var server = new ScheduledServer(); 98 var server = new ScheduledServer();
99 credentialsFile(server, 'access token').scheduleCreate(); 99 credentialsFile(server, 'access token').scheduleCreate();
100 var pub = startPubLish(server); 100 var pub = startPubLish(server);
101 101
102 server.handle('GET', '/packages/versions/new.json', (request, response) { 102 server.handle('GET', '/packages/versions/new.json', (request, response) {
103 response.outputStream.writeString('{not json'); 103 response.outputStream.writeString('{not json');
104 response.outputStream.close(); 104 return closeHttpResponse(request, response);
105 }); 105 });
106 106
107 expectLater(pub.nextErrLine(), equals('Invalid server response:')); 107 expectLater(pub.nextErrLine(), equals('Invalid server response:'));
108 expectLater(pub.nextErrLine(), equals('{not json')); 108 expectLater(pub.nextErrLine(), equals('{not json'));
109 pub.shouldExit(1); 109 pub.shouldExit(1);
110 110
111 run(); 111 run();
112 }); 112 });
113 113
114 test('upload form is missing url', () { 114 test('upload form is missing url', () {
(...skipping 86 matching lines...) Expand 10 before | Expand all | Expand 10 after
201 var server = new ScheduledServer(); 201 var server = new ScheduledServer();
202 credentialsFile(server, 'access token').scheduleCreate(); 202 credentialsFile(server, 'access token').scheduleCreate();
203 var pub = startPubLish(server); 203 var pub = startPubLish(server);
204 handleUploadForm(server); 204 handleUploadForm(server);
205 205
206 server.handle('POST', '/upload', (request, response) { 206 server.handle('POST', '/upload', (request, response) {
207 response.statusCode = 400; 207 response.statusCode = 400;
208 response.headers.contentType = new ContentType('application', 'xml'); 208 response.headers.contentType = new ContentType('application', 'xml');
209 response.outputStream.writeString('<Error><Message>Your request sucked.' 209 response.outputStream.writeString('<Error><Message>Your request sucked.'
210 '</Message></Error>'); 210 '</Message></Error>');
211 response.outputStream.close(); 211 return closeHttpResponse(request, response);
212 }); 212 });
213 213
214 // TODO(nweiz): This should use the server's error message once the client 214 // TODO(nweiz): This should use the server's error message once the client
215 // can parse the XML. 215 // can parse the XML.
216 expectLater(pub.nextErrLine(), equals('Failed to upload the package.')); 216 expectLater(pub.nextErrLine(), equals('Failed to upload the package.'));
217 pub.shouldExit(1); 217 pub.shouldExit(1);
218 218
219 run(); 219 run();
220 }); 220 });
221 221
222 test("cloud storage upload doesn't redirect", () { 222 test("cloud storage upload doesn't redirect", () {
223 var server = new ScheduledServer(); 223 var server = new ScheduledServer();
224 credentialsFile(server, 'access token').scheduleCreate(); 224 credentialsFile(server, 'access token').scheduleCreate();
225 var pub = startPubLish(server); 225 var pub = startPubLish(server);
226 handleUploadForm(server); 226 handleUploadForm(server);
227 227
228 server.handle('POST', '/upload', (request, response) { 228 server.handle('POST', '/upload', (request, response) {
229 // don't set the location header 229 // don't set the location header
230 response.outputStream.close(); 230 return closeHttpResponse(request, response);
231 }); 231 });
232 232
233 expectLater(pub.nextErrLine(), equals('Failed to upload the package.')); 233 expectLater(pub.nextErrLine(), equals('Failed to upload the package.'));
234 pub.shouldExit(1); 234 pub.shouldExit(1);
235 235
236 run(); 236 run();
237 }); 237 });
238 238
239 test('package creation provides an error', () { 239 test('package creation provides an error', () {
240 var server = new ScheduledServer(); 240 var server = new ScheduledServer();
241 credentialsFile(server, 'access token').scheduleCreate(); 241 credentialsFile(server, 'access token').scheduleCreate();
242 var pub = startPubLish(server); 242 var pub = startPubLish(server);
243 handleUploadForm(server); 243 handleUploadForm(server);
244 handleUpload(server); 244 handleUpload(server);
245 245
246 server.handle('GET', '/create', (request, response) { 246 server.handle('GET', '/create', (request, response) {
247 response.outputStream.writeString(JSON.stringify({ 247 response.outputStream.writeString(JSON.stringify({
248 'error': {'message': 'Your package was too boring.'} 248 'error': {'message': 'Your package was too boring.'}
249 })); 249 }));
250 response.outputStream.close(); 250 return closeHttpResponse(request, response);
251 }); 251 });
252 252
253 expectLater(pub.nextErrLine(), equals('Your package was too boring.')); 253 expectLater(pub.nextErrLine(), equals('Your package was too boring.'));
254 pub.shouldExit(1); 254 pub.shouldExit(1);
255 255
256 run(); 256 run();
257 }); 257 });
258 258
259 test('package creation provides invalid JSON', () { 259 test('package creation provides invalid JSON', () {
260 var server = new ScheduledServer(); 260 var server = new ScheduledServer();
261 credentialsFile(server, 'access token').scheduleCreate(); 261 credentialsFile(server, 'access token').scheduleCreate();
262 var pub = startPubLish(server); 262 var pub = startPubLish(server);
263 handleUploadForm(server); 263 handleUploadForm(server);
264 handleUpload(server); 264 handleUpload(server);
265 265
266 server.handle('GET', '/create', (request, response) { 266 server.handle('GET', '/create', (request, response) {
267 response.outputStream.writeString('{not json'); 267 response.outputStream.writeString('{not json');
268 response.outputStream.close(); 268 return closeHttpResponse(request, response);
269 }); 269 });
270 270
271 expectLater(pub.nextErrLine(), equals('Invalid server response:')); 271 expectLater(pub.nextErrLine(), equals('Invalid server response:'));
272 expectLater(pub.nextErrLine(), equals('{not json')); 272 expectLater(pub.nextErrLine(), equals('{not json'));
273 pub.shouldExit(1); 273 pub.shouldExit(1);
274 274
275 run(); 275 run();
276 }); 276 });
277 277
278 test('package creation provides a malformed error', () { 278 test('package creation provides a malformed error', () {
279 var server = new ScheduledServer(); 279 var server = new ScheduledServer();
280 credentialsFile(server, 'access token').scheduleCreate(); 280 credentialsFile(server, 'access token').scheduleCreate();
281 var pub = startPubLish(server); 281 var pub = startPubLish(server);
282 handleUploadForm(server); 282 handleUploadForm(server);
283 handleUpload(server); 283 handleUpload(server);
284 284
285 var body = {'error': 'Your package was too boring.'}; 285 var body = {'error': 'Your package was too boring.'};
286 server.handle('GET', '/create', (request, response) { 286 server.handle('GET', '/create', (request, response) {
287 response.statusCode = 400; 287 response.statusCode = 400;
288 response.outputStream.writeString(JSON.stringify(body)); 288 response.outputStream.writeString(JSON.stringify(body));
289 response.outputStream.close(); 289 return closeHttpResponse(request, response);
290 }); 290 });
291 291
292 expectLater(pub.nextErrLine(), equals('Invalid server response:')); 292 expectLater(pub.nextErrLine(), equals('Invalid server response:'));
293 expectLater(pub.nextErrLine(), equals(JSON.stringify(body))); 293 expectLater(pub.nextErrLine(), equals(JSON.stringify(body)));
294 pub.shouldExit(1); 294 pub.shouldExit(1);
295 295
296 run(); 296 run();
297 }); 297 });
298 298
299 test('package creation provides a malformed success', () { 299 test('package creation provides a malformed success', () {
300 var server = new ScheduledServer(); 300 var server = new ScheduledServer();
301 credentialsFile(server, 'access token').scheduleCreate(); 301 credentialsFile(server, 'access token').scheduleCreate();
302 var pub = startPubLish(server); 302 var pub = startPubLish(server);
303 handleUploadForm(server); 303 handleUploadForm(server);
304 handleUpload(server); 304 handleUpload(server);
305 305
306 var body = {'success': 'Your package was awesome.'}; 306 var body = {'success': 'Your package was awesome.'};
307 server.handle('GET', '/create', (request, response) { 307 server.handle('GET', '/create', (request, response) {
308 response.outputStream.writeString(JSON.stringify(body)); 308 response.outputStream.writeString(JSON.stringify(body));
309 response.outputStream.close(); 309 return closeHttpResponse(request, response);
310 }); 310 });
311 311
312 expectLater(pub.nextErrLine(), equals('Invalid server response:')); 312 expectLater(pub.nextErrLine(), equals('Invalid server response:'));
313 expectLater(pub.nextErrLine(), equals(JSON.stringify(body))); 313 expectLater(pub.nextErrLine(), equals(JSON.stringify(body)));
314 pub.shouldExit(1); 314 pub.shouldExit(1);
315 315
316 run(); 316 run();
317 }); 317 });
318 } 318 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698