Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 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 | |
| 3 // BSD-style license that can be found in the LICENSE file. | |
| 4 | |
| 5 library pub_uploader_test; | |
| 6 | |
| 7 import 'dart:io'; | |
| 8 import 'dart:json'; | |
| 9 | |
| 10 import 'test_pub.dart'; | |
| 11 import '../../../pkg/unittest/lib/unittest.dart'; | |
| 12 import '../../pub/utils.dart'; | |
| 13 | |
| 14 final USAGE_STRING = ''' | |
| 15 Manage uploaders for a package on pub.dartlang.org. | |
| 16 | |
| 17 Usage: pub uploader [options] {add/remove} email | |
| 18 --server The package server to which to upload this package | |
| 19 (defaults to "https://pub.dartlang.org") | |
| 20 | |
| 21 --package The package whose uploaders will be modified | |
| 22 (defaults to the current package) | |
| 23 '''; | |
| 24 | |
| 25 ScheduledProcess startPubUploader(ScheduledServer server, List<String> args) { | |
| 26 var tokenEndpoint = server.url.transform((url) => | |
| 27 url.resolve('/token').toString()); | |
| 28 args = flatten(['uploader', '--server', tokenEndpoint, args]); | |
| 29 return startPub(args: args, tokenEndpoint: tokenEndpoint); | |
| 30 } | |
| 31 | |
| 32 main() { | |
| 33 group('displays usage', () { | |
| 34 test('when run with no arguments', () => | |
| 35 runPub(args: ['uploader'], output: USAGE_STRING, exitCode: 64)); | |
| 36 | |
| 37 test('when run with only a command', () => | |
| 38 runPub(args: ['uploader', 'add'], output: USAGE_STRING, exitCode: 64)); | |
|
Bob Nystrom
2012/12/17 18:41:58
It would be good to show a specific error message
nweiz
2012/12/17 21:18:48
We do, it's just on stderr. I didn't think it was
| |
| 39 | |
| 40 test('when run with an invalid command', () => runPub( | |
|
Bob Nystrom
2012/12/17 18:41:58
Ditto. 'Unknown uploader command "foo". Expected "
nweiz
2012/12/17 21:18:48
See above.
| |
| 41 args: ['uploader', 'foo', 'email'], | |
| 42 output: USAGE_STRING, exitCode: 64)); | |
| 43 }); | |
| 44 | |
| 45 test('creates an uploader', () { | |
|
Bob Nystrom
2012/12/17 18:41:58
"creates" -> "adds"
Here and elsewhere.
nweiz
2012/12/17 21:18:48
Done.
| |
| 46 var server = new ScheduledServer(); | |
| 47 credentialsFile(server, 'access token').scheduleCreate(); | |
| 48 var pub = startPubUploader(server, ['--package', 'pkg', 'add', 'email']); | |
| 49 | |
| 50 server.handle('POST', '/packages/pkg/uploaders.json', (request, response) { | |
|
Bob Nystrom
2012/12/17 18:41:58
Validate that the request includes the email?
nweiz
2012/12/17 21:18:48
Done.
| |
| 51 response.headers.contentType = new ContentType("application", "json"); | |
| 52 response.outputStream.writeString(JSON.stringify({ | |
| 53 'success': {'message': 'Good job!'} | |
| 54 })); | |
| 55 response.outputStream.close(); | |
| 56 }); | |
| 57 | |
|
Bob Nystrom
2012/12/17 18:41:58
Should we validate that pub prints out "Good job!"
nweiz
2012/12/17 21:18:48
Yeah, that seems reasonable. Done.
| |
| 58 pub.shouldExit(0); | |
| 59 | |
| 60 run(); | |
| 61 }); | |
| 62 | |
| 63 test('deletes an uploader', () { | |
|
Bob Nystrom
2012/12/17 18:41:58
"deletes" -> "removes"
Here and elsewhere.
nweiz
2012/12/17 21:18:48
Done.
| |
| 64 var server = new ScheduledServer(); | |
| 65 credentialsFile(server, 'access token').scheduleCreate(); | |
| 66 var pub = startPubUploader(server, ['--package', 'pkg', 'remove', 'email']); | |
| 67 | |
| 68 server.handle('DELETE', '/packages/pkg/uploaders/email.json', | |
| 69 (request, response) { | |
|
Bob Nystrom
2012/12/17 18:41:58
Validate that the request includes the email?
nweiz
2012/12/17 21:18:48
In this case it's embedded in the URL.
Bob Nystrom
2012/12/17 21:26:59
Oh, sorry didn't notice. Does it URL-encode the em
| |
| 70 response.headers.contentType = new ContentType("application", "json"); | |
| 71 response.outputStream.writeString(JSON.stringify({ | |
| 72 'success': {'message': 'Good job!'} | |
| 73 })); | |
| 74 response.outputStream.close(); | |
| 75 }); | |
| 76 | |
| 77 pub.shouldExit(0); | |
| 78 | |
| 79 run(); | |
| 80 }); | |
| 81 | |
| 82 test('defaults to the current package', () { | |
| 83 normalPackage.scheduleCreate(); | |
| 84 | |
| 85 var server = new ScheduledServer(); | |
| 86 credentialsFile(server, 'access token').scheduleCreate(); | |
| 87 var pub = startPubUploader(server, ['add', 'email']); | |
| 88 | |
| 89 server.handle('POST', '/packages/test_pkg/uploaders.json', | |
| 90 (request, response) { | |
| 91 response.headers.contentType = new ContentType("application", "json"); | |
| 92 response.outputStream.writeString(JSON.stringify({ | |
| 93 'success': {'message': 'Good job!'} | |
| 94 })); | |
| 95 response.outputStream.close(); | |
| 96 }); | |
| 97 | |
| 98 pub.shouldExit(0); | |
| 99 | |
| 100 run(); | |
| 101 }); | |
| 102 | |
| 103 test('credentials are invalid', () { | |
| 104 var server = new ScheduledServer(); | |
| 105 credentialsFile(server, 'access token').scheduleCreate(); | |
| 106 var pub = startPubUploader(server, ['--package', 'pkg', 'add', 'email']); | |
| 107 | |
| 108 server.handle('POST', '/packages/pkg/uploaders.json', (request, response) { | |
| 109 response.statusCode = 401; | |
| 110 response.headers.set('www-authenticate', 'Bearer error="invalid_token",' | |
| 111 ' error_description="your token sucks"'); | |
| 112 response.outputStream.writeString(JSON.stringify({ | |
| 113 'error': {'message': 'your token sucks'} | |
| 114 })); | |
|
Bob Nystrom
2012/12/17 18:41:58
We do this pretty frequently. Break out into a sep
nweiz
2012/12/17 21:18:48
I think we only do it twice. And actually, this te
| |
| 115 response.outputStream.close(); | |
| 116 }); | |
| 117 | |
| 118 expectLater(pub.nextErrLine(), equals('OAuth2 authorization failed (your ' | |
| 119 'token sucks).')); | |
| 120 expectLater(pub.nextLine(), equals( | |
| 121 'Pub needs your authorization to upload packages on your behalf.')); | |
| 122 pub.kill(); | |
| 123 run(); | |
| 124 }); | |
| 125 | |
| 126 test('create provides an error', () { | |
| 127 var server = new ScheduledServer(); | |
| 128 credentialsFile(server, 'access token').scheduleCreate(); | |
| 129 var pub = startPubUploader(server, ['--package', 'pkg', 'add', 'email']); | |
| 130 | |
| 131 server.handle('POST', '/packages/pkg/uploaders.json', (request, response) { | |
| 132 response.statusCode = 400; | |
| 133 response.headers.contentType = new ContentType("application", "json"); | |
| 134 response.outputStream.writeString(JSON.stringify({ | |
| 135 'error': {'message': 'Bad job!'} | |
| 136 })); | |
| 137 response.outputStream.close(); | |
| 138 }); | |
| 139 | |
| 140 expectLater(pub.nextErrLine(), equals('Bad job!')); | |
| 141 pub.shouldExit(1); | |
| 142 | |
| 143 run(); | |
| 144 }); | |
| 145 | |
| 146 test('delete provides an error', () { | |
| 147 var server = new ScheduledServer(); | |
| 148 credentialsFile(server, 'access token').scheduleCreate(); | |
| 149 var pub = startPubUploader(server, ['--package', 'pkg', 'remove', 'email']); | |
| 150 | |
| 151 server.handle('DELETE', '/packages/pkg/uploaders/email.json', | |
| 152 (request, response) { | |
| 153 response.statusCode = 400; | |
| 154 response.headers.contentType = new ContentType("application", "json"); | |
| 155 response.outputStream.writeString(JSON.stringify({ | |
| 156 'error': {'message': 'Bad job!'} | |
| 157 })); | |
| 158 response.outputStream.close(); | |
| 159 }); | |
| 160 | |
| 161 expectLater(pub.nextErrLine(), equals('Bad job!')); | |
| 162 pub.shouldExit(1); | |
| 163 | |
| 164 run(); | |
| 165 }); | |
| 166 | |
| 167 test('create provides invalid JSON', () { | |
| 168 var server = new ScheduledServer(); | |
| 169 credentialsFile(server, 'access token').scheduleCreate(); | |
| 170 var pub = startPubUploader(server, ['--package', 'pkg', 'add', 'email']); | |
| 171 | |
| 172 server.handle('POST', '/packages/pkg/uploaders.json', (request, response) { | |
| 173 response.outputStream.writeString("{not json"); | |
| 174 response.outputStream.close(); | |
| 175 }); | |
| 176 | |
| 177 expectLater(pub.nextErrLine(), equals('Invalid server response:')); | |
| 178 expectLater(pub.nextErrLine(), equals('{not json')); | |
| 179 pub.shouldExit(1); | |
| 180 | |
| 181 run(); | |
| 182 }); | |
| 183 | |
| 184 test('delete provides invalid JSON', () { | |
| 185 var server = new ScheduledServer(); | |
| 186 credentialsFile(server, 'access token').scheduleCreate(); | |
| 187 var pub = startPubUploader(server, ['--package', 'pkg', 'remove', 'email']); | |
| 188 | |
| 189 server.handle('DELETE', '/packages/pkg/uploaders/email.json', | |
| 190 (request, response) { | |
| 191 response.outputStream.writeString("{not json"); | |
| 192 response.outputStream.close(); | |
| 193 }); | |
| 194 | |
| 195 expectLater(pub.nextErrLine(), equals('Invalid server response:')); | |
| 196 expectLater(pub.nextErrLine(), equals('{not json')); | |
| 197 pub.shouldExit(1); | |
| 198 | |
| 199 run(); | |
| 200 }); | |
| 201 } | |
| OLD | NEW |