TestListenerOrdonancer.java

00001 /*
00002  * OpenMobileIS - a free Java(TM) Framework for mobile applications Java(TM)
00003  * Copyright (C) 2004-2006 Philippe Delrieu
00004  * All rights reserved.
00005  * Contact: pdelrieu@openmobileis.org
00006  *
00007  * This library is free software; you can redistribute it and/or
00008  * modify it under the terms of the GNU Lesser General Public
00009  * License as published by the Free Software Foundation; either
00010  * version 2.1 of the License, or any later version.
00011  *
00012  * This library is distributed in the hope that it will be useful,
00013  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00014  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00015  * Lesser General Public License for more details.
00016  *
00017  * You should have received a copy of the GNU Lesser General Public
00018  * License along with this library; if not, write to the Free Software
00019  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307
00020  * USA
00021  *
00022  *  Author : Philippe Delrieu
00023  * 
00024  */
00025 package org.openmobileis.synchro.openmsp.client.core.test;
00026 
00027 import org.openmobileis.common.util.collection.Array;
00028 import org.openmobileis.common.util.log.LogManager;
00029 import org.openmobileis.synchro.openmsp.client.OpenMSPSyncListener;
00030 import org.openmobileis.synchro.openmsp.client.core.ListenerOrdonancer;
00031 
00039 public final class TestListenerOrdonancer {
00043   public TestListenerOrdonancer() {
00044     super();
00045     // TODO Auto-generated constructor stub
00046   }
00047 
00051   public static void main(String[] args) {
00052     LogManager.registerLogManager(null);
00053     // Add listener
00054     //simple add
00055     ListenerOrdonancer ordonancer = new ListenerOrdonancer();
00056     TestSynchroListener listener = new TestSynchroListener("1");
00057     ordonancer.addListener(listener, null);
00058     
00059     //add with simple dependance.
00060     listener = new TestSynchroListener("2");
00061     ordonancer.addListener(listener, new String[]{"1"});
00062 
00063     //add with not registered dependance.
00064     listener = new TestSynchroListener("4");
00065     ordonancer.addListener(listener, new String[]{"1", "3"});
00066 
00067     //add listener of last depence with new dependance.
00068     listener = new TestSynchroListener("3");
00069     ordonancer.addListener(listener, new String[]{"1", "2"});
00070 
00071     //add listener 
00072     listener = new TestSynchroListener("5");
00073     ordonancer.addListener(listener, null);
00074 
00075     //add listener 
00076     listener = new TestSynchroListener("6");
00077     ordonancer.addListener(listener, new String[]{"4", "5"});
00078 
00079     //add listener 
00080     listener = new TestSynchroListener("7");
00081     ordonancer.addListener(listener, new String[]{"5"});
00082   
00083     //testSynchro
00084     ordonancer.beginSynchro();
00085     //first phase
00086     Array list = ordonancer.getNextListenerList();
00087     for (int i=0; i<list.size(); i++) {
00088       OpenMSPSyncListener oplistener = (OpenMSPSyncListener) list.get(i);
00089       LogManager.traceInfo(0, "Phase :1 listener :"+oplistener.getSyncName());
00090     }
00091     //set 1 in error
00092     ordonancer.notifySynchroError("1");
00093     
00094     //second phase
00095     list = ordonancer.getNextListenerList();
00096     for (int i=0; i<list.size(); i++) {
00097       OpenMSPSyncListener oplistener = (OpenMSPSyncListener) list.get(i);
00098       LogManager.traceInfo(0, "Phase :2 listener :"+oplistener.getSyncName());
00099     }
00100    
00101     //third phase
00102     list = ordonancer.getNextListenerList();
00103     for (int i=0; i<list.size(); i++) {
00104       OpenMSPSyncListener oplistener = (OpenMSPSyncListener) list.get(i);
00105       LogManager.traceInfo(0, "Phase :3 listener :"+oplistener.getSyncName());
00106     }
00107      
00108     //four phase
00109     list = ordonancer.getNextListenerList();
00110     for (int i=0; i<list.size(); i++) {
00111       OpenMSPSyncListener oplistener = (OpenMSPSyncListener) list.get(i);
00112       LogManager.traceInfo(0, "Phase :4 listener :"+oplistener.getSyncName());
00113     }
00114 
00115   }
00116 
00117 }

Generated on Mon Dec 4 11:03:31 2006 for OpenMobileIS by  doxygen 1.5.1-p1