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 |