View Javadoc
1   /*
2    * Licensed to the Apache Software Foundation (ASF) under one or more
3    * contributor license agreements.  See the NOTICE file distributed with
4    * this work for additional information regarding copyright ownership.
5    * The ASF licenses this file to You under the Apache License, Version 2.0
6    * (the "License"); you may not use this file except in compliance with
7    * the License.  You may obtain a copy of the License at
8    *
9    *     http://www.apache.org/licenses/LICENSE-2.0
10   *
11   * Unless required by applicable law or agreed to in writing, software
12   * distributed under the License is distributed on an "AS IS" BASIS,
13   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14   * See the License for the specific language governing permissions and
15   * limitations under the License.
16   */
17  
18  package org.apache.commons.jxpath.ri.model;
19  
20  import java.util.Collections;
21  
22  import org.apache.commons.jxpath.AbstractJXPathTest;
23  import org.apache.commons.jxpath.JXPathContext;
24  import org.junit.jupiter.api.Test;
25  
26  /**
27   * Be sure empty lists/sets/arrays work.
28   */
29  public class EmptyCollectionTest extends AbstractJXPathTest {
30  
31      public static class HasChild {
32  
33          private final Object child;
34  
35          /**
36           * Constructs a new EmptyCollectionTest.HasChild instance.
37           */
38          public HasChild(final Object child) {
39              this.child = child;
40          }
41  
42          public Object getChild() {
43              return child;
44          }
45      }
46  
47      @Test
48      public void testEmptyArray() {
49          assertXPathPointerIterator(JXPathContext.newContext(new Object[0]), "/*", list());
50      }
51  
52      @Test
53      public void testEmptyChildArray() {
54          assertXPathPointerIterator(JXPathContext.newContext(new HasChild(new Object[0])), "/child/*", list());
55      }
56  
57      @Test
58      public void testEmptyChildList() {
59          assertXPathPointerIterator(JXPathContext.newContext(new HasChild(Collections.EMPTY_LIST)), "/child/*", Collections.EMPTY_LIST);
60      }
61  
62      @Test
63      public void testEmptyChildSet() {
64          assertXPathPointerIterator(JXPathContext.newContext(new HasChild(Collections.EMPTY_SET)), "/child/*", Collections.EMPTY_SET);
65      }
66  
67      @Test
68      public void testEmptyList() {
69          assertXPathPointerIterator(JXPathContext.newContext(Collections.EMPTY_LIST), "/*", Collections.EMPTY_LIST);
70      }
71  
72      @Test
73      public void testEmptySet() {
74          assertXPathPointerIterator(JXPathContext.newContext(Collections.EMPTY_SET), "/*", Collections.EMPTY_SET);
75      }
76  }