blob: 6f90bb5d894ecfeb3de05b1a9b649c406d9d0d28 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2009 IBM Corporation and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* IBM Corporation - initial API and implementation
*******************************************************************************/
package org.eclipse.e4.languages.javascript.debug.connect.test;
import java.util.HashMap;
import java.util.Map;
import org.eclipse.e4.internal.languages.javascript.RhinoClassLoader;
import org.eclipse.e4.languages.javascript.JSBundleException;
import org.eclipse.e4.languages.javascript.JSConstants;
import org.eclipse.e4.languages.javascript.debug.connect.DebugSession;
import org.eclipse.e4.languages.javascript.debug.connect.DisconnectException;
import org.eclipse.e4.languages.javascript.debug.connect.EventPacket;
import org.eclipse.e4.languages.javascript.debug.connect.Request;
import org.eclipse.e4.languages.javascript.debug.connect.Response;
import org.eclipse.e4.languages.javascript.debug.connect.TimeoutException;
import org.eclipse.e4.languages.javascript.debug.connect.test.TestEventHandler.Subhandler;
import org.osgi.framework.Constants;
public class RequestThreadTest extends RequestTest {
public void testInvalidThread() throws DisconnectException, TimeoutException {
Request request = new Request("context");
request.getArguments().put("threadId", new Integer("9999"));
debugSession.sendRequest(request);
Response response = debugSession.receiveResponse(request.getSequence(), 30000);
assertFalse(response.isSuccess());
}
public void testThread() throws DisconnectException, TimeoutException, JSBundleException {
Subhandler setbreakpointHandler = new Subhandler() {
public boolean handleEvent(DebugSession debugSession, EventPacket event) {
if (event.getEvent().equals("script")) {
Object scriptId = event.getBody().get("scriptId");
Request request = new Request("script");
request.getArguments().put("scriptId", scriptId);
try {
debugSession.sendRequest(request);
Response response = debugSession.receiveResponse(request.getSequence(), 10000);
assertTrue(response.isSuccess());
// script onEnter
request = new Request("setbreakpoint");
request.getArguments().put("scriptId", scriptId);
debugSession.sendRequest(request);
response = debugSession.receiveResponse(request.getSequence(), 10000);
assertTrue(response.isSuccess());
} catch (DisconnectException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (TimeoutException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return true;
}
return false;
}
};
eventHandler.addSubhandler(setbreakpointHandler);
final Object[] success = new Object[1];
Subhandler contextCheckHandler = new Subhandler() {
public boolean handleEvent(DebugSession debugSession, EventPacket event) {
if (event.getEvent().equals("break")) {
Number threadId = (Number) event.getBody().get("threadId");
Request request = new Request("thread");
request.getArguments().put("threadId", threadId);
try {
debugSession.sendRequest(request);
Response response = debugSession.receiveResponse(request.getSequence(), 10000);
assertTrue(response.isSuccess());
Map thread = (Map) response.getBody().get("thread");
assertEquals(threadId.intValue(), Util.numberAsInt(thread.get("threadId")));
assertEquals("suspended", thread.get("state"));
success[0] = Boolean.TRUE;
} catch (DisconnectException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (TimeoutException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return true;
}
return false;
}
};
eventHandler.addSubhandler(contextCheckHandler);
Map headers = new HashMap();
headers.put(Constants.BUNDLE_SYMBOLICNAME, "test");
String script = "var line1 = true;\r\n";
script += "function test() { // line 2 \r\n";
script += " return \"line 3\";\r\n";
script += "} // line 4 \r\n";
script += "// line 5\r\n";
script += "var line6 = test();\r\n";
script += "var line7 = test();\r\n";
script += "// line 8\r\n";
script += "// line 9\r\n";
script += "var line10 = test();\r\n";
script += "// line 11\r\n";
script += "// line 12\r\n";
script += "function test2() { // line 13 \r\n";
script += " return \"line 14\";\r\n";
script += "} // line 15 \r\n";
script += "// line 16\r\n";
script += "// line 17\r\n";
headers.put(JSConstants.BUNDLE_SCRIPT, script);
framework.installBundle("testloc", headers, new RhinoClassLoader(Activator.getBundleContext().getBundle()));
framework.resolve();
// TODO: figure out this intermittent problem
// junit.framework.AssertionFailedError: expected:<suspended> but was:<running>
// at junit.framework.Assert.fail(Assert.java:47)
// at junit.framework.Assert.failNotEquals(Assert.java:280)
// at junit.framework.Assert.assertEquals(Assert.java:64)
// at junit.framework.Assert.assertEquals(Assert.java:71)
// at org.eclipse.e4.languages.javascript.debug.connect.test.RequestThreadTest$2.handleEvent(RequestThreadTest.java:74)
// at org.eclipse.e4.languages.javascript.debug.connect.test.TestEventHandler.handleEvent(TestEventHandler.java:117)
// at org.eclipse.e4.languages.javascript.debug.connect.test.TestEventHandler.run(TestEventHandler.java:93)
// at java.lang.Thread.run(Thread.java:619)
waitForEvents(2);
assertEquals(Boolean.TRUE, success[0]);
}
}