]> source.dussan.org Git - jgit.git/commitdiff
Better report too large pack-files from PushCommand 48/46348/7
authorChristian Halstrick <christian.halstrick@sap.com>
Thu, 23 Apr 2015 13:24:25 +0000 (15:24 +0200)
committerMatthias Sohn <matthias.sohn@sap.com>
Wed, 27 May 2015 21:52:53 +0000 (23:52 +0200)
JGits PushCommand and BasePackPushConnection were throwing generic
TransportExceptions when the pushed pack-file was rejected by the server
since it was too big. Let JGit better interprete the server's response
to detect this situation and throw a more specific exception.

This detection works by parsing the status line sent by the server. This
change only recognizes the response sent by a JGit based server. All
other servers which report such problems in a different way still lead
to a generic TransportExceptions.

Change-Id: Ic075764ea152939ce72c446252464620dd54edea
Signed-off-by: Matthias Sohn <matthias.sohn@sap.com>
org.eclipse.jgit/src/org/eclipse/jgit/api/PushCommand.java
org.eclipse.jgit/src/org/eclipse/jgit/api/errors/TooLargePackException.java [new file with mode: 0644]
org.eclipse.jgit/src/org/eclipse/jgit/errors/TooLargePackException.java
org.eclipse.jgit/src/org/eclipse/jgit/transport/BasePackPushConnection.java

index c719f0a546fd9c46fed5f80ef4b3fd13361c4b7a..0e1ce58313e6fabd826ed3a876a352fc4db8f027 100644 (file)
@@ -55,6 +55,7 @@ import org.eclipse.jgit.api.errors.GitAPIException;
 import org.eclipse.jgit.api.errors.InvalidRemoteException;
 import org.eclipse.jgit.api.errors.JGitInternalException;
 import org.eclipse.jgit.errors.NotSupportedException;
+import org.eclipse.jgit.errors.TooLargePackException;
 import org.eclipse.jgit.errors.TransportException;
 import org.eclipse.jgit.internal.JGitText;
 import org.eclipse.jgit.lib.Constants;
@@ -156,6 +157,9 @@ public class PushCommand extends
                                        PushResult result = transport.push(monitor, toPush, out);
                                        pushResults.add(result);
 
+                               } catch (TooLargePackException e) {
+                                       throw new org.eclipse.jgit.api.errors.TooLargePackException(
+                                                       e.getMessage(), e);
                                } catch (TransportException e) {
                                        throw new org.eclipse.jgit.api.errors.TransportException(
                                                        e.getMessage(), e);
diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/api/errors/TooLargePackException.java b/org.eclipse.jgit/src/org/eclipse/jgit/api/errors/TooLargePackException.java
new file mode 100644 (file)
index 0000000..3833054
--- /dev/null
@@ -0,0 +1,65 @@
+/*
+ * Copyright (C) 2015, Christian Halstrick <christian.halstrick@sap.com> and
+ * other copyright owners as documented in the project's IP log.
+ *
+ * This program and the accompanying materials are made available under the
+ * terms of the Eclipse Distribution License v1.0 which accompanies this
+ * distribution, is reproduced below, and is available at
+ * http://www.eclipse.org/org/documents/edl-v10.php
+ *
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ *
+ * - Redistributions of source code must retain the above copyright notice, this
+ * list of conditions and the following disclaimer.
+ *
+ * - Redistributions in binary form must reproduce the above copyright notice,
+ * this list of conditions and the following disclaimer in the documentation
+ * and/or other materials provided with the distribution.
+ *
+ * - Neither the name of the Eclipse Foundation, Inc. nor the names of its
+ * contributors may be used to endorse or promote products derived from this
+ * software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
+ * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ */
+package org.eclipse.jgit.api.errors;
+
+/**
+ * Exception thrown when the server rejected a too large pack
+ *
+ * @since 4.0
+ */
+public class TooLargePackException extends TransportException {
+       private static final long serialVersionUID = 1L;
+
+       /**
+        * @param msg
+        *            message describing the transport failure.
+        */
+       public TooLargePackException(String msg) {
+               super(msg);
+       }
+
+       /**
+        * @param msg
+        *            message describing the transport exception.
+        * @param cause
+        *            why the transport failed.
+        */
+       public TooLargePackException(String msg, Throwable cause) {
+               super(msg, cause);
+       }
+}
index 5cf0f802c18545294e43adcc4573868e66c8e649..d54798541d46c29a7a20dfc31d0c9a9d36487bd3 100644 (file)
 
 package org.eclipse.jgit.errors;
 
-import java.io.IOException;
 import java.text.MessageFormat;
 
 import org.eclipse.jgit.internal.JGitText;
+import org.eclipse.jgit.transport.URIish;
 
 /**
  * Thrown when a pack exceeds a given size limit
  *
  * @since 3.3
  */
-public class TooLargePackException extends IOException {
+public class TooLargePackException extends TransportException {
        private static final long serialVersionUID = 1L;
 
        /**
@@ -66,4 +66,17 @@ public class TooLargePackException extends IOException {
                super(MessageFormat.format(JGitText.get().receivePackTooLarge,
                                Long.valueOf(packSizeLimit)));
        }
+
+       /**
+        * Construct a too large pack exception.
+        *
+        * @param uri
+        *            URI used for transport
+        * @param s
+        *            message
+        * @since 4.0
+        */
+       public TooLargePackException(URIish uri, String s) {
+               super(uri.setPass(null) + ": " + s); //$NON-NLS-1$
+       }
 }
index 1e5b8e8ad6baffc4b864ede3074c460fdca965aa..24fb3be64c7257d8a527d0e2129bf30ba3dc3d7a 100644 (file)
@@ -55,6 +55,7 @@ import java.util.Set;
 import org.eclipse.jgit.errors.NoRemoteRepositoryException;
 import org.eclipse.jgit.errors.NotSupportedException;
 import org.eclipse.jgit.errors.PackProtocolException;
+import org.eclipse.jgit.errors.TooLargePackException;
 import org.eclipse.jgit.errors.TransportException;
 import org.eclipse.jgit.internal.JGitText;
 import org.eclipse.jgit.internal.storage.pack.PackWriter;
@@ -314,6 +315,9 @@ public abstract class BasePackPushConnection extends BasePackConnection implemen
                if (!unpackLine.startsWith("unpack ")) //$NON-NLS-1$
                        throw new PackProtocolException(uri, MessageFormat.format(JGitText.get().unexpectedReportLine, unpackLine));
                final String unpackStatus = unpackLine.substring("unpack ".length()); //$NON-NLS-1$
+               if (unpackStatus.startsWith("error Pack exceeds the limit of")) //$NON-NLS-1$
+                       throw new TooLargePackException(uri,
+                                       unpackStatus.substring("error ".length())); //$NON-NLS-1$
                if (!unpackStatus.equals("ok")) //$NON-NLS-1$
                        throw new TransportException(uri, MessageFormat.format(
                                        JGitText.get().errorOccurredDuringUnpackingOnTheRemoteEnd, unpackStatus));