f6afabf30cd222b192e154e5719972259c0a4982
[yangtools.git] / third-party / triemap / src / test / java / org / opendaylight / yangtools / triemap / ListMapTest.java
1 /*
2  * (C) Copyright 2016 Pantheon Technologies, s.r.o. and others.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *     http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 package org.opendaylight.yangtools.triemap;
17
18 import static org.junit.Assert.assertFalse;
19
20 import org.junit.Test;
21
22 public class ListMapTest {
23
24     /**
25      * Test if Listmap.get() does not cause stack overflow.
26      */
27     @Test
28     public void testGetOverflow() {
29         ListMap<Integer, Boolean> map = ListMap.map(1, Boolean.TRUE, 2, Boolean.TRUE);
30
31         // 30K seems to be enough to trigger the problem locally
32         for (int i = 3; i < 30000; ++i) {
33             map = map.add(i, Boolean.TRUE);
34         }
35
36         final Option<Boolean> ret = map.get(0);
37         assertFalse(ret.nonEmpty());
38     }
39
40 }