diff --git a/pom.xml b/pom.xml
index 7ab10f6..5ac5a15 100644
--- a/pom.xml
+++ b/pom.xml
@@ -22,6 +22,12 @@
4.11
test
+
+ org.hamcrest
+ hamcrest-library
+ 1.3
+ test
+
diff --git a/src/main/java/com/github/nkzawa/engineio/client/Socket.java b/src/main/java/com/github/nkzawa/engineio/client/Socket.java
index 784976f..c1d596a 100644
--- a/src/main/java/com/github/nkzawa/engineio/client/Socket.java
+++ b/src/main/java/com/github/nkzawa/engineio/client/Socket.java
@@ -6,9 +6,7 @@ import com.github.nkzawa.engineio.client.transports.PollingXHR;
import com.github.nkzawa.engineio.client.transports.WebSocket;
import com.github.nkzawa.engineio.parser.Packet;
import com.github.nkzawa.engineio.parser.Parser;
-import com.google.gson.JsonElement;
-import com.google.gson.JsonObject;
-import com.google.gson.JsonParser;
+import com.google.gson.Gson;
import java.net.URI;
import java.net.URISyntaxException;
@@ -20,6 +18,8 @@ public abstract class Socket extends Emitter {
private static final Logger logger = Logger.getLogger(Socket.class.getName());
+ private static final Gson gson = new Gson();
+
private static final int OPENING = 0;
private static final int OPEN = 1;
private static final int CLOSING = 2;
@@ -244,7 +244,7 @@ public abstract class Socket extends Emitter {
logger.fine("changing transport and sending upgrade packet");
transport[0].off(Transport.EVENT_ERROR, onerror);
- self.emit(EVENT_UPGRADE, transport);
+ self.emit(EVENT_UPGRADE, transport[0]);
self.setTransport(transport[0]);
Packet packet = new Packet(Packet.UPGRADE);
transport[0].send(new Packet[]{packet});
@@ -316,7 +316,7 @@ public abstract class Socket extends Emitter {
this.emit(EVENT_HEARTBEAT);
if (Packet.OPEN.equals(packet.type)) {
- this.onHandshake(new JsonParser().parse(packet.data).getAsJsonObject());
+ this.onHandshake(gson.fromJson(packet.data, HandshakeData.class));
} else if (Packet.PONG.equals(packet.type)) {
this.ping();
} else if (Packet.ERROR.equals(packet.type)) {
@@ -334,19 +334,13 @@ public abstract class Socket extends Emitter {
}
}
- private void onHandshake(JsonObject data) {
+ private void onHandshake(HandshakeData data) {
this.emit(EVENT_HANDSHAKE, data);
- this.id = data.get("sid").getAsString();
- this.transport.query.put("sid", data.get("sid").getAsString());
-
- List upgrades = new ArrayList();
- for (JsonElement upgrade : data.get("upgrades").getAsJsonArray()) {
- upgrades.add(upgrade.getAsString());
- }
- this.upgrades = this.filterUpgrades(upgrades);
-
- this.pingInterval = data.get("pingInterval").getAsLong();
- this.pingTimeout = data.get("pingTimeout").getAsLong();
+ this.id = data.sid;
+ this.transport.query.put("sid", data.sid);
+ this.upgrades = this.filterUpgrades(data.upgrades);
+ this.pingInterval = data.pingInterval;
+ this.pingTimeout = data.pingTimeout;
this.onOpen();
this.ping();
@@ -526,6 +520,7 @@ public abstract class Socket extends Emitter {
public abstract void onclose();
+
public static class Options extends Transport.Options {
public String host;
@@ -558,4 +553,12 @@ public abstract class Socket extends Emitter {
public Emitter evs = new Emitter();
}
+
+ public static class HandshakeData {
+
+ public String sid;
+ public List upgrades;
+ public long pingInterval;
+ public long pingTimeout;
+ }
}
diff --git a/src/test/java/com/github/nkzawa/engineio/client/ConnectionTest.java b/src/test/java/com/github/nkzawa/engineio/client/ServerConnectionTest.java
similarity index 58%
rename from src/test/java/com/github/nkzawa/engineio/client/ConnectionTest.java
rename to src/test/java/com/github/nkzawa/engineio/client/ServerConnectionTest.java
index cb34109..4da8739 100644
--- a/src/test/java/com/github/nkzawa/engineio/client/ConnectionTest.java
+++ b/src/test/java/com/github/nkzawa/engineio/client/ServerConnectionTest.java
@@ -1,5 +1,6 @@
package com.github.nkzawa.engineio.client;
+import com.github.nkzawa.emitter.Emitter;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
@@ -12,11 +13,14 @@ import java.io.InputStreamReader;
import java.net.URISyntaxException;
import java.util.concurrent.*;
-import static org.hamcrest.CoreMatchers.is;
+import static org.hamcrest.CoreMatchers.*;
+import static org.hamcrest.Matchers.empty;
+import static org.hamcrest.Matchers.greaterThan;
+import static org.hamcrest.Matchers.instanceOf;
import static org.junit.Assert.assertThat;
@RunWith(JUnit4.class)
-public class ConnectionTest {
+public class ServerConnectionTest {
final static int TIMEOUT = 3000;
final static int PORT = 3000;
@@ -133,4 +137,82 @@ public class ConnectionTest {
assertThat(events.take(), is("hi"));
socket.close();
}
+
+ @Test(timeout = TIMEOUT)
+ public void handshake() throws URISyntaxException, InterruptedException {
+ final BlockingQueue