summaryrefslogtreecommitdiffstats
path: root/support/src/test/java/tests
diff options
context:
space:
mode:
authorElliott Hughes <enh@google.com>2009-11-04 16:00:06 -0800
committerElliott Hughes <enh@google.com>2009-11-04 16:00:06 -0800
commita152bc98bbb8feadb1b8b755f1f40fb66548ea12 (patch)
tree768bc0b87cd9fe95c73dea56d29d6714b47201cf /support/src/test/java/tests
parentfba5e71c8f9c29c55ea48bb25a63916d2bd5d2a9 (diff)
downloadlibcore-a152bc98bbb8feadb1b8b755f1f40fb66548ea12.zip
libcore-a152bc98bbb8feadb1b8b755f1f40fb66548ea12.tar.gz
libcore-a152bc98bbb8feadb1b8b755f1f40fb66548ea12.tar.bz2
Remove deadlock-prone thread pool.
This is only test code, so let's not make it any more complicated than it needs to be. (The code sometimes locked the Vector before the individual Worker, and sometimes the other way round.)
Diffstat (limited to 'support/src/test/java/tests')
-rw-r--r--support/src/test/java/tests/support/Support_TestWebServer.java98
1 files changed, 7 insertions, 91 deletions
diff --git a/support/src/test/java/tests/support/Support_TestWebServer.java b/support/src/test/java/tests/support/Support_TestWebServer.java
index 609e993..8c88cc0 100644
--- a/support/src/test/java/tests/support/Support_TestWebServer.java
+++ b/support/src/test/java/tests/support/Support_TestWebServer.java
@@ -39,22 +39,13 @@ public class Support_TestWebServer implements Support_HttpConstants {
/* The ANDROID_LOG_TAG */
private final static String LOGTAG = "httpsv";
- /* Where worker threads stand idle */
- Vector threads = new Vector();
-
/** maps the recently requested URLs to the full request snapshot */
private final Map<String, Request> pathToRequest
= new ConcurrentHashMap<String, Request>();
- /* List of all active worker threads */
- Vector activeThreads = new Vector();
-
/* timeout on client connections */
int timeout = 0;
- /* max # worker threads */
- int workers = 5;
-
/* Default port for this server to listen on */
final static int DEFAULT_PORT = 8080;
@@ -283,19 +274,7 @@ public class Support_TestWebServer implements Support_HttpConstants {
running = false;
}
- Worker w = null;
- synchronized (threads) {
- if (threads.isEmpty()) {
- Worker ws = new Worker();
- ws.setSocket(s);
- activeThreads.addElement(ws);
- (new Thread(ws, "additional worker")).start();
- } else {
- w = (Worker) threads.elementAt(0);
- threads.removeElementAt(0);
- w.setSocket(s);
- }
- }
+ new Thread(new Worker(s), "additional worker").start();
}
} catch (SocketException e) {
log("SocketException in AcceptThread: probably closed during accept");
@@ -316,14 +295,6 @@ public class Support_TestWebServer implements Support_HttpConstants {
therefore the acceptLimit functionality has been added
to circumvent this limitation */
ss.close();
-
- // Stop worker threads from continuing
- for (Enumeration e = activeThreads.elements(); e.hasMoreElements();) {
- Worker w = (Worker)e.nextElement();
- w.close();
- }
- activeThreads.clear();
-
} catch (IOException e) {
/* We are shutting down the server, so we expect
* things to die. Don't propagate.
@@ -393,75 +364,20 @@ public class Support_TestWebServer implements Support_HttpConstants {
/* Indicates whether current request has any data content */
private boolean hasContent = false;
- boolean running = false;
-
/* Request headers are stored here */
private Map<String, String> headers = new LinkedHashMap<String, String>();
/* Create a new worker thread */
- Worker() {
- buf = new byte[BUF_SIZE];
- s = null;
- }
-
- /**
- * Called by the AcceptThread to unblock this Worker to process
- * a request.
- * @param s The socket on which the connection has been made
- */
- synchronized void setSocket(Socket s) {
+ Worker(Socket s) {
+ this.buf = new byte[BUF_SIZE];
this.s = s;
- notify();
}
- /**
- * Called by the accept thread when it's closing. Potentially unblocks
- * the worker thread to terminate properly
- */
- synchronized void close() {
- running = false;
- notify();
- }
-
- /**
- * Main worker thread. This will wait until a request has
- * been identified by the accept thread upon which it will
- * service the thread.
- */
public synchronized void run() {
- running = true;
- while(running) {
- if (s == null) {
- /* nothing to do */
- try {
- log(this+" Moving to wait state");
- wait();
- } catch (InterruptedException e) {
- /* should not happen */
- continue;
- }
- if (!running) break;
- }
- try {
- handleClient();
- } catch (Exception e) {
- log("Exception during handleClient in the TestWebServer: "
- + e.getMessage());
- }
- /* go back in wait queue if there's fewer
- * than numHandler connections.
- */
- s = null;
- Vector pool = threads;
- synchronized (pool) {
- if (pool.size() >= workers) {
- /* too many threads, exit this one */
- activeThreads.remove(this);
- return;
- } else {
- pool.addElement(this);
- }
- }
+ try {
+ handleClient();
+ } catch (Exception e) {
+ log("Exception during handleClient in the TestWebServer: " + e.getMessage());
}
log(this+" terminated");
}