1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44 package org.eclipse.jgit.junit.http;
45
46 import static org.junit.Assert.assertFalse;
47 import static org.junit.Assert.assertTrue;
48
49 import java.io.IOException;
50 import java.net.InetAddress;
51 import java.net.URI;
52 import java.net.URISyntaxException;
53 import java.net.UnknownHostException;
54 import java.util.ArrayList;
55 import java.util.List;
56
57 import org.eclipse.jetty.security.Authenticator;
58 import org.eclipse.jetty.security.ConstraintMapping;
59 import org.eclipse.jetty.security.ConstraintSecurityHandler;
60 import org.eclipse.jetty.security.MappedLoginService;
61 import org.eclipse.jetty.security.authentication.BasicAuthenticator;
62 import org.eclipse.jetty.server.Connector;
63 import org.eclipse.jetty.server.HttpConfiguration;
64 import org.eclipse.jetty.server.HttpConnectionFactory;
65 import org.eclipse.jetty.server.Server;
66 import org.eclipse.jetty.server.ServerConnector;
67 import org.eclipse.jetty.server.UserIdentity;
68 import org.eclipse.jetty.server.handler.ContextHandlerCollection;
69 import org.eclipse.jetty.servlet.ServletContextHandler;
70 import org.eclipse.jetty.util.security.Constraint;
71 import org.eclipse.jetty.util.security.Password;
72 import org.eclipse.jgit.transport.URIish;
73
74
75
76
77
78
79
80
81 public class AppServer {
82
83 public static final String realm = "Secure Area";
84
85
86 public static final String username = "agitter";
87
88
89 public static final String password = "letmein";
90
91 static {
92
93
94 final String prop = "org.eclipse.jetty.util.log.class";
95 System.setProperty(prop, RecordingLogger.class.getName());
96 }
97
98 private final Server server;
99
100 private final ServerConnector connector;
101
102 private final ContextHandlerCollection contexts;
103
104 private final TestRequestLog log;
105
106 public AppServer() {
107 this(0);
108 }
109
110
111
112
113
114
115 public AppServer(int port) {
116 server = new Server();
117
118 HttpConfiguration http_config = new HttpConfiguration();
119 http_config.setSecureScheme("https");
120 http_config.setSecurePort(8443);
121 http_config.setOutputBufferSize(32768);
122
123 connector = new ServerConnector(server,
124 new HttpConnectionFactory(http_config));
125 connector.setPort(port);
126 try {
127 final InetAddress me = InetAddress.getByName("localhost");
128 connector.setHost(me.getHostAddress());
129 } catch (UnknownHostException e) {
130 throw new RuntimeException("Cannot find localhost", e);
131 }
132
133 contexts = new ContextHandlerCollection();
134
135 log = new TestRequestLog();
136 log.setHandler(contexts);
137
138 server.setConnectors(new Connector[] { connector });
139 server.setHandler(log);
140 }
141
142
143
144
145
146
147
148
149
150
151
152
153 public ServletContextHandler addContext(String path) {
154 assertNotYetSetUp();
155 if ("".equals(path))
156 path = "/";
157
158 ServletContextHandler ctx = new ServletContextHandler();
159 ctx.setContextPath(path);
160 contexts.addHandler(ctx);
161
162 return ctx;
163 }
164
165 public ServletContextHandler authBasic(ServletContextHandler ctx) {
166 assertNotYetSetUp();
167 auth(ctx, new BasicAuthenticator());
168 return ctx;
169 }
170
171 private void auth(ServletContextHandler ctx, Authenticator authType) {
172 final String role = "can-access";
173
174 MappedLoginService users = new MappedLoginService() {
175 @Override
176 protected UserIdentity loadUser(String who) {
177 return null;
178 }
179
180 @Override
181 protected void loadUsers() throws IOException {
182 putUser(username, new Password(password), new String[] { role });
183 }
184 };
185
186 ConstraintMapping cm = new ConstraintMapping();
187 cm.setConstraint(new Constraint());
188 cm.getConstraint().setAuthenticate(true);
189 cm.getConstraint().setDataConstraint(Constraint.DC_NONE);
190 cm.getConstraint().setRoles(new String[] { role });
191 cm.setPathSpec("/*");
192
193 ConstraintSecurityHandler sec = new ConstraintSecurityHandler();
194 sec.setRealmName(realm);
195 sec.setAuthenticator(authType);
196 sec.setLoginService(users);
197 sec.setConstraintMappings(new ConstraintMapping[] { cm });
198 sec.setHandler(ctx);
199
200 contexts.removeHandler(ctx);
201 contexts.addHandler(sec);
202 }
203
204
205
206
207
208
209
210 public void setUp() throws Exception {
211 RecordingLogger.clear();
212 log.clear();
213 server.start();
214 }
215
216
217
218
219
220
221
222 public void tearDown() throws Exception {
223 RecordingLogger.clear();
224 log.clear();
225 server.stop();
226 }
227
228
229
230
231
232
233
234
235
236 public URI getURI() {
237 assertAlreadySetUp();
238 String host = connector.getHost();
239 if (host.contains(":") && !host.startsWith("["))
240 host = "[" + host + "]";
241 final String uri = "http://" + host + ":" + getPort();
242 try {
243 return new URI(uri);
244 } catch (URISyntaxException e) {
245 throw new RuntimeException("Unexpected URI error on " + uri, e);
246 }
247 }
248
249
250 public int getPort() {
251 assertAlreadySetUp();
252 return connector.getLocalPort();
253 }
254
255
256 public List<AccessEvent> getRequests() {
257 return new ArrayList<AccessEvent>(log.getEvents());
258 }
259
260
261
262
263
264
265
266
267 public List<AccessEvent> getRequests(URIish base, String path) {
268 return getRequests(HttpTestCase.join(base, path));
269 }
270
271
272
273
274
275
276 public List<AccessEvent> getRequests(String path) {
277 ArrayList<AccessEvent> r = new ArrayList<AccessEvent>();
278 for (AccessEvent event : log.getEvents()) {
279 if (event.getPath().equals(path)) {
280 r.add(event);
281 }
282 }
283 return r;
284 }
285
286 private void assertNotYetSetUp() {
287 assertFalse("server is not running", server.isRunning());
288 }
289
290 private void assertAlreadySetUp() {
291 assertTrue("server is running", server.isRunning());
292 }
293 }