1   /*
2    *
3    * The Seasar Software License, Version 1.1
4    *
5    * Copyright (c) 2003-2004 The Seasar Project. All rights reserved.
6    *
7    * Redistribution and use in source and binary forms, with or
8    * without modification, are permitted provided that the following
9    * conditions are met:
10   *
11   * 1. Redistributions of source code must retain the above
12   *    copyright notice, this list of conditions and the following
13   *    disclaimer.
14   *
15   * 2. Redistributions in binary form must reproduce the above
16   *    copyright notice, this list of conditions and the following
17   *    disclaimer in the documentation and/or other materials provided
18   *    with the distribution.
19   *
20   * 3. The end-user documentation included with the redistribution,
21   *    if any, must include the following acknowledgement:
22   *    "This product includes software developed by the
23   *    Seasar Project (http://www.seasar.org/)."
24   *    Alternately, this acknowledgement may appear in the software
25   *    itself, if and wherever such third-party acknowledgements
26   *    normally appear.
27   *
28   * 4. Neither the name "The Seasar Project" nor the names of its
29   *    contributors may be used to endorse or promote products derived
30   *    from this software without specific prior written permission of
31   *    the Seasar Project.
32   *
33   * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR
34   * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
35   * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
36   * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE SEASAR PROJECT
37   * OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
38   * INCIDENTAL,SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
39   * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
40   * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
41   * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
42   * WHETHER IN CONTRACT, STRICT LIABILITY,OR TORT (INCLUDING
43   * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
44   * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
45   */
46  package org.seasar.remoting.common.connector.impl;
47  
48  import java.lang.reflect.Method;
49  import java.net.URL;
50  
51  import org.seasar.remoting.common.connector.impl.TargetSpecificURLBasedConnector;
52  
53  import junit.framework.TestCase;
54  
55  /***
56   * @author Koichi Kobayashi
57   */
58  public class TargetSpecificURLBasedConnectorTest extends TestCase {
59      public TargetSpecificURLBasedConnectorTest() {
60      }
61  
62      public TargetSpecificURLBasedConnectorTest(String name) {
63          super(name);
64      }
65  
66      public void testGetTargetURL() throws Exception {
67          TargetSpecificURLBasedConnector connector = new TargetSpecificURLBasedConnector() {
68              protected Object invoke(URL url, Method method, Object[] params) {
69                  return null;
70              }
71          };
72  
73          //ends with /
74          connector.setBaseURL(new URL("http://localhost/context/"));
75          assertEquals(new URL("http://localhost/context/Foo"), connector.getTargetURL("Foo"));
76  
77          //ends without /
78          connector.setBaseURL(new URL("http://localhost/context"));
79          assertEquals(new URL("http://localhost/Bar"), connector.getTargetURL("Bar"));
80      }
81  
82      public void testLRUMap() {
83          TargetSpecificURLBasedConnector.LRUMap map = new TargetSpecificURLBasedConnector.LRUMap(1);
84          assertEquals(0, map.size());
85  
86          map.put("1", "1");
87          assertEquals(1, map.size());
88  
89          map.put("2", "2");
90          assertEquals(1, map.size());
91  
92          map.setMaxSize(2);
93          map.put("3", "3");
94          assertEquals(2, map.size());
95  
96          map.put("4", "4");
97          assertEquals(2, map.size());
98  
99          map.setMaxSize(0);
100         map.put("5", "5");
101         assertEquals(3, map.size());
102     }
103 }