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 package org.eclipse.jgit.http.test;
44
45 import static org.junit.Assert.assertEquals;
46
47 import java.util.Collection;
48 import java.util.Collections;
49
50 import javax.servlet.http.HttpServletRequest;
51
52 import org.eclipse.jetty.servlet.ServletContextHandler;
53 import org.eclipse.jetty.servlet.ServletHolder;
54 import org.eclipse.jgit.errors.RepositoryNotFoundException;
55 import org.eclipse.jgit.http.server.GitServlet;
56 import org.eclipse.jgit.http.server.resolver.DefaultReceivePackFactory;
57 import org.eclipse.jgit.junit.TestRepository;
58 import org.eclipse.jgit.lib.Constants;
59 import org.eclipse.jgit.lib.NullProgressMonitor;
60 import org.eclipse.jgit.lib.ObjectId;
61 import org.eclipse.jgit.lib.Repository;
62 import org.eclipse.jgit.lib.StoredConfig;
63 import org.eclipse.jgit.revwalk.RevBlob;
64 import org.eclipse.jgit.revwalk.RevCommit;
65 import org.eclipse.jgit.transport.PushResult;
66 import org.eclipse.jgit.transport.ReceiveCommand;
67 import org.eclipse.jgit.transport.ReceivePack;
68 import org.eclipse.jgit.transport.RemoteRefUpdate;
69 import org.eclipse.jgit.transport.Transport;
70 import org.eclipse.jgit.transport.URIish;
71 import org.eclipse.jgit.transport.http.HttpConnectionFactory;
72 import org.eclipse.jgit.transport.resolver.ServiceNotAuthorizedException;
73 import org.eclipse.jgit.transport.resolver.ServiceNotEnabledException;
74 import org.junit.Before;
75 import org.junit.Test;
76
77 public class MeasurePackSizeTest extends AllFactoriesHttpTestCase {
78
79 private Repository remoteRepository;
80
81 private URIish remoteURI;
82
83 long packSize = -1;
84
85 public MeasurePackSizeTest(HttpConnectionFactory cf) {
86 super(cf);
87 }
88
89 @Override
90 @Before
91 public void setUp() throws Exception {
92 super.setUp();
93
94 final TestRepository<Repository> src = createTestRepository();
95 final String srcName = src.getRepository().getDirectory().getName();
96
97 ServletContextHandler app = server.addContext("/git");
98 GitServlet gs = new GitServlet();
99 gs.setRepositoryResolver((HttpServletRequest req, String name) -> {
100 if (!name.equals(srcName)) {
101 throw new RepositoryNotFoundException(name);
102 }
103 final Repository db = src.getRepository();
104 db.incrementOpen();
105 return db;
106 });
107 gs.setReceivePackFactory(new DefaultReceivePackFactory() {
108 @Override
109 public ReceivePack create(HttpServletRequest req, Repository db)
110 throws ServiceNotEnabledException,
111 ServiceNotAuthorizedException {
112 ReceivePack recv = super.create(req, db);
113 recv.setPostReceiveHook((ReceivePack rp,
114 Collection<ReceiveCommand> commands) -> {
115 packSize = rp.getPackSize();
116 });
117 return recv;
118 }
119
120 });
121 app.addServlet(new ServletHolder(gs), "/*");
122
123 server.setUp();
124
125 remoteRepository = src.getRepository();
126 remoteURI = toURIish(app, srcName);
127
128 StoredConfig cfg = remoteRepository.getConfig();
129 cfg.setBoolean("http", null, "receivepack", true);
130 cfg.save();
131 }
132
133 @Test
134 public void testPush_packSize() throws Exception {
135 final TestRepository src = createTestRepository();
136 final RevBlob Q_txt = src
137 .blob("some blob content to measure pack size");
138 final RevCommit Q = src.commit().add("Q", Q_txt).create();
139 final Repository db = src.getRepository();
140 final String dstName = Constants.R_HEADS + "new.branch";
141 PushResult result;
142
143 try (Transport t = Transport.open(db, remoteURI)) {
144 final String srcExpr = Q.name();
145 final boolean forceUpdate = false;
146 final String localName = null;
147 final ObjectId oldId = null;
148
149 RemoteRefUpdate update = new RemoteRefUpdate(src.getRepository(),
150 srcExpr, dstName, forceUpdate, localName, oldId);
151 result = t.push(NullProgressMonitor.INSTANCE,
152 Collections.singleton(update));
153 }
154 assertEquals("expected 1 RemoteUpdate", 1, result.getRemoteUpdates()
155 .size());
156 assertEquals("unexpected pack size", 1398, packSize);
157 }
158
159 }