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 }