1   //----------------------------------------------------------------------
2   // 
3   // PerfectJPattern: "Design patterns are good but components are better!" 
4   // TestExample.java Copyright (c) 2009 Giovanni Azua Garcia
5   // bravegag@hotmail.com
6   //  
7   // This program is free software; you can redistribute it and/or
8   // modify it under the terms of the GNU General Public License
9   // as published by the Free Software Foundation; either version 3
10  // of the License, or (at your option) any later version.
11  //
12  // This program 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
15  // GNU General Public License for more details.
16  //
17  // You should have received a copy of the GNU General Public License
18  // along with this program; if not, see <http://www.gnu.org/licenses/>.
19  //
20  //----------------------------------------------------------------------
21  package org.perfectjpattern.core.behavioral.visitor;
22  
23  import junit.framework.*;
24  
25  import org.slf4j.*;
26  
27  import static org.easymock.EasyMock.*;
28  
29  /**
30   * Visitor example test suite 
31   *
32   * @author <a href="mailto:bravegag@hotmail.com">Giovanni Azua</a>
33   * @version $Revision: 1.0 $Date: Apr 20, 2008 1:58:38 PM $
34   */
35  public 
36  class TestExample
37  extends TestCase
38  {
39      //------------------------------------------------------------------------
40      // public
41      //------------------------------------------------------------------------
42      public void
43      testVisitor()
44      {
45          Logger myLoggerMock = createNiceMock(Logger.class);
46                  
47          myLoggerMock.debug("Visiting car");
48          myLoggerMock.debug("Visiting engine");
49          myLoggerMock.debug("Visiting body");
50          myLoggerMock.debug("Visiting front left wheel");
51          myLoggerMock.debug("Visiting front right wheel");
52          myLoggerMock.debug("Visiting back left wheel");
53          myLoggerMock.debug("Visiting back right wheel");
54          myLoggerMock.debug("Vroom!");
55          myLoggerMock.debug("Starting my engine");
56          myLoggerMock.debug("Moving my body");
57          myLoggerMock.debug("Steering my wheel");
58          myLoggerMock.debug("Steering my wheel");
59          myLoggerMock.debug("Steering my wheel");
60          myLoggerMock.debug("Steering my wheel");
61                  
62          replay(myLoggerMock);
63          
64          PrintVisitor.setLogger(myLoggerMock);
65          DoVisitor.setLogger(myLoggerMock);
66          
67          Example.main(new String[0]);
68          
69          verify(myLoggerMock);
70      }
71  }