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

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

Issue 11569046: Add a pub command for managing uploaders for packages. (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
(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 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698