Index: sdk/lib/_internal/pub_generated/test/pub_uploader_test.dart |
diff --git a/sdk/lib/_internal/pub_generated/test/pub_uploader_test.dart b/sdk/lib/_internal/pub_generated/test/pub_uploader_test.dart |
index db294c0a9d02771e7cf9fe5ceef6f83ab762b19e..19ff839f89d0d9eab558f030cea927f2ab276d4f 100644 |
--- a/sdk/lib/_internal/pub_generated/test/pub_uploader_test.dart |
+++ b/sdk/lib/_internal/pub_generated/test/pub_uploader_test.dart |
@@ -1,13 +1,21 @@ |
+// Copyright (c) 2013, 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. |
+ |
library pub_uploader_test; |
+ |
import 'dart:convert'; |
+ |
import 'package:scheduled_test/scheduled_process.dart'; |
import 'package:scheduled_test/scheduled_server.dart'; |
import 'package:scheduled_test/scheduled_test.dart'; |
import 'package:shelf/shelf.dart' as shelf; |
+ |
import '../lib/src/exit_codes.dart' as exit_codes; |
import '../lib/src/utils.dart'; |
import 'descriptor.dart' as d; |
import 'test_pub.dart'; |
+ |
final USAGE_STRING = ''' |
Manage uploaders for a package on pub.dartlang.org. |
@@ -22,12 +30,14 @@ Usage: pub uploader [options] {add/remove} <email> |
Run "pub help" to see global options. |
See http://dartlang.org/tools/pub/cmd/pub-uploader.html for detailed documentation. |
'''; |
+ |
ScheduledProcess startPubUploader(ScheduledServer server, List<String> args) { |
var tokenEndpoint = |
server.url.then((url) => url.resolve('/token').toString()); |
args = flatten(['uploader', '--server', tokenEndpoint, args]); |
return startPub(args: args, tokenEndpoint: tokenEndpoint); |
} |
+ |
main() { |
initConfig(); |
group('displays usage', () { |
@@ -37,12 +47,14 @@ main() { |
output: USAGE_STRING, |
exitCode: exit_codes.USAGE); |
}); |
+ |
integration('when run with only a command', () { |
schedulePub( |
args: ['uploader', 'add'], |
output: USAGE_STRING, |
exitCode: exit_codes.USAGE); |
}); |
+ |
integration('when run with an invalid command', () { |
schedulePub( |
args: ['uploader', 'foo', 'email'], |
@@ -50,13 +62,16 @@ main() { |
exitCode: exit_codes.USAGE); |
}); |
}); |
+ |
integration('adds an uploader', () { |
var server = new ScheduledServer(); |
d.credentialsFile(server, 'access token').create(); |
var pub = startPubUploader(server, ['--package', 'pkg', 'add', 'email']); |
+ |
server.handle('POST', '/api/packages/pkg/uploaders', (request) { |
return request.readAsString().then((body) { |
expect(body, equals('email=email')); |
+ |
return new shelf.Response.ok(JSON.encode({ |
'success': { |
'message': 'Good job!' |
@@ -66,13 +81,16 @@ main() { |
}); |
}); |
}); |
+ |
pub.stdout.expect('Good job!'); |
pub.shouldExit(exit_codes.SUCCESS); |
}); |
+ |
integration('removes an uploader', () { |
var server = new ScheduledServer(); |
d.credentialsFile(server, 'access token').create(); |
var pub = startPubUploader(server, ['--package', 'pkg', 'remove', 'email']); |
+ |
server.handle('DELETE', '/api/packages/pkg/uploaders/email', (request) { |
return new shelf.Response.ok(JSON.encode({ |
'success': { |
@@ -82,14 +100,18 @@ main() { |
'content-type': 'application/json' |
}); |
}); |
+ |
pub.stdout.expect('Good job!'); |
pub.shouldExit(exit_codes.SUCCESS); |
}); |
+ |
integration('defaults to the current package', () { |
d.validPackage.create(); |
+ |
var server = new ScheduledServer(); |
d.credentialsFile(server, 'access token').create(); |
var pub = startPubUploader(server, ['add', 'email']); |
+ |
server.handle('POST', '/api/packages/test_pkg/uploaders', (request) { |
return new shelf.Response.ok(JSON.encode({ |
'success': { |
@@ -99,13 +121,16 @@ main() { |
'content-type': 'application/json' |
}); |
}); |
+ |
pub.stdout.expect('Good job!'); |
pub.shouldExit(exit_codes.SUCCESS); |
}); |
+ |
integration('add provides an error', () { |
var server = new ScheduledServer(); |
d.credentialsFile(server, 'access token').create(); |
var pub = startPubUploader(server, ['--package', 'pkg', 'add', 'email']); |
+ |
server.handle('POST', '/api/packages/pkg/uploaders', (request) { |
return new shelf.Response(400, body: JSON.encode({ |
'error': { |
@@ -115,14 +140,17 @@ main() { |
'content-type': 'application/json' |
}); |
}); |
+ |
pub.stderr.expect('Bad job!'); |
pub.shouldExit(1); |
}); |
+ |
integration('remove provides an error', () { |
var server = new ScheduledServer(); |
d.credentialsFile(server, 'access token').create(); |
var pub = |
startPubUploader(server, ['--package', 'pkg', 'remove', 'e/mail']); |
+ |
server.handle('DELETE', '/api/packages/pkg/uploaders/e%2Fmail', (request) { |
return new shelf.Response(400, body: JSON.encode({ |
'error': { |
@@ -132,28 +160,35 @@ main() { |
'content-type': 'application/json' |
}); |
}); |
+ |
pub.stderr.expect('Bad job!'); |
pub.shouldExit(1); |
}); |
+ |
integration('add provides invalid JSON', () { |
var server = new ScheduledServer(); |
d.credentialsFile(server, 'access token').create(); |
var pub = startPubUploader(server, ['--package', 'pkg', 'add', 'email']); |
+ |
server.handle( |
'POST', |
'/api/packages/pkg/uploaders', |
(request) => new shelf.Response.ok("{not json")); |
+ |
pub.stderr.expect(emitsLines('Invalid server response:\n' '{not json')); |
pub.shouldExit(1); |
}); |
+ |
integration('remove provides invalid JSON', () { |
var server = new ScheduledServer(); |
d.credentialsFile(server, 'access token').create(); |
var pub = startPubUploader(server, ['--package', 'pkg', 'remove', 'email']); |
+ |
server.handle( |
'DELETE', |
'/api/packages/pkg/uploaders/email', |
(request) => new shelf.Response.ok("{not json")); |
+ |
pub.stderr.expect(emitsLines('Invalid server response:\n' '{not json')); |
pub.shouldExit(1); |
}); |