01: /*
02: * JBoss, Home of Professional Open Source.
03: * Copyright 2006, Red Hat Middleware LLC, and individual contributors
04: * as indicated by the @author tags. See the copyright.txt file in the
05: * distribution for a full listing of individual contributors.
06: *
07: * This is free software; you can redistribute it and/or modify it
08: * under the terms of the GNU Lesser General Public License as
09: * published by the Free Software Foundation; either version 2.1 of
10: * the License, or (at your option) any later version.
11: *
12: * This software is distributed in the hope that it will be useful,
13: * but WITHOUT ANY WARRANTY; without even the implied warranty of
14: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15: * Lesser General Public License for more details.
16: *
17: * You should have received a copy of the GNU Lesser General Public
18: * License along with this software; if not, write to the Free
19: * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
20: * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
21: */
22: package org.jboss.test.cluster.partition;
23:
24: import java.io.Serializable;
25:
26: import org.jboss.ha.framework.interfaces.HAPartition;
27: import org.jboss.ha.framework.interfaces.HAPartition.HAPartitionStateTransfer;
28: import org.jboss.ha.jmx.HAServiceMBeanSupport;
29:
30: public class BadHAPartitionStateTransfer extends HAServiceMBeanSupport
31: implements HAPartitionStateTransfer,
32: BadHAPartitionStateTransferMBean {
33: private HAPartition haPartition;
34: private boolean returnState;
35:
36: public Serializable getCurrentState() {
37: if (returnState)
38: return new BadHAPartitionState();
39:
40: throw new BadHAPartitionStateException(
41: "Configured not to return state");
42: }
43:
44: public void setCurrentState(Serializable newState) {
45: // no-op
46: }
47:
48: protected void setupPartition() throws Exception {
49: if (haPartition == null) {
50: super .setupPartition();
51: haPartition = getPartition();
52: haPartition.subscribeToStateTransferEvents(
53: getServiceHAName(), this );
54: }
55: }
56:
57: protected void createService() throws Exception {
58: super .createService();
59: setupPartition();
60: }
61:
62: public boolean getReturnState() {
63: return returnState;
64: }
65:
66: public void setReturnState(boolean returnState) {
67: this.returnState = returnState;
68: }
69:
70: }
|