1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81
|
/*-
* See the file LICENSE for redistribution information.
*
* Copyright (c) 2011, 2013 Oracle and/or its affiliates. All rights reserved.
*
*/
package repmgrtests;
import com.sleepycat.db.EventHandlerAdapter;
class EventHandler extends EventHandlerAdapter {
private boolean done;
private boolean panic;
private boolean gotNewmaster;
private boolean iAmMaster;
private int permFailCount;
@Override synchronized public void handleRepStartupDoneEvent() {
done = true;
notifyAll();
}
@Override synchronized public void handleRepMasterEvent() {
iAmMaster = true;
}
@Override synchronized public void handleRepClientEvent() {
iAmMaster = false;
}
@Override synchronized public void handleRepNewMasterEvent(int eid) {
gotNewmaster = true;
notifyAll();
}
@Override synchronized public void handleRepPermFailedEvent() {
permFailCount++;
}
synchronized public boolean isMaster() { return iAmMaster; }
@Override synchronized public void handlePanicEvent() {
panic = true;
notifyAll();
}
synchronized void await() throws Exception {
while (!done) {
wait();
checkPanic();
}
}
synchronized void awaitNewmaster(long maxWait) throws Exception {
long deadline = System.currentTimeMillis() + maxWait;
while (!gotNewmaster) {
long now = System.currentTimeMillis();
if (now >= deadline)
throw new Exception("aborted by timeout");
long waitTime = deadline-now;
wait(waitTime);
checkPanic();
}
}
synchronized void awaitNewmaster() throws Exception {
while (!gotNewmaster) {
wait();
checkPanic();
}
}
synchronized public int getPermFailCount() { return permFailCount; }
private void checkPanic() throws Exception {
if (panic)
throw new Exception("aborted by DB panic");
}
}
|