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.http.test;
45  
46  import static org.junit.Assert.assertTrue;
47  import static org.junit.Assert.fail;
48  
49  import java.util.List;
50  
51  import javax.servlet.ServletException;
52  
53  import org.eclipse.jetty.servlet.ServletContextHandler;
54  import org.eclipse.jetty.servlet.ServletHolder;
55  import org.eclipse.jetty.util.MultiException;
56  import org.eclipse.jgit.http.server.GitServlet;
57  import org.eclipse.jgit.junit.http.AppServer;
58  import org.eclipse.jgit.junit.http.MockServletConfig;
59  import org.eclipse.jgit.junit.http.RecordingLogger;
60  import org.junit.After;
61  import org.junit.Test;
62  
63  public class GitServletInitTest {
64  	private AppServer server;
65  
66  	@After
67  	public void tearDown() throws Exception {
68  		if (server != null) {
69  			server.tearDown();
70  			server = null;
71  		}
72  	}
73  
74  	@Test
75  	public void testDefaultConstructor_NoBasePath() throws Exception {
76  		GitServlet s = new GitServlet();
77  		try {
78  			s.init(new MockServletConfig());
79  			fail("Init did not crash due to missing parameter");
80  		} catch (ServletException e) {
81  			assertTrue(e.getMessage().contains("base-path"));
82  		}
83  	}
84  
85  	@Test
86  	public void testDefaultConstructor_WithBasePath() throws Exception {
87  		MockServletConfig c = new MockServletConfig();
88  		c.setInitParameter("base-path", ".");
89  		c.setInitParameter("export-all", "false");
90  
91  		GitServlet s = new GitServlet();
92  		s.init(c);
93  		s.destroy();
94  	}
95  
96  	@Test
97  	public void testInitUnderContainer_NoBasePath() throws Exception {
98  		server = new AppServer();
99  
100 		ServletContextHandler app = server.addContext("/");
101 		ServletHolder s = app.addServlet(GitServlet.class, "/git");
102 		s.setInitOrder(1);
103 		s.getServletHandler().setStartWithUnavailable(false);
104 		
105 		s.setInitParameter("aliases", "true");
106 
107 		try {
108 			server.setUp();
109 		} catch (Exception e) {
110 			Throwable why = null;
111 			if (e instanceof MultiException) {
112 				MultiException multi = (MultiException) e;
113 				List<Throwable> reasons = multi.getThrowables();
114 				why = reasons.get(0);
115 				assertTrue("Expected ServletException",
116 						why instanceof ServletException);
117 			} else if (e instanceof ServletException)
118 				why = e;
119 
120 			if (why != null) {
121 				assertTrue("Wanted base-path",
122 						why.getMessage().contains("base-path"));
123 				return;
124 			}
125 		}
126 		fail("Expected ServletException complaining about unset base-path");
127 	}
128 
129 	@Test
130 	public void testInitUnderContainer_WithBasePath() throws Exception {
131 		server = new AppServer();
132 
133 		ServletContextHandler app = server.addContext("/");
134 		ServletHolder s = app.addServlet(GitServlet.class, "/git");
135 		s.setInitOrder(1);
136 		s.setInitParameter("base-path", ".");
137 		s.setInitParameter("export-all", "true");
138 		
139 		s.setInitParameter("aliases", "true");
140 
141 		server.setUp();
142 		assertTrue("no warnings", RecordingLogger.getWarnings().isEmpty());
143 	}
144 }