Skip to content

Commit 9d6947a

Browse files
committed
bump engine.io-client
1 parent 8f8c138 commit 9d6947a

File tree

5 files changed

+48
-26
lines changed

5 files changed

+48
-26
lines changed

pom.xml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -62,7 +62,7 @@
6262
<dependency>
6363
<groupId>io.socket</groupId>
6464
<artifactId>engine.io-client</artifactId>
65-
<version>0.8.3</version>
65+
<version>0.8.4-SNAPSHOT</version>
6666
</dependency>
6767
<dependency>
6868
<groupId>org.json</groupId>

src/main/java/io/socket/client/IO.java

Lines changed: 7 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -2,6 +2,9 @@
22

33

44
import io.socket.parser.Parser;
5+
import okhttp3.Call;
6+
import okhttp3.OkHttpClient;
7+
import okhttp3.WebSocket;
58

69
import javax.net.ssl.HostnameVerifier;
710
import javax.net.ssl.SSLContext;
@@ -23,12 +26,12 @@ public class IO {
2326
*/
2427
public static int protocol = Parser.protocol;
2528

26-
public static void setDefaultSSLContext(SSLContext sslContext) {
27-
Manager.defaultSSLContext = sslContext;
29+
public static void setDefaultOkHttpWebSocketFactory(WebSocket.Factory factory) {
30+
Manager.defaultWebSocketFactory = factory;
2831
}
2932

30-
public static void setDefaultHostnameVerifier(HostnameVerifier hostnameVerifier) {
31-
Manager.defaultHostnameVerifier = hostnameVerifier;
33+
public static void setDefaultOkHttpCallFactory(Call.Factory factory) {
34+
Manager.defaultCallFactory = factory;
3235
}
3336

3437
private IO() {}

src/main/java/io/socket/client/Manager.java

Lines changed: 8 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -5,6 +5,8 @@
55
import io.socket.parser.Packet;
66
import io.socket.parser.Parser;
77
import io.socket.thread.EventThread;
8+
import okhttp3.Call;
9+
import okhttp3.WebSocket;
810

911
import javax.net.ssl.HostnameVerifier;
1012
import javax.net.ssl.SSLContext;
@@ -73,8 +75,8 @@ public class Manager extends Emitter {
7375
*/
7476
public static final String EVENT_TRANSPORT = Engine.EVENT_TRANSPORT;
7577

76-
/*package*/ static SSLContext defaultSSLContext;
77-
/*package*/ static HostnameVerifier defaultHostnameVerifier;
78+
/*package*/ static WebSocket.Factory defaultWebSocketFactory;
79+
/*package*/ static Call.Factory defaultCallFactory;
7880

7981
/*package*/ ReadyState readyState;
8082

@@ -123,11 +125,11 @@ public Manager(URI uri, Options opts) {
123125
if (opts.path == null) {
124126
opts.path = "/socket.io";
125127
}
126-
if (opts.sslContext == null) {
127-
opts.sslContext = defaultSSLContext;
128+
if (opts.webSocketFactory == null) {
129+
opts.webSocketFactory = defaultWebSocketFactory;
128130
}
129-
if (opts.hostnameVerifier == null) {
130-
opts.hostnameVerifier = defaultHostnameVerifier;
131+
if (opts.callFactory == null) {
132+
opts.callFactory = defaultCallFactory;
131133
}
132134
this.opts = opts;
133135
this.nsps = new ConcurrentHashMap<String, Socket>();

src/test/java/io/socket/client/ExecutionTest.java

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -17,7 +17,7 @@ public class ExecutionTest extends Connection {
1717

1818
private static final Logger logger = Logger.getLogger(ExecutionTest.class.getName());
1919

20-
final static int TIMEOUT = 60 * 1000;
20+
final static int TIMEOUT = 100 * 1000;
2121

2222
@Test(timeout = TIMEOUT)
2323
public void execConnection() throws InterruptedException, IOException {

src/test/java/io/socket/client/SSLConnectionTest.java

Lines changed: 31 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,7 @@
11
package io.socket.client;
22

33
import io.socket.emitter.Emitter;
4+
import okhttp3.OkHttpClient;
45
import org.junit.After;
56
import org.junit.Test;
67
import org.junit.runner.RunWith;
@@ -9,7 +10,9 @@
910
import javax.net.ssl.HostnameVerifier;
1011
import javax.net.ssl.KeyManagerFactory;
1112
import javax.net.ssl.SSLContext;
13+
import javax.net.ssl.SSLSession;
1214
import javax.net.ssl.TrustManagerFactory;
15+
import javax.net.ssl.X509TrustManager;
1316
import java.io.File;
1417
import java.io.FileInputStream;
1518
import java.io.IOException;
@@ -21,15 +24,20 @@
2124
@RunWith(JUnit4.class)
2225
public class SSLConnectionTest extends Connection {
2326

24-
// for test on localhost
25-
static HostnameVerifier hostnameVerifier = new javax.net.ssl.HostnameVerifier(){
26-
public boolean verify(String hostname, javax.net.ssl.SSLSession sslSession) {
27-
return hostname.equals("localhost");
28-
}
29-
};
27+
private static OkHttpClient sOkHttpClient;
3028

3129
private Socket socket;
3230

31+
static {
32+
try {
33+
prepareOkHttpClient();
34+
} catch(GeneralSecurityException e) {
35+
e.printStackTrace();
36+
} catch (IOException e) {
37+
e.printStackTrace();
38+
}
39+
}
40+
3341
@Override
3442
String uri() {
3543
return "https://localhost:" + PORT;
@@ -47,7 +55,7 @@ String[] createEnv() {
4755
return new String[] {"DEBUG=socket.io:*", "PORT=" + PORT, "SSL=1"};
4856
}
4957

50-
SSLContext createSSLContext() throws GeneralSecurityException, IOException {
58+
private static void prepareOkHttpClient() throws GeneralSecurityException, IOException {
5159
KeyStore ks = KeyStore.getInstance("JKS");
5260
File file = new File("src/test/resources/keystore.jks");
5361
ks.load(new FileInputStream(file), "password".toCharArray());
@@ -60,21 +68,30 @@ SSLContext createSSLContext() throws GeneralSecurityException, IOException {
6068

6169
SSLContext sslContext = SSLContext.getInstance("TLSv1");
6270
sslContext.init(kmf.getKeyManagers(), tmf.getTrustManagers(), null);
63-
return sslContext;
71+
72+
sOkHttpClient = new OkHttpClient.Builder()
73+
.hostnameVerifier(new HostnameVerifier(){
74+
public boolean verify(String hostname, SSLSession sslSession) {
75+
return hostname.equals("localhost");
76+
}
77+
})
78+
.sslSocketFactory(sslContext.getSocketFactory(),
79+
(X509TrustManager) tmf.getTrustManagers()[0])
80+
.build();
6481
}
6582

6683
@After
6784
public void tearDown() {
68-
IO.setDefaultSSLContext(null);
69-
IO.setDefaultHostnameVerifier(null);
85+
IO.setDefaultOkHttpCallFactory(null);
86+
IO.setDefaultOkHttpWebSocketFactory(null);
7087
}
7188

7289
@Test(timeout = TIMEOUT)
7390
public void connect() throws Exception {
7491
final BlockingQueue<Object> values = new LinkedBlockingQueue<Object>();
7592
IO.Options opts = createOptions();
76-
opts.sslContext = createSSLContext();
77-
opts.hostnameVerifier = hostnameVerifier;
93+
opts.callFactory = sOkHttpClient;
94+
opts.webSocketFactory = sOkHttpClient;
7895
socket = client(opts);
7996
socket.on(Socket.EVENT_CONNECT, new Emitter.Listener() {
8097
@Override
@@ -96,8 +113,8 @@ public void call(Object... args) {
96113
@Test(timeout = TIMEOUT)
97114
public void defaultSSLContext() throws Exception {
98115
final BlockingQueue<Object> values = new LinkedBlockingQueue<Object>();
99-
IO.setDefaultSSLContext(createSSLContext());
100-
IO.setDefaultHostnameVerifier(hostnameVerifier);
116+
IO.setDefaultOkHttpWebSocketFactory(sOkHttpClient);
117+
IO.setDefaultOkHttpCallFactory(sOkHttpClient);
101118
socket = client();
102119
socket.on(Socket.EVENT_CONNECT, new Emitter.Listener() {
103120
@Override

0 commit comments

Comments
 (0)