diff options
author | David Pursehouse <david.pursehouse@gmail.com> | 2017-11-22 11:31:20 +0900 |
---|---|---|
committer | David Pursehouse <david.pursehouse@gmail.com> | 2017-11-22 11:31:29 +0900 |
commit | bd052b94aa5349f34515763f442d9a0456c630fa (patch) | |
tree | 50394a582e467f2b896f8a4ef6f07715c6befe1f | |
parent | 8b3ab4343c4d34993176b5fa799a039e8114054b (diff) | |
parent | 5284cc1bf764207343a43effccdcada02c05b2bd (diff) | |
download | jgit-bd052b94aa5349f34515763f442d9a0456c630fa.tar.gz jgit-bd052b94aa5349f34515763f442d9a0456c630fa.zip |
Merge branch 'stable-4.9'
* stable-4.9:
Yet another work-around for a Jsch bug: timeouts
Change-Id: I7cf227c62a3c06f91cee1a6c61719b6fe50da883
Signed-off-by: David Pursehouse <david.pursehouse@gmail.com>
-rw-r--r-- | org.eclipse.jgit.test/tst/org/eclipse/jgit/transport/OpenSshConfigTest.java | 3 | ||||
-rw-r--r-- | org.eclipse.jgit/src/org/eclipse/jgit/transport/OpenSshConfig.java | 62 |
2 files changed, 61 insertions, 4 deletions
diff --git a/org.eclipse.jgit.test/tst/org/eclipse/jgit/transport/OpenSshConfigTest.java b/org.eclipse.jgit.test/tst/org/eclipse/jgit/transport/OpenSshConfigTest.java index d604751fef..8ce3f0f147 100644 --- a/org.eclipse.jgit.test/tst/org/eclipse/jgit/transport/OpenSshConfigTest.java +++ b/org.eclipse.jgit.test/tst/org/eclipse/jgit/transport/OpenSshConfigTest.java @@ -343,8 +343,7 @@ public class OpenSshConfigTest extends RepositoryTestCase { assertEquals(h1.getConnectionAttempts(), h2.getConnectionAttempts()); final ConfigRepository.Config c = osc.getConfig("orcz"); assertNotNull(c); - assertSame(c, h1.getConfig()); - assertSame(c, h2.getConfig()); + assertSame(h1.getConfig(), h2.getConfig()); } @Test diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/transport/OpenSshConfig.java b/org.eclipse.jgit/src/org/eclipse/jgit/transport/OpenSshConfig.java index 67a7db99f4..79fab01297 100644 --- a/org.eclipse.jgit/src/org/eclipse/jgit/transport/OpenSshConfig.java +++ b/org.eclipse.jgit/src/org/eclipse/jgit/transport/OpenSshConfig.java @@ -59,6 +59,7 @@ import java.util.List; import java.util.Locale; import java.util.Map; import java.util.Set; +import java.util.concurrent.TimeUnit; import org.eclipse.jgit.errors.InvalidPatternException; import org.eclipse.jgit.fnmatch.FileNameMatcher; @@ -961,7 +962,7 @@ public class OpenSshConfig implements ConfigRepository { /** * Retrieves the full {@link com.jcraft.jsch.ConfigRepository.Config Config} - * for the given host name. + * for the given host name. Should be called only by Jsch and tests. * * @param hostName * to get the config for @@ -971,7 +972,7 @@ public class OpenSshConfig implements ConfigRepository { @Override public Config getConfig(String hostName) { Host host = lookup(hostName); - return host.getConfig(); + return new JschBugFixingConfig(host.getConfig()); } @Override @@ -980,4 +981,61 @@ public class OpenSshConfig implements ConfigRepository { return "OpenSshConfig [home=" + home + ", configFile=" + configFile + ", lastModified=" + lastModified + ", state=" + state + "]"; } + + /** + * A {@link com.jcraft.jsch.ConfigRepository.Config} that transforms some + * values from the config file into the format Jsch 0.1.54 expects. This is + * a work-around for bugs in Jsch. + */ + private static class JschBugFixingConfig implements Config { + + private final Config real; + + public JschBugFixingConfig(Config delegate) { + real = delegate; + } + + @Override + public String getHostname() { + return real.getHostname(); + } + + @Override + public String getUser() { + return real.getUser(); + } + + @Override + public int getPort() { + return real.getPort(); + } + + @Override + public String getValue(String key) { + String result = real.getValue(key); + if (result != null) { + String k = key.toUpperCase(Locale.ROOT); + if ("SERVERALIVEINTERVAL".equals(k) //$NON-NLS-1$ + || "CONNECTTIMEOUT".equals(k)) { //$NON-NLS-1$ + // These values are in seconds. Jsch 0.1.54 passes them on + // as is to java.net.Socket.setSoTimeout(), which expects + // milliseconds. So convert here to milliseconds... + try { + int timeout = Integer.parseInt(result); + result = Long + .toString(TimeUnit.SECONDS.toMillis(timeout)); + } catch (NumberFormatException e) { + // Ignore + } + } + } + return result; + } + + @Override + public String[] getValues(String key) { + return real.getValues(key); + } + + } } |