Ignore:
Timestamp:
07/12/13 17:15:18 (11 years ago)
Author:
pharms
Message:
  • corrected formating
File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/autoquest-core-usageprofiles-test/src/test/java/de/ugoe/cs/autoquest/usageprofiles/TrieTest.java

    r1118 r1252  
    3131 
    3232/** 
    33  * The class <code>TrieTest</code> contains tests for the class 
    34  * <code>{@link Trie}</code>. 
     33 * The class <code>TrieTest</code> contains tests for the class <code>{@link Trie}</code>. 
    3534 *  
    3635 * @author Steffen Herbold 
     
    3938public class TrieTest { 
    4039 
    41         List<String> sequence; 
    42         Collection<String> symbols; 
    43  
    44         private static void assertCollectionContent(Collection<?> c1, 
    45                         Collection<?> c2) { 
    46                 assertEquals(c1.size(), c2.size()); 
    47                 for (Object obj : c1) { 
    48                         assertTrue(c2.contains(obj)); 
    49                 } 
    50         } 
    51  
    52         @Test 
    53         public void testTrie_1() throws Exception { 
    54  
    55                 Trie<String> result = new Trie<String>(); 
    56  
    57                 assertNotNull(result); 
    58                 assertEquals(0, result.getNumLeafs()); 
    59                 assertEquals(0, result.getNumSymbols()); 
    60                 assertEquals(0, result.getNumLeafAncestors()); 
    61                 assertTrue(result.getKnownSymbols().isEmpty()); 
    62         } 
    63  
    64         @Test 
    65         public void testTrie_2() throws Exception { 
    66                 Trie<String> trie1 = new Trie<String>(); 
    67                 trie1.train(sequence, 3); 
    68  
    69                 Trie<String> result = new Trie<String>(trie1); 
    70  
    71                 assertEquals(trie1, result); 
    72                 assertNotSame(trie1, result); 
    73         } 
    74  
    75         @Test(expected = java.lang.IllegalArgumentException.class) 
    76         public void testTrie_3() throws Exception { 
    77                 new Trie<String>((SymbolComparator<String>) null); 
    78         } 
    79  
    80         @Test(expected = java.lang.IllegalArgumentException.class) 
    81         public void testTrie_4() throws Exception { 
    82                 new Trie<String>((Trie<String>) null); 
     40    List<String> sequence; 
     41    Collection<String> symbols; 
     42 
     43    private static void assertCollectionContent(Collection<?> c1, Collection<?> c2) { 
     44        assertEquals(c1.size(), c2.size()); 
     45        for (Object obj : c1) { 
     46            assertTrue(c2.contains(obj)); 
    8347        } 
    84  
    85         @Test 
    86         public void testAdd_1() throws Exception { 
    87                 Trie<String> fixture = new Trie<String>(); 
    88                 List<String> seq = new ArrayList<String>(); 
    89                 seq.add("a"); 
    90                 seq.add("b"); 
    91  
    92                 fixture.add(seq); 
    93  
    94                 assertEquals(1, fixture.getChild("a").getCount()); 
    95                 assertEquals(1, fixture.getChild("a").getChild("b").getCount()); 
    96                 assertNull(fixture.getChild("b")); 
    97         } 
    98  
    99         @Test 
    100         public void testAdd_2() throws Exception { 
    101                 Trie<String> fixture = new Trie<String>(); 
    102  
    103                 fixture.add(new ArrayList<String>()); 
    104  
    105                 assertEquals(0, fixture.getNumSymbols()); 
    106         } 
    107  
    108         @Test 
    109         public void testAdd_3() throws Exception { 
    110                 Trie<String> fixture = new Trie<String>(); 
    111  
    112                 fixture.add(null); 
    113  
    114                 assertEquals(0, fixture.getNumSymbols()); 
    115         } 
    116  
    117         @Test 
    118         public void testFind_1() throws Exception { 
    119                 Trie<String> fixture = new Trie<String>(); 
    120                 fixture.train(sequence, 3); 
    121                 List<String> findSequence = new ArrayList<String>(); 
    122                 findSequence.add("a"); 
    123                 findSequence.add("b"); 
    124                 findSequence.add("r"); 
    125                 TrieNode<String> expected = fixture.getChild("a").getChild("b") 
    126                                 .getChild("r"); 
    127  
    128                 TrieNode<String> result = fixture.find(findSequence); 
    129  
    130                 assertEquals(expected, result); 
    131         } 
    132  
    133         @Test 
    134         public void testFind_2() throws Exception { 
    135                 Trie<String> fixture = new Trie<String>(); 
    136                 fixture.train(sequence, 3); 
    137                 List<String> findSequence = new ArrayList<String>(); 
    138                 findSequence.add("c"); 
    139                 findSequence.add("a"); 
    140                 TrieNode<String> expected = fixture.getChild("c").getChild("a"); 
    141  
    142                 TrieNode<String> result = fixture.find(findSequence); 
    143  
    144                 assertEquals(expected, result); 
    145         } 
    146  
    147         @Test 
    148         public void testFind_3() throws Exception { 
    149                 Trie<String> fixture = new Trie<String>(); 
    150                 fixture.train(sequence, 3); 
    151                 List<String> findSequence = new ArrayList<String>(); 
    152  
    153                 TrieNode<String> result = fixture.find(findSequence); 
    154  
    155                 assertTrue(result.isRoot()); 
    156         } 
    157  
    158         @Test 
    159         public void testFind_4() throws Exception { 
    160                 Trie<String> fixture = new Trie<String>(); 
    161                 fixture.train(sequence, 3); 
    162  
    163                 TrieNode<String> result = fixture.find(null); 
    164  
    165                 assertTrue(result.isRoot()); 
    166         } 
    167  
    168         @Test 
    169         public void testGetChildCreate_1() throws Exception { 
    170                 Trie<String> fixture = new Trie<String>(); 
    171                 String symbol = "a"; 
    172  
    173                 TrieNode<String> result = fixture.getChildCreate(symbol); 
    174  
    175                 assertEquals(symbol, result.getSymbol()); 
    176                 assertEquals(0, result.getCount()); 
    177                 assertTrue(result.isLeaf()); 
    178         } 
    179  
    180         @Test(expected = java.lang.IllegalArgumentException.class) 
    181         public void testGetChildCreate_2() throws Exception { 
    182                 Trie<String> fixture = new Trie<String>(); 
    183                 fixture.getChildCreate(null); 
    184         } 
    185  
    186         @Test 
    187         public void testGetContextSuffix_1() throws Exception { 
    188                 Trie<String> fixture = new Trie<String>(); 
    189                 fixture.train(sequence, 3); 
    190                 List<String> context = new ArrayList<String>(); 
    191                 context.add("a"); 
    192                 context.add("a"); 
    193                 context.add("b"); 
    194                 List<String> expected = new ArrayList<String>(); 
    195                 expected.add("a"); 
    196                 expected.add("b"); 
    197  
    198                 List<String> result = fixture.getContextSuffix(context); 
    199  
    200                 ListAssert.assertEquals(expected, result); 
    201         } 
    202  
    203         @Test 
    204         public void testGetContextSuffix_2() throws Exception { 
    205                 Trie<String> fixture = new Trie<String>(); 
    206                 fixture.train(sequence, 3); 
    207                 List<String> context = new ArrayList<String>(); 
    208                 context.add("a"); 
    209                 context.add("a"); 
    210                 context.add("b"); 
    211                 context.add("r"); 
    212                 List<String> expected = new ArrayList<String>(); 
    213                 expected.add("b"); 
    214                 expected.add("r"); 
    215  
    216                 List<String> result = fixture.getContextSuffix(context); 
    217  
    218                 ListAssert.assertEquals(expected, result); 
    219         } 
    220  
    221         @Test 
    222         public void testGetContextSuffix_3() throws Exception { 
    223                 Trie<String> fixture = new Trie<String>(); 
    224                 fixture.train(sequence, 3); 
    225                 List<String> context = new ArrayList<String>(); 
    226                 context.add("a"); 
    227                 context.add("a"); 
    228                 context.add("b"); 
    229                 context.add("x"); 
    230                 List<String> expected = new ArrayList<String>(); 
    231  
    232                 List<String> result = fixture.getContextSuffix(context); 
    233  
    234                 ListAssert.assertEquals(expected, result); 
    235         } 
    236  
    237         @Test 
    238         public void testGetContextSuffix_4() throws Exception { 
    239                 Trie<String> fixture = new Trie<String>(); 
    240  
    241                 List<String> result = fixture.getContextSuffix(null); 
    242  
    243                 // add additional test code here 
    244                 assertNotNull(result); 
    245                 assertEquals(0, result.size()); 
    246         } 
    247  
    248         @Test 
    249         public void testGetContextSuffix_5() throws Exception { 
    250                 Trie<String> fixture = new Trie<String>(); 
    251                 fixture.train(sequence, 3); 
    252                 List<String> context = new ArrayList<String>(); 
    253                 context.add("a"); 
    254                 context.add("a"); 
    255                 context.add("b"); 
    256                 List<String> expected = new ArrayList<String>(); 
    257                 expected.add("a"); 
    258                 expected.add("b"); 
    259  
    260                 List<String> result = fixture.getContextSuffix(context); 
    261  
    262                 ListAssert.assertEquals(expected, result); 
     48    } 
     49 
     50    @Test 
     51    public void testTrie_1() throws Exception { 
     52 
     53        Trie<String> result = new Trie<String>(); 
     54 
     55        assertNotNull(result); 
     56        assertEquals(0, result.getNumLeafs()); 
     57        assertEquals(0, result.getNumSymbols()); 
     58        assertEquals(0, result.getNumLeafAncestors()); 
     59        assertTrue(result.getKnownSymbols().isEmpty()); 
     60    } 
     61 
     62    @Test 
     63    public void testTrie_2() throws Exception { 
     64        Trie<String> trie1 = new Trie<String>(); 
     65        trie1.train(sequence, 3); 
     66 
     67        Trie<String> result = new Trie<String>(trie1); 
     68 
     69        assertEquals(trie1, result); 
     70        assertNotSame(trie1, result); 
     71    } 
     72 
     73    @Test(expected = java.lang.IllegalArgumentException.class) 
     74    public void testTrie_3() throws Exception { 
     75        new Trie<String>((SymbolComparator<String>) null); 
     76    } 
     77 
     78    @Test(expected = java.lang.IllegalArgumentException.class) 
     79    public void testTrie_4() throws Exception { 
     80        new Trie<String>((Trie<String>) null); 
     81    } 
     82 
     83    @Test 
     84    public void testAdd_1() throws Exception { 
     85        Trie<String> fixture = new Trie<String>(); 
     86        List<String> seq = new ArrayList<String>(); 
     87        seq.add("a"); 
     88        seq.add("b"); 
     89 
     90        fixture.add(seq); 
     91 
     92        assertEquals(1, fixture.getChild("a").getCount()); 
     93        assertEquals(1, fixture.getChild("a").getChild("b").getCount()); 
     94        assertNull(fixture.getChild("b")); 
     95    } 
     96 
     97    @Test 
     98    public void testAdd_2() throws Exception { 
     99        Trie<String> fixture = new Trie<String>(); 
     100 
     101        fixture.add(new ArrayList<String>()); 
     102 
     103        assertEquals(0, fixture.getNumSymbols()); 
     104    } 
     105 
     106    @Test 
     107    public void testAdd_3() throws Exception { 
     108        Trie<String> fixture = new Trie<String>(); 
     109 
     110        fixture.add(null); 
     111 
     112        assertEquals(0, fixture.getNumSymbols()); 
     113    } 
     114 
     115    @Test 
     116    public void testFind_1() throws Exception { 
     117        Trie<String> fixture = new Trie<String>(); 
     118        fixture.train(sequence, 3); 
     119        List<String> findSequence = new ArrayList<String>(); 
     120        findSequence.add("a"); 
     121        findSequence.add("b"); 
     122        findSequence.add("r"); 
     123        TrieNode<String> expected = fixture.getChild("a").getChild("b").getChild("r"); 
     124 
     125        TrieNode<String> result = fixture.find(findSequence); 
     126 
     127        assertEquals(expected, result); 
     128    } 
     129 
     130    @Test 
     131    public void testFind_2() throws Exception { 
     132        Trie<String> fixture = new Trie<String>(); 
     133        fixture.train(sequence, 3); 
     134        List<String> findSequence = new ArrayList<String>(); 
     135        findSequence.add("c"); 
     136        findSequence.add("a"); 
     137        TrieNode<String> expected = fixture.getChild("c").getChild("a"); 
     138 
     139        TrieNode<String> result = fixture.find(findSequence); 
     140 
     141        assertEquals(expected, result); 
     142    } 
     143 
     144    @Test 
     145    public void testFind_3() throws Exception { 
     146        Trie<String> fixture = new Trie<String>(); 
     147        fixture.train(sequence, 3); 
     148        List<String> findSequence = new ArrayList<String>(); 
     149 
     150        TrieNode<String> result = fixture.find(findSequence); 
     151 
     152        assertTrue(result.isRoot()); 
     153    } 
     154 
     155    @Test 
     156    public void testFind_4() throws Exception { 
     157        Trie<String> fixture = new Trie<String>(); 
     158        fixture.train(sequence, 3); 
     159 
     160        TrieNode<String> result = fixture.find(null); 
     161 
     162        assertTrue(result.isRoot()); 
     163    } 
     164 
     165    @Test 
     166    public void testGetChildCreate_1() throws Exception { 
     167        Trie<String> fixture = new Trie<String>(); 
     168        String symbol = "a"; 
     169 
     170        TrieNode<String> result = fixture.getChildCreate(symbol); 
     171 
     172        assertEquals(symbol, result.getSymbol()); 
     173        assertEquals(0, result.getCount()); 
     174        assertTrue(result.isLeaf()); 
     175    } 
     176 
     177    @Test(expected = java.lang.IllegalArgumentException.class) 
     178    public void testGetChildCreate_2() throws Exception { 
     179        Trie<String> fixture = new Trie<String>(); 
     180        fixture.getChildCreate(null); 
     181    } 
     182 
     183    @Test 
     184    public void testGetContextSuffix_1() throws Exception { 
     185        Trie<String> fixture = new Trie<String>(); 
     186        fixture.train(sequence, 3); 
     187        List<String> context = new ArrayList<String>(); 
     188        context.add("a"); 
     189        context.add("a"); 
     190        context.add("b"); 
     191        List<String> expected = new ArrayList<String>(); 
     192        expected.add("a"); 
     193        expected.add("b"); 
     194 
     195        List<String> result = fixture.getContextSuffix(context); 
     196 
     197        ListAssert.assertEquals(expected, result); 
     198    } 
     199 
     200    @Test 
     201    public void testGetContextSuffix_2() throws Exception { 
     202        Trie<String> fixture = new Trie<String>(); 
     203        fixture.train(sequence, 3); 
     204        List<String> context = new ArrayList<String>(); 
     205        context.add("a"); 
     206        context.add("a"); 
     207        context.add("b"); 
     208        context.add("r"); 
     209        List<String> expected = new ArrayList<String>(); 
     210        expected.add("b"); 
     211        expected.add("r"); 
     212 
     213        List<String> result = fixture.getContextSuffix(context); 
     214 
     215        ListAssert.assertEquals(expected, result); 
     216    } 
     217 
     218    @Test 
     219    public void testGetContextSuffix_3() throws Exception { 
     220        Trie<String> fixture = new Trie<String>(); 
     221        fixture.train(sequence, 3); 
     222        List<String> context = new ArrayList<String>(); 
     223        context.add("a"); 
     224        context.add("a"); 
     225        context.add("b"); 
     226        context.add("x"); 
     227        List<String> expected = new ArrayList<String>(); 
     228 
     229        List<String> result = fixture.getContextSuffix(context); 
     230 
     231        ListAssert.assertEquals(expected, result); 
     232    } 
     233 
     234    @Test 
     235    public void testGetContextSuffix_4() throws Exception { 
     236        Trie<String> fixture = new Trie<String>(); 
     237 
     238        List<String> result = fixture.getContextSuffix(null); 
     239 
     240        // add additional test code here 
     241        assertNotNull(result); 
     242        assertEquals(0, result.size()); 
     243    } 
     244 
     245    @Test 
     246    public void testGetContextSuffix_5() throws Exception { 
     247        Trie<String> fixture = new Trie<String>(); 
     248        fixture.train(sequence, 3); 
     249        List<String> context = new ArrayList<String>(); 
     250        context.add("a"); 
     251        context.add("a"); 
     252        context.add("b"); 
     253        List<String> expected = new ArrayList<String>(); 
     254        expected.add("a"); 
     255        expected.add("b"); 
     256 
     257        List<String> result = fixture.getContextSuffix(context); 
     258 
     259        ListAssert.assertEquals(expected, result); 
     260    } 
     261 
     262    @Test 
     263    public void testProcessWithTrieProcessor_1() throws Exception { 
     264        Trie<String> fixture = new Trie<String>(); 
     265        fixture.train(sequence, 2); 
     266 
     267        final List<String> sequences = new ArrayList<String>(); 
     268        TrieProcessor<String> processor = new TrieProcessor<String>() { 
     269            @Override 
     270            public TrieProcessor.Result process(List<String> sequence, int count) { 
     271                sequences.add(count + "_" + sequence.toString()); 
     272                return TrieProcessor.Result.CONTINUE; 
     273            } 
     274 
     275        }; 
     276 
     277        fixture.process(processor); 
     278 
     279        List<String> expected = new ArrayList<String>(); 
     280 
     281        expected.add("5_[a]"); 
     282        expected.add("2_[a, b]"); 
     283        expected.add("2_[b]"); 
     284        expected.add("2_[b, r]"); 
     285        expected.add("2_[r]"); 
     286        expected.add("2_[r, a]"); 
     287        expected.add("1_[a, c]"); 
     288        expected.add("1_[c]"); 
     289        expected.add("1_[c, a]"); 
     290        expected.add("1_[a, d]"); 
     291        expected.add("1_[d]"); 
     292        expected.add("1_[d, a]"); 
     293 
     294        assertEquals(expected.size(), sequences.size()); 
     295 
     296        for (String sequence : sequences) { 
     297            ListAssert.assertContains(expected, sequence); 
    263298        } 
    264  
    265         @Test 
    266         public void testProcessWithTrieProcessor_1() throws Exception { 
    267                 Trie<String> fixture = new Trie<String>(); 
    268                 fixture.train(sequence, 2); 
    269  
    270                 final List<String> sequences = new ArrayList<String>(); 
    271                 TrieProcessor<String> processor = new TrieProcessor<String>() { 
    272                     @Override 
    273                     public TrieProcessor.Result process(List<String> sequence, int count) { 
    274                         sequences.add(count + "_" + sequence.toString()); 
    275                         return TrieProcessor.Result.CONTINUE; 
    276                     } 
    277                      
    278                 }; 
    279                  
    280                 fixture.process(processor); 
    281                  
    282                 List<String> expected = new ArrayList<String>(); 
    283                  
    284                 expected.add("5_[a]"); 
    285                 expected.add("2_[a, b]"); 
    286                 expected.add("2_[b]"); 
    287                 expected.add("2_[b, r]"); 
    288                 expected.add("2_[r]"); 
    289                 expected.add("2_[r, a]"); 
    290                 expected.add("1_[a, c]"); 
    291                 expected.add("1_[c]"); 
    292                 expected.add("1_[c, a]"); 
    293                 expected.add("1_[a, d]"); 
    294                 expected.add("1_[d]"); 
    295                 expected.add("1_[d, a]"); 
    296                  
    297                 assertEquals(expected.size(), sequences.size()); 
    298                  
    299                 for (String sequence : sequences) { 
    300                     ListAssert.assertContains(expected, sequence); 
    301                 } 
     299    } 
     300 
     301    @Test 
     302    public void testProcessWithTrieProcessor_2() throws Exception { 
     303        Trie<String> fixture = new Trie<String>(); 
     304        fixture.train(sequence, 3); 
     305 
     306        final List<String> sequences = new ArrayList<String>(); 
     307        TrieProcessor<String> processor = new TrieProcessor<String>() { 
     308            @Override 
     309            public TrieProcessor.Result process(List<String> sequence, int count) { 
     310                sequences.add(count + "_" + sequence.toString()); 
     311                return TrieProcessor.Result.CONTINUE; 
     312            } 
     313 
     314        }; 
     315 
     316        fixture.process(processor); 
     317 
     318        List<String> expected = new ArrayList<String>(); 
     319 
     320        expected.add("5_[a]"); 
     321        expected.add("2_[a, b]"); 
     322        expected.add("2_[a, b, r]"); 
     323        expected.add("2_[b]"); 
     324        expected.add("2_[b, r]"); 
     325        expected.add("2_[b, r, a]"); 
     326        expected.add("2_[r]"); 
     327        expected.add("2_[r, a]"); 
     328        expected.add("1_[r, a, c]"); 
     329        expected.add("1_[a, c]"); 
     330        expected.add("1_[a, c, a]"); 
     331        expected.add("1_[c]"); 
     332        expected.add("1_[c, a]"); 
     333        expected.add("1_[c, a, d]"); 
     334        expected.add("1_[a, d]"); 
     335        expected.add("1_[a, d, a]"); 
     336        expected.add("1_[d]"); 
     337        expected.add("1_[d, a]"); 
     338        expected.add("1_[d, a, b]"); 
     339 
     340        assertEquals(expected.size(), sequences.size()); 
     341 
     342        for (String sequence : sequences) { 
     343            ListAssert.assertContains(expected, sequence); 
    302344        } 
    303  
    304         @Test 
    305         public void testProcessWithTrieProcessor_2() throws Exception { 
    306                 Trie<String> fixture = new Trie<String>(); 
    307                 fixture.train(sequence, 3); 
    308  
    309                 final List<String> sequences = new ArrayList<String>(); 
    310                 TrieProcessor<String> processor = new TrieProcessor<String>() { 
    311                     @Override 
    312                     public TrieProcessor.Result process(List<String> sequence, int count) { 
    313                         sequences.add(count + "_" + sequence.toString()); 
    314                         return TrieProcessor.Result.CONTINUE; 
    315                     } 
    316                      
    317                 }; 
    318                  
    319                 fixture.process(processor); 
    320                  
    321                 List<String> expected = new ArrayList<String>(); 
    322                  
    323                 expected.add("5_[a]"); 
    324                 expected.add("2_[a, b]"); 
    325                 expected.add("2_[a, b, r]"); 
    326                 expected.add("2_[b]"); 
    327                 expected.add("2_[b, r]"); 
    328                 expected.add("2_[b, r, a]"); 
    329                 expected.add("2_[r]"); 
    330                 expected.add("2_[r, a]"); 
    331                 expected.add("1_[r, a, c]"); 
    332                 expected.add("1_[a, c]"); 
    333                 expected.add("1_[a, c, a]"); 
    334                 expected.add("1_[c]"); 
    335                 expected.add("1_[c, a]"); 
    336                 expected.add("1_[c, a, d]"); 
    337                 expected.add("1_[a, d]"); 
    338                 expected.add("1_[a, d, a]"); 
    339                 expected.add("1_[d]"); 
    340                 expected.add("1_[d, a]"); 
    341                 expected.add("1_[d, a, b]"); 
    342                  
    343                 assertEquals(expected.size(), sequences.size()); 
    344                  
    345                 for (String sequence : sequences) { 
    346                     ListAssert.assertContains(expected, sequence); 
    347                 } 
     345    } 
     346 
     347    @Test 
     348    public void testProcessWithTrieProcessor_3() throws Exception { 
     349        Trie<String> fixture = new Trie<String>(); 
     350        fixture.train(sequence, 4); 
     351 
     352        final List<String> sequences = new ArrayList<String>(); 
     353        TrieProcessor<String> processor = new TrieProcessor<String>() { 
     354            @Override 
     355            public TrieProcessor.Result process(List<String> sequence, int count) { 
     356                sequences.add(count + "_" + sequence.toString()); 
     357                return TrieProcessor.Result.CONTINUE; 
     358            } 
     359 
     360        }; 
     361 
     362        fixture.process(processor); 
     363 
     364        List<String> expected = new ArrayList<String>(); 
     365 
     366        expected.add("5_[a]"); 
     367        expected.add("2_[a, b]"); 
     368        expected.add("2_[a, b, r]"); 
     369        expected.add("2_[a, b, r, a]"); 
     370        expected.add("2_[b]"); 
     371        expected.add("2_[b, r]"); 
     372        expected.add("2_[b, r, a]"); 
     373        expected.add("1_[b, r, a, c]"); 
     374        expected.add("2_[r]"); 
     375        expected.add("2_[r, a]"); 
     376        expected.add("1_[r, a, c]"); 
     377        expected.add("1_[r, a, c, a]"); 
     378        expected.add("1_[a, c]"); 
     379        expected.add("1_[a, c, a]"); 
     380        expected.add("1_[a, c, a, d]"); 
     381        expected.add("1_[c]"); 
     382        expected.add("1_[c, a]"); 
     383        expected.add("1_[c, a, d]"); 
     384        expected.add("1_[c, a, d, a]"); 
     385        expected.add("1_[a, d]"); 
     386        expected.add("1_[a, d, a]"); 
     387        expected.add("1_[a, d, a, b]"); 
     388        expected.add("1_[d]"); 
     389        expected.add("1_[d, a]"); 
     390        expected.add("1_[d, a, b]"); 
     391        expected.add("1_[d, a, b, r]"); 
     392 
     393        assertEquals(expected.size(), sequences.size()); 
     394 
     395        for (String sequence : sequences) { 
     396            ListAssert.assertContains(expected, sequence); 
    348397        } 
    349  
    350         @Test 
    351         public void testProcessWithTrieProcessor_3() throws Exception { 
    352                 Trie<String> fixture = new Trie<String>(); 
    353                 fixture.train(sequence, 4); 
    354  
    355                 final List<String> sequences = new ArrayList<String>(); 
    356                 TrieProcessor<String> processor = new TrieProcessor<String>() { 
    357                     @Override 
    358                     public TrieProcessor.Result process(List<String> sequence, int count) { 
    359                         sequences.add(count + "_" + sequence.toString()); 
    360                         return TrieProcessor.Result.CONTINUE; 
    361                     } 
    362                      
    363                 }; 
    364                  
    365                 fixture.process(processor); 
    366                  
    367                 List<String> expected = new ArrayList<String>(); 
    368                  
    369                 expected.add("5_[a]"); 
    370                 expected.add("2_[a, b]"); 
    371                 expected.add("2_[a, b, r]"); 
    372                 expected.add("2_[a, b, r, a]"); 
    373                 expected.add("2_[b]"); 
    374                 expected.add("2_[b, r]"); 
    375                 expected.add("2_[b, r, a]"); 
    376                 expected.add("1_[b, r, a, c]"); 
    377                 expected.add("2_[r]"); 
    378                 expected.add("2_[r, a]"); 
    379                 expected.add("1_[r, a, c]"); 
    380                 expected.add("1_[r, a, c, a]"); 
    381                 expected.add("1_[a, c]"); 
    382                 expected.add("1_[a, c, a]"); 
    383                 expected.add("1_[a, c, a, d]"); 
    384                 expected.add("1_[c]"); 
    385                 expected.add("1_[c, a]"); 
    386                 expected.add("1_[c, a, d]"); 
    387                 expected.add("1_[c, a, d, a]"); 
    388                 expected.add("1_[a, d]"); 
    389                 expected.add("1_[a, d, a]"); 
    390                 expected.add("1_[a, d, a, b]"); 
    391                 expected.add("1_[d]"); 
    392                 expected.add("1_[d, a]"); 
    393                 expected.add("1_[d, a, b]"); 
    394                 expected.add("1_[d, a, b, r]"); 
    395                  
    396                 assertEquals(expected.size(), sequences.size()); 
    397                  
    398                 for (String sequence : sequences) { 
    399                     ListAssert.assertContains(expected, sequence); 
    400                 } 
     398    } 
     399 
     400    @Test 
     401    public void testProcessWithTrieProcessor_4() throws Exception { 
     402        Trie<String> fixture = new Trie<String>(); 
     403        fixture.train(sequence, 5); 
     404 
     405        final List<String> sequences = new ArrayList<String>(); 
     406        TrieProcessor<String> processor = new TrieProcessor<String>() { 
     407            @Override 
     408            public TrieProcessor.Result process(List<String> sequence, int count) { 
     409                sequences.add(count + "_" + sequence.toString()); 
     410                return TrieProcessor.Result.CONTINUE; 
     411            } 
     412 
     413        }; 
     414 
     415        fixture.process(processor); 
     416 
     417        List<String> expected = new ArrayList<String>(); 
     418 
     419        expected.add("5_[a]"); 
     420        expected.add("2_[a, b]"); 
     421        expected.add("2_[a, b, r]"); 
     422        expected.add("2_[a, b, r, a]"); 
     423        expected.add("1_[a, b, r, a, c]"); 
     424        expected.add("2_[b]"); 
     425        expected.add("2_[b, r]"); 
     426        expected.add("2_[b, r, a]"); 
     427        expected.add("1_[b, r, a, c]"); 
     428        expected.add("1_[b, r, a, c, a]"); 
     429        expected.add("2_[r]"); 
     430        expected.add("2_[r, a]"); 
     431        expected.add("1_[r, a, c]"); 
     432        expected.add("1_[r, a, c, a]"); 
     433        expected.add("1_[r, a, c, a, d]"); 
     434        expected.add("1_[a, c]"); 
     435        expected.add("1_[a, c, a]"); 
     436        expected.add("1_[a, c, a, d]"); 
     437        expected.add("1_[a, c, a, d, a]"); 
     438        expected.add("1_[c]"); 
     439        expected.add("1_[c, a]"); 
     440        expected.add("1_[c, a, d]"); 
     441        expected.add("1_[c, a, d, a]"); 
     442        expected.add("1_[c, a, d, a, b]"); 
     443        expected.add("1_[a, d]"); 
     444        expected.add("1_[a, d, a]"); 
     445        expected.add("1_[a, d, a, b]"); 
     446        expected.add("1_[a, d, a, b, r]"); 
     447        expected.add("1_[d]"); 
     448        expected.add("1_[d, a]"); 
     449        expected.add("1_[d, a, b]"); 
     450        expected.add("1_[d, a, b, r]"); 
     451        expected.add("1_[d, a, b, r, a]"); 
     452 
     453        assertEquals(expected.size(), sequences.size()); 
     454 
     455        for (String sequence : sequences) { 
     456            ListAssert.assertContains(expected, sequence); 
    401457        } 
    402  
    403         @Test 
    404         public void testProcessWithTrieProcessor_4() throws Exception { 
    405                 Trie<String> fixture = new Trie<String>(); 
    406                 fixture.train(sequence, 5); 
    407  
    408                 final List<String> sequences = new ArrayList<String>(); 
    409                 TrieProcessor<String> processor = new TrieProcessor<String>() { 
    410                     @Override 
    411                     public TrieProcessor.Result process(List<String> sequence, int count) { 
    412                         sequences.add(count + "_" + sequence.toString()); 
    413                         return TrieProcessor.Result.CONTINUE; 
    414                     } 
    415                      
    416                 }; 
    417                  
    418                 fixture.process(processor); 
    419                  
    420                 List<String> expected = new ArrayList<String>(); 
    421                  
    422                 expected.add("5_[a]"); 
    423                 expected.add("2_[a, b]"); 
    424                 expected.add("2_[a, b, r]"); 
    425                 expected.add("2_[a, b, r, a]"); 
    426                 expected.add("1_[a, b, r, a, c]"); 
    427                 expected.add("2_[b]"); 
    428                 expected.add("2_[b, r]"); 
    429                 expected.add("2_[b, r, a]"); 
    430                 expected.add("1_[b, r, a, c]"); 
    431                 expected.add("1_[b, r, a, c, a]"); 
    432                 expected.add("2_[r]"); 
    433                 expected.add("2_[r, a]"); 
    434                 expected.add("1_[r, a, c]"); 
    435                 expected.add("1_[r, a, c, a]"); 
    436                 expected.add("1_[r, a, c, a, d]"); 
    437                 expected.add("1_[a, c]"); 
    438                 expected.add("1_[a, c, a]"); 
    439                 expected.add("1_[a, c, a, d]"); 
    440                 expected.add("1_[a, c, a, d, a]"); 
    441                 expected.add("1_[c]"); 
    442                 expected.add("1_[c, a]"); 
    443                 expected.add("1_[c, a, d]"); 
    444                 expected.add("1_[c, a, d, a]"); 
    445                 expected.add("1_[c, a, d, a, b]"); 
    446                 expected.add("1_[a, d]"); 
    447                 expected.add("1_[a, d, a]"); 
    448                 expected.add("1_[a, d, a, b]"); 
    449                 expected.add("1_[a, d, a, b, r]"); 
    450                 expected.add("1_[d]"); 
    451                 expected.add("1_[d, a]"); 
    452                 expected.add("1_[d, a, b]"); 
    453                 expected.add("1_[d, a, b, r]"); 
    454                 expected.add("1_[d, a, b, r, a]"); 
    455                  
    456                 assertEquals(expected.size(), sequences.size()); 
    457                  
    458                 for (String sequence : sequences) { 
    459                     ListAssert.assertContains(expected, sequence); 
    460                 } 
     458    } 
     459 
     460    @Test 
     461    public void testProcessWithTrieProcessor_5() throws Exception { 
     462        Trie<String> fixture = new Trie<String>(); 
     463        fixture.train(sequence, 6); 
     464 
     465        final List<String> sequences = new ArrayList<String>(); 
     466        TrieProcessor<String> processor = new TrieProcessor<String>() { 
     467            @Override 
     468            public TrieProcessor.Result process(List<String> sequence, int count) { 
     469                sequences.add(count + "_" + sequence.toString()); 
     470                return TrieProcessor.Result.CONTINUE; 
     471            } 
     472 
     473        }; 
     474 
     475        fixture.process(processor); 
     476 
     477        List<String> expected = new ArrayList<String>(); 
     478 
     479        expected.add("5_[a]"); 
     480        expected.add("2_[a, b]"); 
     481        expected.add("2_[a, b, r]"); 
     482        expected.add("2_[a, b, r, a]"); 
     483        expected.add("1_[a, b, r, a, c]"); 
     484        expected.add("1_[a, b, r, a, c, a]"); 
     485        expected.add("2_[b]"); 
     486        expected.add("2_[b, r]"); 
     487        expected.add("2_[b, r, a]"); 
     488        expected.add("1_[b, r, a, c]"); 
     489        expected.add("1_[b, r, a, c, a]"); 
     490        expected.add("1_[b, r, a, c, a, d]"); 
     491        expected.add("2_[r]"); 
     492        expected.add("2_[r, a]"); 
     493        expected.add("1_[r, a, c]"); 
     494        expected.add("1_[r, a, c, a]"); 
     495        expected.add("1_[r, a, c, a, d]"); 
     496        expected.add("1_[r, a, c, a, d, a]"); 
     497        expected.add("1_[a, c]"); 
     498        expected.add("1_[a, c, a]"); 
     499        expected.add("1_[a, c, a, d]"); 
     500        expected.add("1_[a, c, a, d, a]"); 
     501        expected.add("1_[a, c, a, d, a, b]"); 
     502        expected.add("1_[c]"); 
     503        expected.add("1_[c, a]"); 
     504        expected.add("1_[c, a, d]"); 
     505        expected.add("1_[c, a, d, a]"); 
     506        expected.add("1_[c, a, d, a, b]"); 
     507        expected.add("1_[c, a, d, a, b, r]"); 
     508        expected.add("1_[a, d]"); 
     509        expected.add("1_[a, d, a]"); 
     510        expected.add("1_[a, d, a, b]"); 
     511        expected.add("1_[a, d, a, b, r]"); 
     512        expected.add("1_[a, d, a, b, r, a]"); 
     513        expected.add("1_[d]"); 
     514        expected.add("1_[d, a]"); 
     515        expected.add("1_[d, a, b]"); 
     516        expected.add("1_[d, a, b, r]"); 
     517        expected.add("1_[d, a, b, r, a]"); 
     518 
     519        assertEquals(expected.size(), sequences.size()); 
     520 
     521        for (String sequence : sequences) { 
     522            ListAssert.assertContains(expected, sequence); 
    461523        } 
    462  
    463         @Test 
    464         public void testProcessWithTrieProcessor_5() throws Exception { 
    465                 Trie<String> fixture = new Trie<String>(); 
    466                 fixture.train(sequence, 6); 
    467  
    468                 final List<String> sequences = new ArrayList<String>(); 
    469                 TrieProcessor<String> processor = new TrieProcessor<String>() { 
    470                     @Override 
    471                     public TrieProcessor.Result process(List<String> sequence, int count) { 
    472                         sequences.add(count + "_" + sequence.toString()); 
    473                         return TrieProcessor.Result.CONTINUE; 
    474                     } 
    475                      
    476                 }; 
    477                  
    478                 fixture.process(processor); 
    479                  
    480                 List<String> expected = new ArrayList<String>(); 
    481                  
    482                 expected.add("5_[a]"); 
    483                 expected.add("2_[a, b]"); 
    484                 expected.add("2_[a, b, r]"); 
    485                 expected.add("2_[a, b, r, a]"); 
    486                 expected.add("1_[a, b, r, a, c]"); 
    487                 expected.add("1_[a, b, r, a, c, a]"); 
    488                 expected.add("2_[b]"); 
    489                 expected.add("2_[b, r]"); 
    490                 expected.add("2_[b, r, a]"); 
    491                 expected.add("1_[b, r, a, c]"); 
    492                 expected.add("1_[b, r, a, c, a]"); 
    493                 expected.add("1_[b, r, a, c, a, d]"); 
    494                 expected.add("2_[r]"); 
    495                 expected.add("2_[r, a]"); 
    496                 expected.add("1_[r, a, c]"); 
    497                 expected.add("1_[r, a, c, a]"); 
    498                 expected.add("1_[r, a, c, a, d]"); 
    499                 expected.add("1_[r, a, c, a, d, a]"); 
    500                 expected.add("1_[a, c]"); 
    501                 expected.add("1_[a, c, a]"); 
    502                 expected.add("1_[a, c, a, d]"); 
    503                 expected.add("1_[a, c, a, d, a]"); 
    504                 expected.add("1_[a, c, a, d, a, b]"); 
    505                 expected.add("1_[c]"); 
    506                 expected.add("1_[c, a]"); 
    507                 expected.add("1_[c, a, d]"); 
    508                 expected.add("1_[c, a, d, a]"); 
    509                 expected.add("1_[c, a, d, a, b]"); 
    510                 expected.add("1_[c, a, d, a, b, r]"); 
    511                 expected.add("1_[a, d]"); 
    512                 expected.add("1_[a, d, a]"); 
    513                 expected.add("1_[a, d, a, b]"); 
    514                 expected.add("1_[a, d, a, b, r]"); 
    515                 expected.add("1_[a, d, a, b, r, a]"); 
    516                 expected.add("1_[d]"); 
    517                 expected.add("1_[d, a]"); 
    518                 expected.add("1_[d, a, b]"); 
    519                 expected.add("1_[d, a, b, r]"); 
    520                 expected.add("1_[d, a, b, r, a]"); 
    521                  
    522                 assertEquals(expected.size(), sequences.size()); 
    523                  
    524                 for (String sequence : sequences) { 
    525                     ListAssert.assertContains(expected, sequence); 
    526                 } 
     524    } 
     525 
     526    @Test 
     527    public void testProcessWithTrieProcessor_6() throws Exception { 
     528        Trie<String> fixture = new Trie<String>(); 
     529        fixture.train(sequence, 7); 
     530 
     531        final List<String> sequences = new ArrayList<String>(); 
     532        TrieProcessor<String> processor = new TrieProcessor<String>() { 
     533            @Override 
     534            public TrieProcessor.Result process(List<String> sequence, int count) { 
     535                sequences.add(count + "_" + sequence.toString()); 
     536                return TrieProcessor.Result.CONTINUE; 
     537            } 
     538 
     539        }; 
     540 
     541        fixture.process(processor); 
     542 
     543        List<String> expected = new ArrayList<String>(); 
     544 
     545        expected.add("5_[a]"); 
     546        expected.add("2_[a, b]"); 
     547        expected.add("2_[a, b, r]"); 
     548        expected.add("2_[a, b, r, a]"); 
     549        expected.add("1_[a, b, r, a, c]"); 
     550        expected.add("1_[a, b, r, a, c, a]"); 
     551        expected.add("1_[a, b, r, a, c, a, d]"); 
     552        expected.add("2_[b]"); 
     553        expected.add("2_[b, r]"); 
     554        expected.add("2_[b, r, a]"); 
     555        expected.add("1_[b, r, a, c]"); 
     556        expected.add("1_[b, r, a, c, a]"); 
     557        expected.add("1_[b, r, a, c, a, d]"); 
     558        expected.add("1_[b, r, a, c, a, d, a]"); 
     559        expected.add("2_[r]"); 
     560        expected.add("2_[r, a]"); 
     561        expected.add("1_[r, a, c]"); 
     562        expected.add("1_[r, a, c, a]"); 
     563        expected.add("1_[r, a, c, a, d]"); 
     564        expected.add("1_[r, a, c, a, d, a]"); 
     565        expected.add("1_[r, a, c, a, d, a, b]"); 
     566        expected.add("1_[a, c]"); 
     567        expected.add("1_[a, c, a]"); 
     568        expected.add("1_[a, c, a, d]"); 
     569        expected.add("1_[a, c, a, d, a]"); 
     570        expected.add("1_[a, c, a, d, a, b]"); 
     571        expected.add("1_[a, c, a, d, a, b, r]"); 
     572        expected.add("1_[c]"); 
     573        expected.add("1_[c, a]"); 
     574        expected.add("1_[c, a, d]"); 
     575        expected.add("1_[c, a, d, a]"); 
     576        expected.add("1_[c, a, d, a, b]"); 
     577        expected.add("1_[c, a, d, a, b, r]"); 
     578        expected.add("1_[c, a, d, a, b, r, a]"); 
     579        expected.add("1_[a, d]"); 
     580        expected.add("1_[a, d, a]"); 
     581        expected.add("1_[a, d, a, b]"); 
     582        expected.add("1_[a, d, a, b, r]"); 
     583        expected.add("1_[a, d, a, b, r, a]"); 
     584        expected.add("1_[d]"); 
     585        expected.add("1_[d, a]"); 
     586        expected.add("1_[d, a, b]"); 
     587        expected.add("1_[d, a, b, r]"); 
     588        expected.add("1_[d, a, b, r, a]"); 
     589 
     590        assertEquals(expected.size(), sequences.size()); 
     591 
     592        for (String sequence : sequences) { 
     593            ListAssert.assertContains(expected, sequence); 
    527594        } 
    528  
    529         @Test 
    530         public void testProcessWithTrieProcessor_6() throws Exception { 
    531                 Trie<String> fixture = new Trie<String>(); 
    532                 fixture.train(sequence, 7); 
    533  
    534                 final List<String> sequences = new ArrayList<String>(); 
    535                 TrieProcessor<String> processor = new TrieProcessor<String>() { 
    536                     @Override 
    537                     public TrieProcessor.Result process(List<String> sequence, int count) { 
    538                         sequences.add(count + "_" + sequence.toString()); 
    539                         return TrieProcessor.Result.CONTINUE; 
    540                     } 
    541                      
    542                 }; 
    543                  
    544                 fixture.process(processor); 
    545                  
    546                 List<String> expected = new ArrayList<String>(); 
    547                  
    548                 expected.add("5_[a]"); 
    549                 expected.add("2_[a, b]"); 
    550                 expected.add("2_[a, b, r]"); 
    551                 expected.add("2_[a, b, r, a]"); 
    552                 expected.add("1_[a, b, r, a, c]"); 
    553                 expected.add("1_[a, b, r, a, c, a]"); 
    554                 expected.add("1_[a, b, r, a, c, a, d]"); 
    555                 expected.add("2_[b]"); 
    556                 expected.add("2_[b, r]"); 
    557                 expected.add("2_[b, r, a]"); 
    558                 expected.add("1_[b, r, a, c]"); 
    559                 expected.add("1_[b, r, a, c, a]"); 
    560                 expected.add("1_[b, r, a, c, a, d]"); 
    561                 expected.add("1_[b, r, a, c, a, d, a]"); 
    562                 expected.add("2_[r]"); 
    563                 expected.add("2_[r, a]"); 
    564                 expected.add("1_[r, a, c]"); 
    565                 expected.add("1_[r, a, c, a]"); 
    566                 expected.add("1_[r, a, c, a, d]"); 
    567                 expected.add("1_[r, a, c, a, d, a]"); 
    568                 expected.add("1_[r, a, c, a, d, a, b]"); 
    569                 expected.add("1_[a, c]"); 
    570                 expected.add("1_[a, c, a]"); 
    571                 expected.add("1_[a, c, a, d]"); 
    572                 expected.add("1_[a, c, a, d, a]"); 
    573                 expected.add("1_[a, c, a, d, a, b]"); 
    574                 expected.add("1_[a, c, a, d, a, b, r]"); 
    575                 expected.add("1_[c]"); 
    576                 expected.add("1_[c, a]"); 
    577                 expected.add("1_[c, a, d]"); 
    578                 expected.add("1_[c, a, d, a]"); 
    579                 expected.add("1_[c, a, d, a, b]"); 
    580                 expected.add("1_[c, a, d, a, b, r]"); 
    581                 expected.add("1_[c, a, d, a, b, r, a]"); 
    582                 expected.add("1_[a, d]"); 
    583                 expected.add("1_[a, d, a]"); 
    584                 expected.add("1_[a, d, a, b]"); 
    585                 expected.add("1_[a, d, a, b, r]"); 
    586                 expected.add("1_[a, d, a, b, r, a]"); 
    587                 expected.add("1_[d]"); 
    588                 expected.add("1_[d, a]"); 
    589                 expected.add("1_[d, a, b]"); 
    590                 expected.add("1_[d, a, b, r]"); 
    591                 expected.add("1_[d, a, b, r, a]"); 
    592                  
    593                 assertEquals(expected.size(), sequences.size()); 
    594                  
    595                 for (String sequence : sequences) { 
    596                     ListAssert.assertContains(expected, sequence); 
    597                 } 
     595    } 
     596 
     597    @Test 
     598    public void testProcessWithTrieProcessor_7() throws Exception { 
     599        Trie<String> fixture = new Trie<String>(); 
     600        fixture.train(sequence, 8); 
     601 
     602        final List<String> sequences = new ArrayList<String>(); 
     603        TrieProcessor<String> processor = new TrieProcessor<String>() { 
     604            @Override 
     605            public TrieProcessor.Result process(List<String> sequence, int count) { 
     606                sequences.add(count + "_" + sequence.toString()); 
     607                return TrieProcessor.Result.CONTINUE; 
     608            } 
     609 
     610        }; 
     611 
     612        fixture.process(processor); 
     613 
     614        List<String> expected = new ArrayList<String>(); 
     615 
     616        expected.add("5_[a]"); 
     617        expected.add("2_[a, b]"); 
     618        expected.add("2_[a, b, r]"); 
     619        expected.add("2_[a, b, r, a]"); 
     620        expected.add("1_[a, b, r, a, c]"); 
     621        expected.add("1_[a, b, r, a, c, a]"); 
     622        expected.add("1_[a, b, r, a, c, a, d]"); 
     623        expected.add("1_[a, b, r, a, c, a, d, a]"); 
     624        expected.add("2_[b]"); 
     625        expected.add("2_[b, r]"); 
     626        expected.add("2_[b, r, a]"); 
     627        expected.add("1_[b, r, a, c]"); 
     628        expected.add("1_[b, r, a, c, a]"); 
     629        expected.add("1_[b, r, a, c, a, d]"); 
     630        expected.add("1_[b, r, a, c, a, d, a]"); 
     631        expected.add("1_[b, r, a, c, a, d, a, b]"); 
     632        expected.add("2_[r]"); 
     633        expected.add("2_[r, a]"); 
     634        expected.add("1_[r, a, c]"); 
     635        expected.add("1_[r, a, c, a]"); 
     636        expected.add("1_[r, a, c, a, d]"); 
     637        expected.add("1_[r, a, c, a, d, a]"); 
     638        expected.add("1_[r, a, c, a, d, a, b]"); 
     639        expected.add("1_[r, a, c, a, d, a, b, r]"); 
     640        expected.add("1_[a, c]"); 
     641        expected.add("1_[a, c, a]"); 
     642        expected.add("1_[a, c, a, d]"); 
     643        expected.add("1_[a, c, a, d, a]"); 
     644        expected.add("1_[a, c, a, d, a, b]"); 
     645        expected.add("1_[a, c, a, d, a, b, r]"); 
     646        expected.add("1_[a, c, a, d, a, b, r, a]"); 
     647        expected.add("1_[c]"); 
     648        expected.add("1_[c, a]"); 
     649        expected.add("1_[c, a, d]"); 
     650        expected.add("1_[c, a, d, a]"); 
     651        expected.add("1_[c, a, d, a, b]"); 
     652        expected.add("1_[c, a, d, a, b, r]"); 
     653        expected.add("1_[c, a, d, a, b, r, a]"); 
     654        expected.add("1_[a, d]"); 
     655        expected.add("1_[a, d, a]"); 
     656        expected.add("1_[a, d, a, b]"); 
     657        expected.add("1_[a, d, a, b, r]"); 
     658        expected.add("1_[a, d, a, b, r, a]"); 
     659        expected.add("1_[d]"); 
     660        expected.add("1_[d, a]"); 
     661        expected.add("1_[d, a, b]"); 
     662        expected.add("1_[d, a, b, r]"); 
     663        expected.add("1_[d, a, b, r, a]"); 
     664 
     665        assertEquals(expected.size(), sequences.size()); 
     666 
     667        for (String sequence : sequences) { 
     668            ListAssert.assertContains(expected, sequence); 
    598669        } 
    599  
    600         @Test 
    601         public void testProcessWithTrieProcessor_7() throws Exception { 
    602                 Trie<String> fixture = new Trie<String>(); 
    603                 fixture.train(sequence, 8); 
    604  
    605                 final List<String> sequences = new ArrayList<String>(); 
    606                 TrieProcessor<String> processor = new TrieProcessor<String>() { 
    607                     @Override 
    608                     public TrieProcessor.Result process(List<String> sequence, int count) { 
    609                         sequences.add(count + "_" + sequence.toString()); 
    610                         return TrieProcessor.Result.CONTINUE; 
    611                     } 
    612                      
    613                 }; 
    614                  
    615                 fixture.process(processor); 
    616                  
    617                 List<String> expected = new ArrayList<String>(); 
    618                  
    619                 expected.add("5_[a]"); 
    620                 expected.add("2_[a, b]"); 
    621                 expected.add("2_[a, b, r]"); 
    622                 expected.add("2_[a, b, r, a]"); 
    623                 expected.add("1_[a, b, r, a, c]"); 
    624                 expected.add("1_[a, b, r, a, c, a]"); 
    625                 expected.add("1_[a, b, r, a, c, a, d]"); 
    626                 expected.add("1_[a, b, r, a, c, a, d, a]"); 
    627                 expected.add("2_[b]"); 
    628                 expected.add("2_[b, r]"); 
    629                 expected.add("2_[b, r, a]"); 
    630                 expected.add("1_[b, r, a, c]"); 
    631                 expected.add("1_[b, r, a, c, a]"); 
    632                 expected.add("1_[b, r, a, c, a, d]"); 
    633                 expected.add("1_[b, r, a, c, a, d, a]"); 
    634                 expected.add("1_[b, r, a, c, a, d, a, b]"); 
    635                 expected.add("2_[r]"); 
    636                 expected.add("2_[r, a]"); 
    637                 expected.add("1_[r, a, c]"); 
    638                 expected.add("1_[r, a, c, a]"); 
    639                 expected.add("1_[r, a, c, a, d]"); 
    640                 expected.add("1_[r, a, c, a, d, a]"); 
    641                 expected.add("1_[r, a, c, a, d, a, b]"); 
    642                 expected.add("1_[r, a, c, a, d, a, b, r]"); 
    643                 expected.add("1_[a, c]"); 
    644                 expected.add("1_[a, c, a]"); 
    645                 expected.add("1_[a, c, a, d]"); 
    646                 expected.add("1_[a, c, a, d, a]"); 
    647                 expected.add("1_[a, c, a, d, a, b]"); 
    648                 expected.add("1_[a, c, a, d, a, b, r]"); 
    649                 expected.add("1_[a, c, a, d, a, b, r, a]"); 
    650                 expected.add("1_[c]"); 
    651                 expected.add("1_[c, a]"); 
    652                 expected.add("1_[c, a, d]"); 
    653                 expected.add("1_[c, a, d, a]"); 
    654                 expected.add("1_[c, a, d, a, b]"); 
    655                 expected.add("1_[c, a, d, a, b, r]"); 
    656                 expected.add("1_[c, a, d, a, b, r, a]"); 
    657                 expected.add("1_[a, d]"); 
    658                 expected.add("1_[a, d, a]"); 
    659                 expected.add("1_[a, d, a, b]"); 
    660                 expected.add("1_[a, d, a, b, r]"); 
    661                 expected.add("1_[a, d, a, b, r, a]"); 
    662                 expected.add("1_[d]"); 
    663                 expected.add("1_[d, a]"); 
    664                 expected.add("1_[d, a, b]"); 
    665                 expected.add("1_[d, a, b, r]"); 
    666                 expected.add("1_[d, a, b, r, a]"); 
    667                  
    668                 assertEquals(expected.size(), sequences.size()); 
    669                  
    670                 for (String sequence : sequences) { 
    671                     ListAssert.assertContains(expected, sequence); 
    672                 } 
     670    } 
     671 
     672    @Test 
     673    public void testProcessWithTrieProcessor_8() throws Exception { 
     674        Trie<String> fixture = new Trie<String>(); 
     675        fixture.train(sequence, 9); 
     676 
     677        final List<String> sequences = new ArrayList<String>(); 
     678        TrieProcessor<String> processor = new TrieProcessor<String>() { 
     679            @Override 
     680            public TrieProcessor.Result process(List<String> sequence, int count) { 
     681                sequences.add(count + "_" + sequence.toString()); 
     682                return TrieProcessor.Result.CONTINUE; 
     683            } 
     684 
     685        }; 
     686 
     687        fixture.process(processor); 
     688 
     689        List<String> expected = new ArrayList<String>(); 
     690 
     691        expected.add("5_[a]"); 
     692        expected.add("2_[a, b]"); 
     693        expected.add("2_[a, b, r]"); 
     694        expected.add("2_[a, b, r, a]"); 
     695        expected.add("1_[a, b, r, a, c]"); 
     696        expected.add("1_[a, b, r, a, c, a]"); 
     697        expected.add("1_[a, b, r, a, c, a, d]"); 
     698        expected.add("1_[a, b, r, a, c, a, d, a]"); 
     699        expected.add("1_[a, b, r, a, c, a, d, a, b]"); 
     700        expected.add("2_[b]"); 
     701        expected.add("2_[b, r]"); 
     702        expected.add("2_[b, r, a]"); 
     703        expected.add("1_[b, r, a, c]"); 
     704        expected.add("1_[b, r, a, c, a]"); 
     705        expected.add("1_[b, r, a, c, a, d]"); 
     706        expected.add("1_[b, r, a, c, a, d, a]"); 
     707        expected.add("1_[b, r, a, c, a, d, a, b]"); 
     708        expected.add("1_[b, r, a, c, a, d, a, b, r]"); 
     709        expected.add("2_[r]"); 
     710        expected.add("2_[r, a]"); 
     711        expected.add("1_[r, a, c]"); 
     712        expected.add("1_[r, a, c, a]"); 
     713        expected.add("1_[r, a, c, a, d]"); 
     714        expected.add("1_[r, a, c, a, d, a]"); 
     715        expected.add("1_[r, a, c, a, d, a, b]"); 
     716        expected.add("1_[r, a, c, a, d, a, b, r]"); 
     717        expected.add("1_[r, a, c, a, d, a, b, r, a]"); 
     718        expected.add("1_[a, c]"); 
     719        expected.add("1_[a, c, a]"); 
     720        expected.add("1_[a, c, a, d]"); 
     721        expected.add("1_[a, c, a, d, a]"); 
     722        expected.add("1_[a, c, a, d, a, b]"); 
     723        expected.add("1_[a, c, a, d, a, b, r]"); 
     724        expected.add("1_[a, c, a, d, a, b, r, a]"); 
     725        expected.add("1_[c]"); 
     726        expected.add("1_[c, a]"); 
     727        expected.add("1_[c, a, d]"); 
     728        expected.add("1_[c, a, d, a]"); 
     729        expected.add("1_[c, a, d, a, b]"); 
     730        expected.add("1_[c, a, d, a, b, r]"); 
     731        expected.add("1_[c, a, d, a, b, r, a]"); 
     732        expected.add("1_[a, d]"); 
     733        expected.add("1_[a, d, a]"); 
     734        expected.add("1_[a, d, a, b]"); 
     735        expected.add("1_[a, d, a, b, r]"); 
     736        expected.add("1_[a, d, a, b, r, a]"); 
     737        expected.add("1_[d]"); 
     738        expected.add("1_[d, a]"); 
     739        expected.add("1_[d, a, b]"); 
     740        expected.add("1_[d, a, b, r]"); 
     741        expected.add("1_[d, a, b, r, a]"); 
     742 
     743        assertEquals(expected.size(), sequences.size()); 
     744 
     745        for (String sequence : sequences) { 
     746            ListAssert.assertContains(expected, sequence); 
    673747        } 
    674  
    675         @Test 
    676         public void testProcessWithTrieProcessor_8() throws Exception { 
    677                 Trie<String> fixture = new Trie<String>(); 
    678                 fixture.train(sequence, 9); 
    679  
    680                 final List<String> sequences = new ArrayList<String>(); 
    681                 TrieProcessor<String> processor = new TrieProcessor<String>() { 
    682                     @Override 
    683                     public TrieProcessor.Result process(List<String> sequence, int count) { 
    684                         sequences.add(count + "_" + sequence.toString()); 
    685                         return TrieProcessor.Result.CONTINUE; 
    686                     } 
    687                      
    688                 }; 
    689                  
    690                 fixture.process(processor); 
    691                  
    692                 List<String> expected = new ArrayList<String>(); 
    693                  
    694                 expected.add("5_[a]"); 
    695                 expected.add("2_[a, b]"); 
    696                 expected.add("2_[a, b, r]"); 
    697                 expected.add("2_[a, b, r, a]"); 
    698                 expected.add("1_[a, b, r, a, c]"); 
    699                 expected.add("1_[a, b, r, a, c, a]"); 
    700                 expected.add("1_[a, b, r, a, c, a, d]"); 
    701                 expected.add("1_[a, b, r, a, c, a, d, a]"); 
    702                 expected.add("1_[a, b, r, a, c, a, d, a, b]"); 
    703                 expected.add("2_[b]"); 
    704                 expected.add("2_[b, r]"); 
    705                 expected.add("2_[b, r, a]"); 
    706                 expected.add("1_[b, r, a, c]"); 
    707                 expected.add("1_[b, r, a, c, a]"); 
    708                 expected.add("1_[b, r, a, c, a, d]"); 
    709                 expected.add("1_[b, r, a, c, a, d, a]"); 
    710                 expected.add("1_[b, r, a, c, a, d, a, b]"); 
    711                 expected.add("1_[b, r, a, c, a, d, a, b, r]"); 
    712                 expected.add("2_[r]"); 
    713                 expected.add("2_[r, a]"); 
    714                 expected.add("1_[r, a, c]"); 
    715                 expected.add("1_[r, a, c, a]"); 
    716                 expected.add("1_[r, a, c, a, d]"); 
    717                 expected.add("1_[r, a, c, a, d, a]"); 
    718                 expected.add("1_[r, a, c, a, d, a, b]"); 
    719                 expected.add("1_[r, a, c, a, d, a, b, r]"); 
    720                 expected.add("1_[r, a, c, a, d, a, b, r, a]"); 
    721                 expected.add("1_[a, c]"); 
    722                 expected.add("1_[a, c, a]"); 
    723                 expected.add("1_[a, c, a, d]"); 
    724                 expected.add("1_[a, c, a, d, a]"); 
    725                 expected.add("1_[a, c, a, d, a, b]"); 
    726                 expected.add("1_[a, c, a, d, a, b, r]"); 
    727                 expected.add("1_[a, c, a, d, a, b, r, a]"); 
    728                 expected.add("1_[c]"); 
    729                 expected.add("1_[c, a]"); 
    730                 expected.add("1_[c, a, d]"); 
    731                 expected.add("1_[c, a, d, a]"); 
    732                 expected.add("1_[c, a, d, a, b]"); 
    733                 expected.add("1_[c, a, d, a, b, r]"); 
    734                 expected.add("1_[c, a, d, a, b, r, a]"); 
    735                 expected.add("1_[a, d]"); 
    736                 expected.add("1_[a, d, a]"); 
    737                 expected.add("1_[a, d, a, b]"); 
    738                 expected.add("1_[a, d, a, b, r]"); 
    739                 expected.add("1_[a, d, a, b, r, a]"); 
    740                 expected.add("1_[d]"); 
    741                 expected.add("1_[d, a]"); 
    742                 expected.add("1_[d, a, b]"); 
    743                 expected.add("1_[d, a, b, r]"); 
    744                 expected.add("1_[d, a, b, r, a]"); 
    745                  
    746                 assertEquals(expected.size(), sequences.size()); 
    747                  
    748                 for (String sequence : sequences) { 
    749                     ListAssert.assertContains(expected, sequence); 
    750                 } 
     748    } 
     749 
     750    @Test 
     751    public void testProcessWithTrieProcessor_9() throws Exception { 
     752        Trie<String> fixture = new Trie<String>(); 
     753        fixture.train(sequence, 10); 
     754 
     755        final List<String> sequences = new ArrayList<String>(); 
     756        TrieProcessor<String> processor = new TrieProcessor<String>() { 
     757            @Override 
     758            public TrieProcessor.Result process(List<String> sequence, int count) { 
     759                sequences.add(count + "_" + sequence.toString()); 
     760                return TrieProcessor.Result.CONTINUE; 
     761            } 
     762 
     763        }; 
     764 
     765        fixture.process(processor); 
     766 
     767        List<String> expected = new ArrayList<String>(); 
     768 
     769        expected.add("5_[a]"); 
     770        expected.add("2_[a, b]"); 
     771        expected.add("2_[a, b, r]"); 
     772        expected.add("2_[a, b, r, a]"); 
     773        expected.add("1_[a, b, r, a, c]"); 
     774        expected.add("1_[a, b, r, a, c, a]"); 
     775        expected.add("1_[a, b, r, a, c, a, d]"); 
     776        expected.add("1_[a, b, r, a, c, a, d, a]"); 
     777        expected.add("1_[a, b, r, a, c, a, d, a, b]"); 
     778        expected.add("1_[a, b, r, a, c, a, d, a, b, r]"); 
     779        expected.add("2_[b]"); 
     780        expected.add("2_[b, r]"); 
     781        expected.add("2_[b, r, a]"); 
     782        expected.add("1_[b, r, a, c]"); 
     783        expected.add("1_[b, r, a, c, a]"); 
     784        expected.add("1_[b, r, a, c, a, d]"); 
     785        expected.add("1_[b, r, a, c, a, d, a]"); 
     786        expected.add("1_[b, r, a, c, a, d, a, b]"); 
     787        expected.add("1_[b, r, a, c, a, d, a, b, r]"); 
     788        expected.add("1_[b, r, a, c, a, d, a, b, r, a]"); 
     789        expected.add("2_[r]"); 
     790        expected.add("2_[r, a]"); 
     791        expected.add("1_[r, a, c]"); 
     792        expected.add("1_[r, a, c, a]"); 
     793        expected.add("1_[r, a, c, a, d]"); 
     794        expected.add("1_[r, a, c, a, d, a]"); 
     795        expected.add("1_[r, a, c, a, d, a, b]"); 
     796        expected.add("1_[r, a, c, a, d, a, b, r]"); 
     797        expected.add("1_[r, a, c, a, d, a, b, r, a]"); 
     798        expected.add("1_[a, c]"); 
     799        expected.add("1_[a, c, a]"); 
     800        expected.add("1_[a, c, a, d]"); 
     801        expected.add("1_[a, c, a, d, a]"); 
     802        expected.add("1_[a, c, a, d, a, b]"); 
     803        expected.add("1_[a, c, a, d, a, b, r]"); 
     804        expected.add("1_[a, c, a, d, a, b, r, a]"); 
     805        expected.add("1_[c]"); 
     806        expected.add("1_[c, a]"); 
     807        expected.add("1_[c, a, d]"); 
     808        expected.add("1_[c, a, d, a]"); 
     809        expected.add("1_[c, a, d, a, b]"); 
     810        expected.add("1_[c, a, d, a, b, r]"); 
     811        expected.add("1_[c, a, d, a, b, r, a]"); 
     812        expected.add("1_[a, d]"); 
     813        expected.add("1_[a, d, a]"); 
     814        expected.add("1_[a, d, a, b]"); 
     815        expected.add("1_[a, d, a, b, r]"); 
     816        expected.add("1_[a, d, a, b, r, a]"); 
     817        expected.add("1_[d]"); 
     818        expected.add("1_[d, a]"); 
     819        expected.add("1_[d, a, b]"); 
     820        expected.add("1_[d, a, b, r]"); 
     821        expected.add("1_[d, a, b, r, a]"); 
     822 
     823        assertEquals(expected.size(), sequences.size()); 
     824 
     825        for (String sequence : sequences) { 
     826            ListAssert.assertContains(expected, sequence); 
    751827        } 
    752  
    753         @Test 
    754         public void testProcessWithTrieProcessor_9() throws Exception { 
    755                 Trie<String> fixture = new Trie<String>(); 
    756                 fixture.train(sequence, 10); 
    757  
    758                 final List<String> sequences = new ArrayList<String>(); 
    759                 TrieProcessor<String> processor = new TrieProcessor<String>() { 
    760                     @Override 
    761                     public TrieProcessor.Result process(List<String> sequence, int count) { 
    762                         sequences.add(count + "_" + sequence.toString()); 
    763                         return TrieProcessor.Result.CONTINUE; 
    764                     } 
    765                      
    766                 }; 
    767                  
    768                 fixture.process(processor); 
    769                  
    770                 List<String> expected = new ArrayList<String>(); 
    771                  
    772                 expected.add("5_[a]"); 
    773                 expected.add("2_[a, b]"); 
    774                 expected.add("2_[a, b, r]"); 
    775                 expected.add("2_[a, b, r, a]"); 
    776                 expected.add("1_[a, b, r, a, c]"); 
    777                 expected.add("1_[a, b, r, a, c, a]"); 
    778                 expected.add("1_[a, b, r, a, c, a, d]"); 
    779                 expected.add("1_[a, b, r, a, c, a, d, a]"); 
    780                 expected.add("1_[a, b, r, a, c, a, d, a, b]"); 
    781                 expected.add("1_[a, b, r, a, c, a, d, a, b, r]"); 
    782                 expected.add("2_[b]"); 
    783                 expected.add("2_[b, r]"); 
    784                 expected.add("2_[b, r, a]"); 
    785                 expected.add("1_[b, r, a, c]"); 
    786                 expected.add("1_[b, r, a, c, a]"); 
    787                 expected.add("1_[b, r, a, c, a, d]"); 
    788                 expected.add("1_[b, r, a, c, a, d, a]"); 
    789                 expected.add("1_[b, r, a, c, a, d, a, b]"); 
    790                 expected.add("1_[b, r, a, c, a, d, a, b, r]"); 
    791                 expected.add("1_[b, r, a, c, a, d, a, b, r, a]"); 
    792                 expected.add("2_[r]"); 
    793                 expected.add("2_[r, a]"); 
    794                 expected.add("1_[r, a, c]"); 
    795                 expected.add("1_[r, a, c, a]"); 
    796                 expected.add("1_[r, a, c, a, d]"); 
    797                 expected.add("1_[r, a, c, a, d, a]"); 
    798                 expected.add("1_[r, a, c, a, d, a, b]"); 
    799                 expected.add("1_[r, a, c, a, d, a, b, r]"); 
    800                 expected.add("1_[r, a, c, a, d, a, b, r, a]"); 
    801                 expected.add("1_[a, c]"); 
    802                 expected.add("1_[a, c, a]"); 
    803                 expected.add("1_[a, c, a, d]"); 
    804                 expected.add("1_[a, c, a, d, a]"); 
    805                 expected.add("1_[a, c, a, d, a, b]"); 
    806                 expected.add("1_[a, c, a, d, a, b, r]"); 
    807                 expected.add("1_[a, c, a, d, a, b, r, a]"); 
    808                 expected.add("1_[c]"); 
    809                 expected.add("1_[c, a]"); 
    810                 expected.add("1_[c, a, d]"); 
    811                 expected.add("1_[c, a, d, a]"); 
    812                 expected.add("1_[c, a, d, a, b]"); 
    813                 expected.add("1_[c, a, d, a, b, r]"); 
    814                 expected.add("1_[c, a, d, a, b, r, a]"); 
    815                 expected.add("1_[a, d]"); 
    816                 expected.add("1_[a, d, a]"); 
    817                 expected.add("1_[a, d, a, b]"); 
    818                 expected.add("1_[a, d, a, b, r]"); 
    819                 expected.add("1_[a, d, a, b, r, a]"); 
    820                 expected.add("1_[d]"); 
    821                 expected.add("1_[d, a]"); 
    822                 expected.add("1_[d, a, b]"); 
    823                 expected.add("1_[d, a, b, r]"); 
    824                 expected.add("1_[d, a, b, r, a]"); 
    825                  
    826                 assertEquals(expected.size(), sequences.size()); 
    827                  
    828                 for (String sequence : sequences) { 
    829                     ListAssert.assertContains(expected, sequence); 
    830                 } 
     828    } 
     829 
     830    @Test 
     831    public void testProcessWithTrieProcessor_10() throws Exception { 
     832        Trie<String> fixture = new Trie<String>(); 
     833        fixture.train(sequence, 11); 
     834 
     835        final List<String> sequences = new ArrayList<String>(); 
     836        TrieProcessor<String> processor = new TrieProcessor<String>() { 
     837            @Override 
     838            public TrieProcessor.Result process(List<String> sequence, int count) { 
     839                sequences.add(count + "_" + sequence.toString()); 
     840                return TrieProcessor.Result.CONTINUE; 
     841            } 
     842 
     843        }; 
     844 
     845        fixture.process(processor); 
     846 
     847        List<String> expected = new ArrayList<String>(); 
     848 
     849        expected.add("5_[a]"); 
     850        expected.add("2_[a, b]"); 
     851        expected.add("2_[a, b, r]"); 
     852        expected.add("2_[a, b, r, a]"); 
     853        expected.add("1_[a, b, r, a, c]"); 
     854        expected.add("1_[a, b, r, a, c, a]"); 
     855        expected.add("1_[a, b, r, a, c, a, d]"); 
     856        expected.add("1_[a, b, r, a, c, a, d, a]"); 
     857        expected.add("1_[a, b, r, a, c, a, d, a, b]"); 
     858        expected.add("1_[a, b, r, a, c, a, d, a, b, r]"); 
     859        expected.add("1_[a, b, r, a, c, a, d, a, b, r, a]"); 
     860        expected.add("2_[b]"); 
     861        expected.add("2_[b, r]"); 
     862        expected.add("2_[b, r, a]"); 
     863        expected.add("1_[b, r, a, c]"); 
     864        expected.add("1_[b, r, a, c, a]"); 
     865        expected.add("1_[b, r, a, c, a, d]"); 
     866        expected.add("1_[b, r, a, c, a, d, a]"); 
     867        expected.add("1_[b, r, a, c, a, d, a, b]"); 
     868        expected.add("1_[b, r, a, c, a, d, a, b, r]"); 
     869        expected.add("1_[b, r, a, c, a, d, a, b, r, a]"); 
     870        expected.add("2_[r]"); 
     871        expected.add("2_[r, a]"); 
     872        expected.add("1_[r, a, c]"); 
     873        expected.add("1_[r, a, c, a]"); 
     874        expected.add("1_[r, a, c, a, d]"); 
     875        expected.add("1_[r, a, c, a, d, a]"); 
     876        expected.add("1_[r, a, c, a, d, a, b]"); 
     877        expected.add("1_[r, a, c, a, d, a, b, r]"); 
     878        expected.add("1_[r, a, c, a, d, a, b, r, a]"); 
     879        expected.add("1_[a, c]"); 
     880        expected.add("1_[a, c, a]"); 
     881        expected.add("1_[a, c, a, d]"); 
     882        expected.add("1_[a, c, a, d, a]"); 
     883        expected.add("1_[a, c, a, d, a, b]"); 
     884        expected.add("1_[a, c, a, d, a, b, r]"); 
     885        expected.add("1_[a, c, a, d, a, b, r, a]"); 
     886        expected.add("1_[c]"); 
     887        expected.add("1_[c, a]"); 
     888        expected.add("1_[c, a, d]"); 
     889        expected.add("1_[c, a, d, a]"); 
     890        expected.add("1_[c, a, d, a, b]"); 
     891        expected.add("1_[c, a, d, a, b, r]"); 
     892        expected.add("1_[c, a, d, a, b, r, a]"); 
     893        expected.add("1_[a, d]"); 
     894        expected.add("1_[a, d, a]"); 
     895        expected.add("1_[a, d, a, b]"); 
     896        expected.add("1_[a, d, a, b, r]"); 
     897        expected.add("1_[a, d, a, b, r, a]"); 
     898        expected.add("1_[d]"); 
     899        expected.add("1_[d, a]"); 
     900        expected.add("1_[d, a, b]"); 
     901        expected.add("1_[d, a, b, r]"); 
     902        expected.add("1_[d, a, b, r, a]"); 
     903 
     904        assertEquals(expected.size(), sequences.size()); 
     905 
     906        for (String sequence : sequences) { 
     907            ListAssert.assertContains(expected, sequence); 
    831908        } 
    832  
    833  
    834         @Test 
    835         public void testProcessWithTrieProcessor_10() throws Exception { 
    836                 Trie<String> fixture = new Trie<String>(); 
    837                 fixture.train(sequence, 11); 
    838  
    839                 final List<String> sequences = new ArrayList<String>(); 
    840                 TrieProcessor<String> processor = new TrieProcessor<String>() { 
    841                     @Override 
    842                     public TrieProcessor.Result process(List<String> sequence, int count) { 
    843                         sequences.add(count + "_" + sequence.toString()); 
    844                         return TrieProcessor.Result.CONTINUE; 
    845                     } 
    846                      
    847                 }; 
    848                  
    849                 fixture.process(processor); 
    850                  
    851                 List<String> expected = new ArrayList<String>(); 
    852                  
    853                 expected.add("5_[a]"); 
    854                 expected.add("2_[a, b]"); 
    855                 expected.add("2_[a, b, r]"); 
    856                 expected.add("2_[a, b, r, a]"); 
    857                 expected.add("1_[a, b, r, a, c]"); 
    858                 expected.add("1_[a, b, r, a, c, a]"); 
    859                 expected.add("1_[a, b, r, a, c, a, d]"); 
    860                 expected.add("1_[a, b, r, a, c, a, d, a]"); 
    861                 expected.add("1_[a, b, r, a, c, a, d, a, b]"); 
    862                 expected.add("1_[a, b, r, a, c, a, d, a, b, r]"); 
    863                 expected.add("1_[a, b, r, a, c, a, d, a, b, r, a]"); 
    864                 expected.add("2_[b]"); 
    865                 expected.add("2_[b, r]"); 
    866                 expected.add("2_[b, r, a]"); 
    867                 expected.add("1_[b, r, a, c]"); 
    868                 expected.add("1_[b, r, a, c, a]"); 
    869                 expected.add("1_[b, r, a, c, a, d]"); 
    870                 expected.add("1_[b, r, a, c, a, d, a]"); 
    871                 expected.add("1_[b, r, a, c, a, d, a, b]"); 
    872                 expected.add("1_[b, r, a, c, a, d, a, b, r]"); 
    873                 expected.add("1_[b, r, a, c, a, d, a, b, r, a]"); 
    874                 expected.add("2_[r]"); 
    875                 expected.add("2_[r, a]"); 
    876                 expected.add("1_[r, a, c]"); 
    877                 expected.add("1_[r, a, c, a]"); 
    878                 expected.add("1_[r, a, c, a, d]"); 
    879                 expected.add("1_[r, a, c, a, d, a]"); 
    880                 expected.add("1_[r, a, c, a, d, a, b]"); 
    881                 expected.add("1_[r, a, c, a, d, a, b, r]"); 
    882                 expected.add("1_[r, a, c, a, d, a, b, r, a]"); 
    883                 expected.add("1_[a, c]"); 
    884                 expected.add("1_[a, c, a]"); 
    885                 expected.add("1_[a, c, a, d]"); 
    886                 expected.add("1_[a, c, a, d, a]"); 
    887                 expected.add("1_[a, c, a, d, a, b]"); 
    888                 expected.add("1_[a, c, a, d, a, b, r]"); 
    889                 expected.add("1_[a, c, a, d, a, b, r, a]"); 
    890                 expected.add("1_[c]"); 
    891                 expected.add("1_[c, a]"); 
    892                 expected.add("1_[c, a, d]"); 
    893                 expected.add("1_[c, a, d, a]"); 
    894                 expected.add("1_[c, a, d, a, b]"); 
    895                 expected.add("1_[c, a, d, a, b, r]"); 
    896                 expected.add("1_[c, a, d, a, b, r, a]"); 
    897                 expected.add("1_[a, d]"); 
    898                 expected.add("1_[a, d, a]"); 
    899                 expected.add("1_[a, d, a, b]"); 
    900                 expected.add("1_[a, d, a, b, r]"); 
    901                 expected.add("1_[a, d, a, b, r, a]"); 
    902                 expected.add("1_[d]"); 
    903                 expected.add("1_[d, a]"); 
    904                 expected.add("1_[d, a, b]"); 
    905                 expected.add("1_[d, a, b, r]"); 
    906                 expected.add("1_[d, a, b, r, a]"); 
    907                  
    908                 assertEquals(expected.size(), sequences.size()); 
    909                  
    910                 for (String sequence : sequences) { 
    911                     ListAssert.assertContains(expected, sequence); 
    912                 } 
    913         } 
    914  
    915         @Test 
    916         public void testGetSequencesWithMostOccurrences_1() throws Exception { 
    917                 Trie<String> fixture = new Trie<String>(); 
    918                 fixture.train(sequence, 3); 
    919                  
    920                 // get all sequences with a minimal length of one that occur most often 
    921                 Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(1, 0); 
    922  
    923                 assertEquals(1, result.size()); 
    924                  
    925                 List<String> expected = new ArrayList<String>(); 
    926                 expected.add("a"); 
    927  
    928                 ListAssert.assertEquals(expected, result.iterator().next()); 
    929         } 
    930  
    931         @Test 
    932         public void testGetSequencesWithMostOccurrences_2() throws Exception { 
    933                 Trie<String> fixture = new Trie<String>(); 
    934                 fixture.train(sequence, 3); 
    935                  
    936                 // get all sequences with a minimal length of one that occur exactly once 
    937                 Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(1, 1); 
    938  
    939                 assertEquals(11, result.size()); 
    940                  
    941                 List<String> expected = new ArrayList<String>(); 
    942                 expected.add("r"); 
    943                 expected.add("a"); 
    944                 expected.add("c"); 
    945                 // rac 
    946                 ListAssert.assertContains((List<List<String>>) result, expected); 
    947                  
    948                 expected.clear(); 
    949                 expected.add("a"); 
    950                 expected.add("c"); 
    951                 // ac 
    952                 ListAssert.assertContains((List<List<String>>) result, expected); 
    953                  
    954                 expected.add("a"); 
    955                 // aca 
    956                 ListAssert.assertContains((List<List<String>>) result, expected); 
    957                  
    958                 expected.clear(); 
    959                 expected.add("c"); 
    960                 // c 
    961                 ListAssert.assertContains((List<List<String>>) result, expected); 
    962                  
    963                 expected.add("a"); 
    964                 // ca 
    965                 ListAssert.assertContains((List<List<String>>) result, expected); 
    966                  
    967                 expected.add("d"); 
    968                 // cad 
    969                 ListAssert.assertContains((List<List<String>>) result, expected); 
    970                  
    971                 expected.clear(); 
    972                 expected.add("a"); 
    973                 expected.add("d"); 
    974                 // ad 
    975                 ListAssert.assertContains((List<List<String>>) result, expected); 
    976                  
    977                 expected.add("a"); 
    978                 // ada 
    979                 ListAssert.assertContains((List<List<String>>) result, expected); 
    980                  
    981                 expected.clear(); 
    982                 expected.add("d"); 
    983                 // d 
    984                 ListAssert.assertContains((List<List<String>>) result, expected); 
    985                  
    986                 expected.add("a"); 
    987                 // da 
    988                 ListAssert.assertContains((List<List<String>>) result, expected); 
    989                  
    990                 expected.add("b"); 
    991                 // dab 
    992                 ListAssert.assertContains((List<List<String>>) result, expected); 
    993         } 
    994  
    995         @Test 
    996         public void testGetSequencesWithMostOccurrences_3() throws Exception { 
    997                 Trie<String> fixture = new Trie<String>(); 
    998                 fixture.train(sequence, 3); 
    999                  
    1000                 // get all sequences with a minimal length of one that occur exactly twice 
    1001                 Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(1, 2); 
    1002  
    1003                 assertEquals(7, result.size()); 
    1004                  
    1005                 List<String> expected = new ArrayList<String>(); 
    1006                 expected.add("a"); 
    1007                 expected.add("b"); 
    1008                 // ab 
    1009                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1010                  
    1011                 expected.add("r"); 
    1012                 // abr 
    1013                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1014  
    1015                 expected.clear(); 
    1016                 expected.add("b"); 
    1017                 // b 
    1018                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1019                  
    1020                 expected.add("r"); 
    1021                 // br 
    1022                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1023                  
    1024                 expected.add("a"); 
    1025                 // bra 
    1026                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1027  
    1028                 expected.clear(); 
    1029                 expected.add("r"); 
    1030                 // r 
    1031                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1032                  
    1033                 expected.add("a"); 
    1034                 // ra 
    1035                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1036         } 
    1037  
    1038         @Test 
    1039         public void testGetSequencesWithMostOccurrences_4() throws Exception { 
    1040                 Trie<String> fixture = new Trie<String>(); 
    1041                 fixture.train(sequence, 3); 
    1042                  
    1043                 // get all sequences with a minimal length of one that occur exactly three times 
    1044                 Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(1, 3); 
    1045  
    1046                 assertEquals(0, result.size()); 
    1047         } 
    1048  
    1049         @Test 
    1050         public void testGetSequencesWithMostOccurrences_5() throws Exception { 
    1051                 Trie<String> fixture = new Trie<String>(); 
    1052                 fixture.train(sequence, 3); 
    1053                  
    1054                 // get all sequences with a minimal length of one that occur exactly four times 
    1055                 Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(1, 4); 
    1056  
    1057                 assertEquals(0, result.size()); 
    1058         } 
    1059  
    1060         @Test 
    1061         public void testGetSequencesWithMostOccurrences_6() throws Exception { 
    1062                 Trie<String> fixture = new Trie<String>(); 
    1063                 fixture.train(sequence, 3); 
    1064                  
    1065                 // get all sequences with a minimal length of one that occur exactly five times 
    1066                 Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(1, 5); 
    1067  
    1068                 assertEquals(1, result.size()); 
    1069                  
    1070                 List<String> expected = new ArrayList<String>(); 
    1071                 expected.add("a"); 
    1072                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1073         } 
    1074  
    1075         @Test 
    1076         public void testGetSequencesWithMostOccurrences_7() throws Exception { 
    1077                 Trie<String> fixture = new Trie<String>(); 
    1078                 fixture.train(sequence, 3); 
    1079                  
    1080                 // get all sequences with a minimal length of two that occur most often 
    1081                 Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(2, 0); 
    1082  
    1083                 assertEquals(5, result.size()); 
    1084                  
    1085                 List<String> expected = new ArrayList<String>(); 
    1086                 expected.add("a"); 
    1087                 expected.add("b"); 
    1088                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1089                  
    1090                 expected.add("r"); 
    1091                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1092                  
    1093                 expected.clear(); 
    1094                 expected.add("b"); 
    1095                 expected.add("r"); 
    1096                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1097                  
    1098                 expected.add("a"); 
    1099                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1100                  
    1101                 expected.clear(); 
    1102                 expected.add("r"); 
    1103                 expected.add("a"); 
    1104                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1105         } 
    1106  
    1107         @Test 
    1108         public void testGetSequencesWithMostOccurrences_8() throws Exception { 
    1109                 Trie<String> fixture = new Trie<String>(); 
    1110                 fixture.train(sequence, 3); 
    1111                  
    1112                 // get all sequences with a minimal length of two that occur exactly once 
    1113                 Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(2, 1); 
    1114  
    1115                 assertEquals(9, result.size()); 
    1116                  
    1117                 List<String> expected = new ArrayList<String>(); 
    1118                 expected.add("r"); 
    1119                 expected.add("a"); 
    1120                 expected.add("c"); 
    1121                 // rac 
    1122                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1123                  
    1124                 expected.clear(); 
    1125                 expected.add("a"); 
    1126                 expected.add("c"); 
    1127                 // ac 
    1128                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1129                  
    1130                 expected.add("a"); 
    1131                 // aca 
    1132                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1133                  
    1134                 expected.clear(); 
    1135                 expected.add("c"); 
    1136                 expected.add("a"); 
    1137                 // ca 
    1138                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1139                  
    1140                 expected.add("d"); 
    1141                 // cad 
    1142                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1143                  
    1144                 expected.clear(); 
    1145                 expected.add("a"); 
    1146                 expected.add("d"); 
    1147                 // ad 
    1148                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1149                  
    1150                 expected.add("a"); 
    1151                 // ada 
    1152                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1153                  
    1154                 expected.clear(); 
    1155                 expected.add("d"); 
    1156                 expected.add("a"); 
    1157                 // da 
    1158                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1159                  
    1160                 expected.add("b"); 
    1161                 // dab 
    1162                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1163         } 
    1164  
    1165         @Test 
    1166         public void testGetSequencesWithMostOccurrences_9() throws Exception { 
    1167                 Trie<String> fixture = new Trie<String>(); 
    1168                 fixture.train(sequence, 3); 
    1169                  
    1170                 // get all sequences with a minimal length of two that occur exactly twice 
    1171                 Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(2, 2); 
    1172  
    1173                 assertEquals(5, result.size()); 
    1174                  
    1175                 List<String> expected = new ArrayList<String>(); 
    1176                 expected.add("a"); 
    1177                 expected.add("b"); 
    1178                 // ab 
    1179                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1180                  
    1181                 expected.add("r"); 
    1182                 // abr 
    1183                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1184  
    1185                 expected.clear(); 
    1186                 expected.add("b"); 
    1187                 expected.add("r"); 
    1188                 // br 
    1189                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1190                  
    1191                 expected.add("a"); 
    1192                 // bra 
    1193                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1194  
    1195                 expected.clear(); 
    1196                 expected.add("r"); 
    1197                 expected.add("a"); 
    1198                 // ra 
    1199                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1200         } 
    1201  
    1202         @Test 
    1203         public void testGetSequencesWithMostOccurrences_10() throws Exception { 
    1204                 Trie<String> fixture = new Trie<String>(); 
    1205                 fixture.train(sequence, 3); 
    1206                  
    1207                 // get all sequences with a minimal length of two that occur exactly three times 
    1208                 Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(2, 3); 
    1209  
    1210                 assertEquals(0, result.size()); 
    1211         } 
    1212          
    1213         @Test 
    1214         public void testGetSequencesWithMostOccurrences_11() throws Exception { 
    1215                 Trie<String> fixture = new Trie<String>(); 
    1216                 fixture.train(sequence, 3); 
    1217                  
    1218                 // get all sequences with a minimal length of three that occur most often 
    1219                 Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(3, 0); 
    1220  
    1221                 assertEquals(2, result.size()); 
    1222                  
    1223                 List<String> expected = new ArrayList<String>(); 
    1224                 expected.add("a"); 
    1225                 expected.add("b"); 
    1226                 expected.add("r"); 
    1227                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1228                  
    1229                 expected.clear(); 
    1230                 expected.add("b"); 
    1231                 expected.add("r"); 
    1232                 expected.add("a"); 
    1233                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1234         } 
    1235  
    1236         @Test 
    1237         public void testGetSequencesWithMostOccurrences_12() throws Exception { 
    1238                 Trie<String> fixture = new Trie<String>(); 
    1239                 fixture.train(sequence, 3); 
    1240                  
    1241                 // get all sequences with a minimal length of three that occur exactly once 
    1242                 Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(3, 1); 
    1243  
    1244                 assertEquals(5, result.size()); 
    1245                  
    1246                 List<String> expected = new ArrayList<String>(); 
    1247                 expected.add("r"); 
    1248                 expected.add("a"); 
    1249                 expected.add("c"); 
    1250                 // rac 
    1251                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1252                  
    1253                 expected.clear(); 
    1254                 expected.add("a"); 
    1255                 expected.add("c"); 
    1256                 expected.add("a"); 
    1257                 // aca 
    1258                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1259                  
    1260                 expected.clear(); 
    1261                 expected.add("c"); 
    1262                 expected.add("a"); 
    1263                 expected.add("d"); 
    1264                 // cad 
    1265                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1266                  
    1267                 expected.clear(); 
    1268                 expected.add("a"); 
    1269                 expected.add("d"); 
    1270                 expected.add("a"); 
    1271                 // ada 
    1272                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1273                  
    1274                 expected.clear(); 
    1275                 expected.add("d"); 
    1276                 expected.add("a"); 
    1277                 expected.add("b"); 
    1278                 // dab 
    1279                 ListAssert.assertContains((List<List<String>>) result, expected); 
    1280         } 
    1281  
    1282         @Test 
    1283         public void testGetSequencesWithMostOccurrences_13() throws Exception { 
    1284                 Trie<String> fixture = new Trie<String>(); 
    1285                 fixture.train(sequence, 3); 
    1286                  
    1287                 // get all sequences with a minimal length of four that occur most often 
    1288                 Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(4, 0); 
    1289  
    1290                 // none of these exist, as the tree is only trained with sequences of length 3 
    1291                 assertEquals(0, result.size()); 
    1292         } 
    1293  
    1294         @Test 
    1295         public void testGetSequencesWithMostOccurrences_14() throws Exception { 
    1296                 Trie<String> fixture = new Trie<String>(); 
    1297                 fixture.train(sequence, 3); 
    1298                  
    1299                 // get all sequences with a minimal length of four that occur exactly once 
    1300                 Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(4, 1); 
    1301  
    1302                 // none of these exist, as the tree is only trained with sequences of length 3 
    1303                 assertEquals(0, result.size()); 
    1304         } 
    1305  
    1306         @Test 
    1307         public void testGetCount_1() throws Exception { 
    1308                 Trie<String> fixture = new Trie<String>(); 
    1309                 fixture.train(sequence, 3); 
    1310                 List<String> subSequence = new ArrayList<String>(); 
    1311                 subSequence.add("a"); 
    1312  
    1313                 int result = fixture.getCount(subSequence); 
    1314  
    1315                 assertEquals(5, result); 
    1316         } 
    1317  
    1318         @Test 
    1319         public void testGetCount_2() throws Exception { 
    1320                 Trie<String> fixture = new Trie<String>(); 
    1321                 fixture.train(sequence, 3); 
    1322                 List<String> subSequence = new ArrayList<String>(); 
    1323                 subSequence.add("a"); 
    1324                 subSequence.add("b"); 
    1325  
    1326                 int result = fixture.getCount(subSequence); 
    1327  
    1328                 assertEquals(2, result); 
    1329         } 
    1330  
    1331         @Test 
    1332         public void testGetCount_3() throws Exception { 
    1333                 Trie<String> fixture = new Trie<String>(); 
    1334                 fixture.train(sequence, 3); 
    1335                 List<String> subSequence = new ArrayList<String>(); 
    1336                 subSequence.add("x"); 
    1337  
    1338                 int result = fixture.getCount(subSequence); 
    1339  
    1340                 assertEquals(0, result); 
    1341         } 
    1342  
    1343         @Test 
    1344         public void testGetCount_4() throws Exception { 
    1345                 Trie<String> fixture = new Trie<String>(); 
    1346                 fixture.train(sequence, 3); 
    1347                 List<String> subSequence = new ArrayList<String>(); 
    1348  
    1349                 int result = fixture.getCount(subSequence, "a"); 
    1350  
    1351                 assertEquals(5, result); 
    1352         } 
    1353  
    1354         @Test 
    1355         public void testGetCount_5() throws Exception { 
    1356                 Trie<String> fixture = new Trie<String>(); 
    1357                 fixture.train(sequence, 3); 
    1358                 List<String> subSequence = new ArrayList<String>(); 
    1359                 subSequence.add("a"); 
    1360                 subSequence.add("b"); 
    1361  
    1362                 int result = fixture.getCount(subSequence, "r"); 
    1363  
    1364                 assertEquals(2, result); 
    1365         } 
    1366  
    1367         @Test 
    1368         public void testGetCount_6() throws Exception { 
    1369                 Trie<String> fixture = new Trie<String>(); 
    1370                 fixture.train(sequence, 3); 
    1371                 List<String> subSequence = new ArrayList<String>(); 
    1372  
    1373                 int result = fixture.getCount(subSequence, "x"); 
    1374  
    1375                 assertEquals(0, result); 
    1376         } 
    1377  
    1378         @Test 
    1379         public void testGetFollowingSymbols_1() throws Exception { 
    1380                 Trie<String> fixture = new Trie<String>(); 
    1381                 fixture.train(sequence, 3); 
    1382                 List<String> subSequence = new ArrayList<String>(); 
    1383                 subSequence.add("a"); 
    1384                 Collection<String> expected = new ArrayList<String>(); 
    1385                 expected.add("b"); 
    1386                 expected.add("c"); 
    1387                 expected.add("d"); 
    1388  
    1389                 Collection<String> result = fixture.getFollowingSymbols(subSequence); 
    1390  
    1391                 assertCollectionContent(expected, result); 
    1392         } 
    1393  
    1394         @Test 
    1395         public void testGetFollowingSymbols_2() throws Exception { 
    1396                 Trie<String> fixture = new Trie<String>(); 
    1397                 fixture.train(sequence, 3); 
    1398                 List<String> subSequence = new ArrayList<String>(); 
    1399                 subSequence.add("a"); 
    1400                 subSequence.add("b"); 
    1401                 subSequence.add("r"); 
    1402  
    1403                 Collection<String> result = fixture.getFollowingSymbols(subSequence); 
    1404  
    1405                 assertEquals(0, result.size()); 
    1406         } 
    1407  
    1408         @Test 
    1409         public void testGetFollowingSymbols_3() throws Exception { 
    1410                 Trie<String> fixture = new Trie<String>(); 
    1411                 fixture.train(sequence, 3); 
    1412                 List<String> subSequence = new ArrayList<String>(); 
    1413                 subSequence.add("x"); 
    1414  
    1415                 Collection<String> result = fixture.getFollowingSymbols(subSequence); 
    1416  
    1417                 assertEquals(0, result.size()); 
    1418         } 
    1419  
    1420         @Test 
    1421         public void testGetNumLeafAncestors_1() throws Exception { 
    1422                 Trie<String> fixture = new Trie<String>(); 
    1423                 fixture.train(sequence, 3); 
    1424  
    1425                 int result = fixture.getNumLeafAncestors(); 
    1426  
    1427                 assertEquals(7, result); 
    1428         } 
    1429  
    1430         @Test 
    1431         public void testGetNumLeafs_1() throws Exception { 
    1432                 Trie<String> fixture = new Trie<String>(); 
    1433                 fixture.train(sequence, 3); 
    1434  
    1435                 int result = fixture.getNumLeafs(); 
    1436  
    1437                 assertEquals(7, result); 
    1438         } 
    1439  
    1440         @Test 
    1441         public void testGetNumSymbols_1() throws Exception { 
    1442                 Trie<String> fixture = new Trie<String>(); 
    1443                 fixture.train(sequence, 3); 
    1444  
    1445                 int result = fixture.getNumSymbols(); 
    1446  
    1447                 assertEquals(5, result); 
    1448         } 
    1449  
    1450         @Test 
    1451         public void testTrain_1() throws Exception { 
    1452                 Trie<String> fixture = new Trie<String>(); 
    1453                 int maxOrder = 3; 
    1454  
    1455                 fixture.train(sequence, maxOrder); 
    1456  
    1457                 // check if symbols are correct 
    1458                 assertCollectionContent(symbols, fixture.getKnownSymbols()); 
    1459  
    1460                 // check if counters are correct and only the correct nodes exist 
    1461                 TrieNode<String> root = fixture.find(new ArrayList<String>()); 
    1462                 TrieNode<String> root_a = root.getChild("a"); 
    1463                 TrieNode<String> root_a_a = root_a.getChild("a"); 
    1464                 TrieNode<String> root_a_b = root_a.getChild("b"); 
    1465                 TrieNode<String> root_a_b_a = root_a_b.getChild("a"); 
    1466                 TrieNode<String> root_a_b_b = root_a_b.getChild("b"); 
    1467                 TrieNode<String> root_a_b_c = root_a_b.getChild("c"); 
    1468                 TrieNode<String> root_a_b_d = root_a_b.getChild("d"); 
    1469                 TrieNode<String> root_a_b_r = root_a_b.getChild("r"); 
    1470                 TrieNode<String> root_a_c = root_a.getChild("c"); 
    1471                 TrieNode<String> root_a_c_a = root_a_c.getChild("a"); 
    1472                 TrieNode<String> root_a_c_b = root_a_c.getChild("b"); 
    1473                 TrieNode<String> root_a_c_c = root_a_c.getChild("c"); 
    1474                 TrieNode<String> root_a_c_d = root_a_c.getChild("d"); 
    1475                 TrieNode<String> root_a_c_r = root_a_c.getChild("r"); 
    1476                 TrieNode<String> root_a_d = root_a.getChild("d"); 
    1477                 TrieNode<String> root_a_d_a = root_a_d.getChild("a"); 
    1478                 TrieNode<String> root_a_d_b = root_a_d.getChild("b"); 
    1479                 TrieNode<String> root_a_d_c = root_a_d.getChild("c"); 
    1480                 TrieNode<String> root_a_d_d = root_a_d.getChild("d"); 
    1481                 TrieNode<String> root_a_d_r = root_a_d.getChild("r"); 
    1482                 TrieNode<String> root_a_r = root_a.getChild("r"); 
    1483                 TrieNode<String> root_b = root.getChild("b"); 
    1484                 TrieNode<String> root_b_a = root_b.getChild("a"); 
    1485                 TrieNode<String> root_b_b = root_b.getChild("b"); 
    1486                 TrieNode<String> root_b_c = root_b.getChild("c"); 
    1487                 TrieNode<String> root_b_d = root_b.getChild("d"); 
    1488                 TrieNode<String> root_b_r = root_b.getChild("r"); 
    1489                 TrieNode<String> root_b_r_a = root_b_r.getChild("a"); 
    1490                 TrieNode<String> root_b_r_b = root_b_r.getChild("b"); 
    1491                 TrieNode<String> root_b_r_c = root_b_r.getChild("c"); 
    1492                 TrieNode<String> root_b_r_d = root_b_r.getChild("d"); 
    1493                 TrieNode<String> root_b_r_r = root_b_r.getChild("r"); 
    1494                 TrieNode<String> root_c = root.getChild("c"); 
    1495                 TrieNode<String> root_c_a = root_c.getChild("a"); 
    1496                 TrieNode<String> root_c_a_a = root_c_a.getChild("a"); 
    1497                 TrieNode<String> root_c_a_b = root_c_a.getChild("b"); 
    1498                 TrieNode<String> root_c_a_c = root_c_a.getChild("c"); 
    1499                 TrieNode<String> root_c_a_d = root_c_a.getChild("d"); 
    1500                 TrieNode<String> root_c_a_r = root_c_a.getChild("r"); 
    1501                 TrieNode<String> root_c_b = root_c.getChild("b"); 
    1502                 TrieNode<String> root_c_c = root_c.getChild("c"); 
    1503                 TrieNode<String> root_c_d = root_c.getChild("d"); 
    1504                 TrieNode<String> root_c_r = root_c.getChild("r"); 
    1505                 TrieNode<String> root_d = root.getChild("d"); 
    1506                 TrieNode<String> root_d_a = root_d.getChild("a"); 
    1507                 TrieNode<String> root_d_a_a = root_d_a.getChild("a"); 
    1508                 TrieNode<String> root_d_a_b = root_d_a.getChild("b"); 
    1509                 TrieNode<String> root_d_a_c = root_d_a.getChild("c"); 
    1510                 TrieNode<String> root_d_a_d = root_d_a.getChild("d"); 
    1511                 TrieNode<String> root_d_a_r = root_d_a.getChild("r"); 
    1512                 TrieNode<String> root_d_b = root_d.getChild("b"); 
    1513                 TrieNode<String> root_d_c = root_d.getChild("c"); 
    1514                 TrieNode<String> root_d_d = root_d.getChild("d"); 
    1515                 TrieNode<String> root_d_r = root_d.getChild("r"); 
    1516                 TrieNode<String> root_r = root.getChild("r"); 
    1517                 TrieNode<String> root_r_a = root_r.getChild("a"); 
    1518                 TrieNode<String> root_r_a_a = root_r_a.getChild("a"); 
    1519                 TrieNode<String> root_r_a_b = root_r_a.getChild("b"); 
    1520                 TrieNode<String> root_r_a_c = root_r_a.getChild("c"); 
    1521                 TrieNode<String> root_r_a_d = root_r_a.getChild("d"); 
    1522                 TrieNode<String> root_r_a_r = root_r_a.getChild("r"); 
    1523                 TrieNode<String> root_r_b = root_r.getChild("b"); 
    1524                 TrieNode<String> root_r_c = root_r.getChild("c"); 
    1525                 TrieNode<String> root_r_d = root_r.getChild("d"); 
    1526                 TrieNode<String> root_r_r = root_r.getChild("r"); 
    1527  
    1528                 assertEquals(5, root_a.getCount()); 
    1529                 assertNull(root_a_a); 
    1530                 assertEquals(2, root_a_b.getCount()); 
    1531                 assertNull(root_a_b_a); 
    1532                 assertNull(root_a_b_b); 
    1533                 assertNull(root_a_b_c); 
    1534                 assertNull(root_a_b_d); 
    1535                 assertEquals(2, root_a_b_r.getCount()); 
    1536                 assertEquals(1, root_a_c.getCount()); 
    1537                 assertEquals(1, root_a_c_a.getCount()); 
    1538                 assertNull(root_a_c_b); 
    1539                 assertNull(root_a_c_c); 
    1540                 assertNull(root_a_c_d); 
    1541                 assertNull(root_a_c_r); 
    1542                 assertEquals(1, root_a_d.getCount()); 
    1543                 assertEquals(1, root_a_d_a.getCount()); 
    1544                 assertNull(root_a_d_b); 
    1545                 assertNull(root_a_d_c); 
    1546                 assertNull(root_a_d_d); 
    1547                 assertNull(root_a_d_r); 
    1548                 assertNull(root_a_r); 
    1549  
    1550                 assertEquals(2, root_b.getCount()); 
    1551                 assertNull(root_b_a); 
    1552                 assertNull(root_b_b); 
    1553                 assertNull(root_b_c); 
    1554                 assertNull(root_b_d); 
    1555                 assertEquals(2, root_b_r.getCount()); 
    1556                 assertEquals(2, root_b_r_a.getCount()); 
    1557                 assertNull(root_b_r_b); 
    1558                 assertNull(root_b_r_c); 
    1559                 assertNull(root_b_r_d); 
    1560                 assertNull(root_b_r_r); 
    1561  
    1562                 assertEquals(1, root_c.getCount()); 
    1563                 assertEquals(1, root_c_a.getCount()); 
    1564                 assertNull(root_c_a_a); 
    1565                 assertNull(root_c_a_b); 
    1566                 assertNull(root_c_a_c); 
    1567                 assertEquals(1, root_c_a_d.getCount()); 
    1568                 assertNull(root_c_a_r); 
    1569                 assertNull(root_c_b); 
    1570                 assertNull(root_c_c); 
    1571                 assertNull(root_c_d); 
    1572                 assertNull(root_c_r); 
    1573  
    1574                 assertEquals(1, root_d.getCount()); 
    1575                 assertEquals(1, root_d_a.getCount()); 
    1576                 assertNull(root_d_a_a); 
    1577                 assertEquals(1, root_d_a_b.getCount()); 
    1578                 assertNull(root_d_a_c); 
    1579                 assertNull(root_d_a_d); 
    1580                 assertNull(root_d_a_r); 
    1581                 assertNull(root_d_b); 
    1582                 assertNull(root_d_c); 
    1583                 assertNull(root_d_d); 
    1584                 assertNull(root_d_r); 
    1585  
    1586                 assertEquals(2, root_r.getCount()); 
    1587                 assertEquals(2, root_r_a.getCount()); 
    1588                 assertNull(root_r_a_a); 
    1589                 assertNull(root_r_a_b); 
    1590                 assertEquals(1, root_r_a_c.getCount()); 
    1591                 assertNull(root_r_a_d); 
    1592                 assertNull(root_r_a_r); 
    1593                 assertNull(root_r_b); 
    1594                 assertNull(root_r_c); 
    1595                 assertNull(root_r_d); 
    1596                 assertNull(root_r_r); 
    1597  
    1598                 // check if leafs are really leafs 
    1599                 assertTrue(root_a_b_r.isLeaf()); 
    1600                 assertTrue(root_a_c_a.isLeaf()); 
    1601                 assertTrue(root_a_d_a.isLeaf()); 
    1602                 assertTrue(root_b_r_a.isLeaf()); 
    1603                 assertTrue(root_c_a_d.isLeaf()); 
    1604                 assertTrue(root_d_a_b.isLeaf()); 
    1605                 assertTrue(root_r_a_c.isLeaf()); 
    1606         } 
    1607  
    1608         @Test 
    1609         public void testTrain_2() throws Exception { 
    1610                 Trie<String> fixture = new Trie<String>(); 
    1611                 int maxOrder = 0; 
    1612  
    1613                 fixture.train(sequence, maxOrder); 
    1614  
    1615                 assertTrue(fixture.getKnownSymbols().isEmpty()); 
    1616         } 
    1617  
    1618         @Test 
    1619         public void testTrain_3() throws Exception { 
    1620                 Trie<Object> fixture = new Trie<Object>(); 
    1621                 List<Object> sequence = new ArrayList<Object>(); 
    1622                 int maxOrder = 1; 
    1623  
    1624                 fixture.train(sequence, maxOrder); 
    1625  
    1626                 assertTrue(fixture.getKnownSymbols().isEmpty()); 
    1627         } 
    1628  
    1629         @Test 
    1630         public void testTrain_4() throws Exception { 
    1631                 Trie<String> fixture = new Trie<String>(); 
    1632                 List<String> sequence = new ArrayList<String>(); 
    1633                 sequence.add("a"); 
    1634                 sequence.add("b"); 
    1635                 int maxOrder = 3; 
    1636  
    1637                 fixture.train(sequence, maxOrder); 
    1638  
    1639                 assertCollectionContent(sequence, fixture.getKnownSymbols()); 
    1640                 TrieNode<String> root = fixture.find(new ArrayList<String>()); 
    1641                 TrieNode<String> root_a = root.getChild("a"); 
    1642                 TrieNode<String> root_a_a = root_a.getChild("a"); 
    1643                 TrieNode<String> root_a_b = root_a.getChild("b"); 
    1644                 TrieNode<String> root_b = root.getChild("b"); 
    1645                 TrieNode<String> root_b_a = root_b.getChild("a"); 
    1646                 TrieNode<String> root_b_b = root_b.getChild("b"); 
    1647  
    1648                 assertEquals(1, root_a.getCount()); 
    1649                 assertNull(root_a_a); 
    1650                 assertEquals(1, root_a_b.getCount()); 
    1651                 assertEquals(1, root_b.getCount()); 
    1652                 assertNull(root_b_a); 
    1653                 assertNull(root_b_b); 
    1654  
    1655                 assertTrue(root_a_b.isLeaf()); 
    1656                 assertTrue(root_b.isLeaf()); 
    1657         } 
    1658  
    1659         @Test 
    1660         public void testEdgeEdge_1() throws Exception { 
    1661                 Edge result = new Edge(); 
    1662  
    1663                 assertNotNull(result); 
    1664         } 
    1665  
    1666         @Test 
    1667         public void testTrieVertexTrieVertex_1() throws Exception { 
    1668                 String id = "idString"; 
    1669  
    1670                 TrieVertex result = new TrieVertex(id); 
    1671  
    1672                 assertNotNull(result); 
    1673         } 
    1674  
    1675         @Test 
    1676         public void testTrieVertexToString_1() throws Exception { 
    1677                 String id = "idString"; 
    1678                 TrieVertex fixture = new TrieVertex(id); 
    1679  
    1680                 String result = fixture.toString(); 
    1681  
    1682                 assertEquals(id, result); 
    1683         } 
    1684  
    1685         @Test 
    1686         public void testEquals_1() throws Exception { 
    1687                 Trie<String> trieOther = new Trie<String>(); 
    1688                 Trie<String> fixture = new Trie<String>(); 
    1689  
    1690                 boolean result = fixture.equals(trieOther); 
    1691  
    1692                 assertEquals(true, result); 
    1693         } 
    1694  
    1695         @Test 
    1696         public void testEquals_2() throws Exception { 
    1697                 Trie<String> trieOther = new Trie<String>(); 
    1698                 trieOther.train(sequence, 2); 
    1699                 Trie<String> fixture = new Trie<String>(); 
    1700                 fixture.train(sequence, 2); 
    1701  
    1702                 boolean result = fixture.equals(trieOther); 
    1703  
    1704                 assertEquals(true, result); 
    1705         } 
    1706  
    1707         @Test 
    1708         public void testEquals_3() throws Exception { 
    1709                 Trie<String> trieOther = new Trie<String>(); 
    1710                 trieOther.train(sequence, 2); 
    1711                 Trie<String> fixture = new Trie<String>(); 
    1712                 fixture.train(sequence, 3); 
    1713  
    1714                 boolean result = fixture.equals(trieOther); 
    1715  
    1716                 assertEquals(false, result); 
    1717         } 
    1718  
    1719         @Test 
    1720         public void testEquals_4() throws Exception { 
    1721                 Trie<String> trieOther = new Trie<String>(); 
    1722                 Trie<String> fixture = new Trie<String>(); 
    1723                 fixture.train(sequence, 2); 
    1724  
    1725                 boolean result = fixture.equals(trieOther); 
    1726  
    1727                 assertEquals(false, result); 
    1728         } 
    1729  
    1730         @Test 
    1731         public void testEquals_5() throws Exception { 
    1732                 Trie<String> trieOther = new Trie<String>(); 
    1733                 trieOther.train(sequence, 2); 
    1734                 Trie<String> fixture = new Trie<String>(); 
    1735  
    1736                 boolean result = fixture.equals(trieOther); 
    1737  
    1738                 assertEquals(false, result); 
    1739         } 
    1740  
    1741         @Test 
    1742         public void testEquals_6() throws Exception { 
    1743                 Trie<String> fixture = new Trie<String>(); 
    1744                 fixture.train(sequence, 2); 
    1745  
    1746                 boolean result = fixture.equals(fixture); 
    1747  
    1748                 assertEquals(true, result); 
    1749         } 
    1750  
    1751         @Test 
    1752         public void testEquals_7() throws Exception { 
    1753                 Trie<String> fixture = new Trie<String>(); 
    1754                 fixture.train(sequence, 2); 
    1755  
    1756                 boolean result = fixture.equals(null); 
    1757  
    1758                 assertEquals(false, result); 
    1759         } 
    1760  
    1761         @Before 
    1762         public void setUp() throws Exception { 
    1763                 sequence = new ArrayList<String>(); 
    1764                 sequence.add("a"); 
    1765                 sequence.add("b"); 
    1766                 sequence.add("r"); 
    1767                 sequence.add("a"); 
    1768                 sequence.add("c"); 
    1769                 sequence.add("a"); 
    1770                 sequence.add("d"); 
    1771                 sequence.add("a"); 
    1772                 sequence.add("b"); 
    1773                 sequence.add("r"); 
    1774                 sequence.add("a"); 
    1775  
    1776                 symbols = new HashSet<String>(); 
    1777                 symbols.add("a"); 
    1778                 symbols.add("b"); 
    1779                 symbols.add("c"); 
    1780                 symbols.add("d"); 
    1781                 symbols.add("r"); 
    1782         } 
    1783  
    1784         public static void main(String[] args) { 
    1785                 new org.junit.runner.JUnitCore().run(TrieTest.class); 
    1786         } 
     909    } 
     910 
     911    @Test 
     912    public void testGetSequencesWithMostOccurrences_1() throws Exception { 
     913        Trie<String> fixture = new Trie<String>(); 
     914        fixture.train(sequence, 3); 
     915 
     916        // get all sequences with a minimal length of one that occur most often 
     917        Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(1, 0); 
     918 
     919        assertEquals(1, result.size()); 
     920 
     921        List<String> expected = new ArrayList<String>(); 
     922        expected.add("a"); 
     923 
     924        ListAssert.assertEquals(expected, result.iterator().next()); 
     925    } 
     926 
     927    @Test 
     928    public void testGetSequencesWithMostOccurrences_2() throws Exception { 
     929        Trie<String> fixture = new Trie<String>(); 
     930        fixture.train(sequence, 3); 
     931 
     932        // get all sequences with a minimal length of one that occur exactly once 
     933        Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(1, 1); 
     934 
     935        assertEquals(11, result.size()); 
     936 
     937        List<String> expected = new ArrayList<String>(); 
     938        expected.add("r"); 
     939        expected.add("a"); 
     940        expected.add("c"); 
     941        // rac 
     942        ListAssert.assertContains((List<List<String>>) result, expected); 
     943 
     944        expected.clear(); 
     945        expected.add("a"); 
     946        expected.add("c"); 
     947        // ac 
     948        ListAssert.assertContains((List<List<String>>) result, expected); 
     949 
     950        expected.add("a"); 
     951        // aca 
     952        ListAssert.assertContains((List<List<String>>) result, expected); 
     953 
     954        expected.clear(); 
     955        expected.add("c"); 
     956        // c 
     957        ListAssert.assertContains((List<List<String>>) result, expected); 
     958 
     959        expected.add("a"); 
     960        // ca 
     961        ListAssert.assertContains((List<List<String>>) result, expected); 
     962 
     963        expected.add("d"); 
     964        // cad 
     965        ListAssert.assertContains((List<List<String>>) result, expected); 
     966 
     967        expected.clear(); 
     968        expected.add("a"); 
     969        expected.add("d"); 
     970        // ad 
     971        ListAssert.assertContains((List<List<String>>) result, expected); 
     972 
     973        expected.add("a"); 
     974        // ada 
     975        ListAssert.assertContains((List<List<String>>) result, expected); 
     976 
     977        expected.clear(); 
     978        expected.add("d"); 
     979        // d 
     980        ListAssert.assertContains((List<List<String>>) result, expected); 
     981 
     982        expected.add("a"); 
     983        // da 
     984        ListAssert.assertContains((List<List<String>>) result, expected); 
     985 
     986        expected.add("b"); 
     987        // dab 
     988        ListAssert.assertContains((List<List<String>>) result, expected); 
     989    } 
     990 
     991    @Test 
     992    public void testGetSequencesWithMostOccurrences_3() throws Exception { 
     993        Trie<String> fixture = new Trie<String>(); 
     994        fixture.train(sequence, 3); 
     995 
     996        // get all sequences with a minimal length of one that occur exactly twice 
     997        Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(1, 2); 
     998 
     999        assertEquals(7, result.size()); 
     1000 
     1001        List<String> expected = new ArrayList<String>(); 
     1002        expected.add("a"); 
     1003        expected.add("b"); 
     1004        // ab 
     1005        ListAssert.assertContains((List<List<String>>) result, expected); 
     1006 
     1007        expected.add("r"); 
     1008        // abr 
     1009        ListAssert.assertContains((List<List<String>>) result, expected); 
     1010 
     1011        expected.clear(); 
     1012        expected.add("b"); 
     1013        // b 
     1014        ListAssert.assertContains((List<List<String>>) result, expected); 
     1015 
     1016        expected.add("r"); 
     1017        // br 
     1018        ListAssert.assertContains((List<List<String>>) result, expected); 
     1019 
     1020        expected.add("a"); 
     1021        // bra 
     1022        ListAssert.assertContains((List<List<String>>) result, expected); 
     1023 
     1024        expected.clear(); 
     1025        expected.add("r"); 
     1026        // r 
     1027        ListAssert.assertContains((List<List<String>>) result, expected); 
     1028 
     1029        expected.add("a"); 
     1030        // ra 
     1031        ListAssert.assertContains((List<List<String>>) result, expected); 
     1032    } 
     1033 
     1034    @Test 
     1035    public void testGetSequencesWithMostOccurrences_4() throws Exception { 
     1036        Trie<String> fixture = new Trie<String>(); 
     1037        fixture.train(sequence, 3); 
     1038 
     1039        // get all sequences with a minimal length of one that occur exactly three times 
     1040        Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(1, 3); 
     1041 
     1042        assertEquals(0, result.size()); 
     1043    } 
     1044 
     1045    @Test 
     1046    public void testGetSequencesWithMostOccurrences_5() throws Exception { 
     1047        Trie<String> fixture = new Trie<String>(); 
     1048        fixture.train(sequence, 3); 
     1049 
     1050        // get all sequences with a minimal length of one that occur exactly four times 
     1051        Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(1, 4); 
     1052 
     1053        assertEquals(0, result.size()); 
     1054    } 
     1055 
     1056    @Test 
     1057    public void testGetSequencesWithMostOccurrences_6() throws Exception { 
     1058        Trie<String> fixture = new Trie<String>(); 
     1059        fixture.train(sequence, 3); 
     1060 
     1061        // get all sequences with a minimal length of one that occur exactly five times 
     1062        Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(1, 5); 
     1063 
     1064        assertEquals(1, result.size()); 
     1065 
     1066        List<String> expected = new ArrayList<String>(); 
     1067        expected.add("a"); 
     1068        ListAssert.assertContains((List<List<String>>) result, expected); 
     1069    } 
     1070 
     1071    @Test 
     1072    public void testGetSequencesWithMostOccurrences_7() throws Exception { 
     1073        Trie<String> fixture = new Trie<String>(); 
     1074        fixture.train(sequence, 3); 
     1075 
     1076        // get all sequences with a minimal length of two that occur most often 
     1077        Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(2, 0); 
     1078 
     1079        assertEquals(5, result.size()); 
     1080 
     1081        List<String> expected = new ArrayList<String>(); 
     1082        expected.add("a"); 
     1083        expected.add("b"); 
     1084        ListAssert.assertContains((List<List<String>>) result, expected); 
     1085 
     1086        expected.add("r"); 
     1087        ListAssert.assertContains((List<List<String>>) result, expected); 
     1088 
     1089        expected.clear(); 
     1090        expected.add("b"); 
     1091        expected.add("r"); 
     1092        ListAssert.assertContains((List<List<String>>) result, expected); 
     1093 
     1094        expected.add("a"); 
     1095        ListAssert.assertContains((List<List<String>>) result, expected); 
     1096 
     1097        expected.clear(); 
     1098        expected.add("r"); 
     1099        expected.add("a"); 
     1100        ListAssert.assertContains((List<List<String>>) result, expected); 
     1101    } 
     1102 
     1103    @Test 
     1104    public void testGetSequencesWithMostOccurrences_8() throws Exception { 
     1105        Trie<String> fixture = new Trie<String>(); 
     1106        fixture.train(sequence, 3); 
     1107 
     1108        // get all sequences with a minimal length of two that occur exactly once 
     1109        Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(2, 1); 
     1110 
     1111        assertEquals(9, result.size()); 
     1112 
     1113        List<String> expected = new ArrayList<String>(); 
     1114        expected.add("r"); 
     1115        expected.add("a"); 
     1116        expected.add("c"); 
     1117        // rac 
     1118        ListAssert.assertContains((List<List<String>>) result, expected); 
     1119 
     1120        expected.clear(); 
     1121        expected.add("a"); 
     1122        expected.add("c"); 
     1123        // ac 
     1124        ListAssert.assertContains((List<List<String>>) result, expected); 
     1125 
     1126        expected.add("a"); 
     1127        // aca 
     1128        ListAssert.assertContains((List<List<String>>) result, expected); 
     1129 
     1130        expected.clear(); 
     1131        expected.add("c"); 
     1132        expected.add("a"); 
     1133        // ca 
     1134        ListAssert.assertContains((List<List<String>>) result, expected); 
     1135 
     1136        expected.add("d"); 
     1137        // cad 
     1138        ListAssert.assertContains((List<List<String>>) result, expected); 
     1139 
     1140        expected.clear(); 
     1141        expected.add("a"); 
     1142        expected.add("d"); 
     1143        // ad 
     1144        ListAssert.assertContains((List<List<String>>) result, expected); 
     1145 
     1146        expected.add("a"); 
     1147        // ada 
     1148        ListAssert.assertContains((List<List<String>>) result, expected); 
     1149 
     1150        expected.clear(); 
     1151        expected.add("d"); 
     1152        expected.add("a"); 
     1153        // da 
     1154        ListAssert.assertContains((List<List<String>>) result, expected); 
     1155 
     1156        expected.add("b"); 
     1157        // dab 
     1158        ListAssert.assertContains((List<List<String>>) result, expected); 
     1159    } 
     1160 
     1161    @Test 
     1162    public void testGetSequencesWithMostOccurrences_9() throws Exception { 
     1163        Trie<String> fixture = new Trie<String>(); 
     1164        fixture.train(sequence, 3); 
     1165 
     1166        // get all sequences with a minimal length of two that occur exactly twice 
     1167        Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(2, 2); 
     1168 
     1169        assertEquals(5, result.size()); 
     1170 
     1171        List<String> expected = new ArrayList<String>(); 
     1172        expected.add("a"); 
     1173        expected.add("b"); 
     1174        // ab 
     1175        ListAssert.assertContains((List<List<String>>) result, expected); 
     1176 
     1177        expected.add("r"); 
     1178        // abr 
     1179        ListAssert.assertContains((List<List<String>>) result, expected); 
     1180 
     1181        expected.clear(); 
     1182        expected.add("b"); 
     1183        expected.add("r"); 
     1184        // br 
     1185        ListAssert.assertContains((List<List<String>>) result, expected); 
     1186 
     1187        expected.add("a"); 
     1188        // bra 
     1189        ListAssert.assertContains((List<List<String>>) result, expected); 
     1190 
     1191        expected.clear(); 
     1192        expected.add("r"); 
     1193        expected.add("a"); 
     1194        // ra 
     1195        ListAssert.assertContains((List<List<String>>) result, expected); 
     1196    } 
     1197 
     1198    @Test 
     1199    public void testGetSequencesWithMostOccurrences_10() throws Exception { 
     1200        Trie<String> fixture = new Trie<String>(); 
     1201        fixture.train(sequence, 3); 
     1202 
     1203        // get all sequences with a minimal length of two that occur exactly three times 
     1204        Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(2, 3); 
     1205 
     1206        assertEquals(0, result.size()); 
     1207    } 
     1208 
     1209    @Test 
     1210    public void testGetSequencesWithMostOccurrences_11() throws Exception { 
     1211        Trie<String> fixture = new Trie<String>(); 
     1212        fixture.train(sequence, 3); 
     1213 
     1214        // get all sequences with a minimal length of three that occur most often 
     1215        Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(3, 0); 
     1216 
     1217        assertEquals(2, result.size()); 
     1218 
     1219        List<String> expected = new ArrayList<String>(); 
     1220        expected.add("a"); 
     1221        expected.add("b"); 
     1222        expected.add("r"); 
     1223        ListAssert.assertContains((List<List<String>>) result, expected); 
     1224 
     1225        expected.clear(); 
     1226        expected.add("b"); 
     1227        expected.add("r"); 
     1228        expected.add("a"); 
     1229        ListAssert.assertContains((List<List<String>>) result, expected); 
     1230    } 
     1231 
     1232    @Test 
     1233    public void testGetSequencesWithMostOccurrences_12() throws Exception { 
     1234        Trie<String> fixture = new Trie<String>(); 
     1235        fixture.train(sequence, 3); 
     1236 
     1237        // get all sequences with a minimal length of three that occur exactly once 
     1238        Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(3, 1); 
     1239 
     1240        assertEquals(5, result.size()); 
     1241 
     1242        List<String> expected = new ArrayList<String>(); 
     1243        expected.add("r"); 
     1244        expected.add("a"); 
     1245        expected.add("c"); 
     1246        // rac 
     1247        ListAssert.assertContains((List<List<String>>) result, expected); 
     1248 
     1249        expected.clear(); 
     1250        expected.add("a"); 
     1251        expected.add("c"); 
     1252        expected.add("a"); 
     1253        // aca 
     1254        ListAssert.assertContains((List<List<String>>) result, expected); 
     1255 
     1256        expected.clear(); 
     1257        expected.add("c"); 
     1258        expected.add("a"); 
     1259        expected.add("d"); 
     1260        // cad 
     1261        ListAssert.assertContains((List<List<String>>) result, expected); 
     1262 
     1263        expected.clear(); 
     1264        expected.add("a"); 
     1265        expected.add("d"); 
     1266        expected.add("a"); 
     1267        // ada 
     1268        ListAssert.assertContains((List<List<String>>) result, expected); 
     1269 
     1270        expected.clear(); 
     1271        expected.add("d"); 
     1272        expected.add("a"); 
     1273        expected.add("b"); 
     1274        // dab 
     1275        ListAssert.assertContains((List<List<String>>) result, expected); 
     1276    } 
     1277 
     1278    @Test 
     1279    public void testGetSequencesWithMostOccurrences_13() throws Exception { 
     1280        Trie<String> fixture = new Trie<String>(); 
     1281        fixture.train(sequence, 3); 
     1282 
     1283        // get all sequences with a minimal length of four that occur most often 
     1284        Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(4, 0); 
     1285 
     1286        // none of these exist, as the tree is only trained with sequences of length 3 
     1287        assertEquals(0, result.size()); 
     1288    } 
     1289 
     1290    @Test 
     1291    public void testGetSequencesWithMostOccurrences_14() throws Exception { 
     1292        Trie<String> fixture = new Trie<String>(); 
     1293        fixture.train(sequence, 3); 
     1294 
     1295        // get all sequences with a minimal length of four that occur exactly once 
     1296        Collection<List<String>> result = fixture.getSequencesWithOccurrenceCount(4, 1); 
     1297 
     1298        // none of these exist, as the tree is only trained with sequences of length 3 
     1299        assertEquals(0, result.size()); 
     1300    } 
     1301 
     1302    @Test 
     1303    public void testGetCount_1() throws Exception { 
     1304        Trie<String> fixture = new Trie<String>(); 
     1305        fixture.train(sequence, 3); 
     1306        List<String> subSequence = new ArrayList<String>(); 
     1307        subSequence.add("a"); 
     1308 
     1309        int result = fixture.getCount(subSequence); 
     1310 
     1311        assertEquals(5, result); 
     1312    } 
     1313 
     1314    @Test 
     1315    public void testGetCount_2() throws Exception { 
     1316        Trie<String> fixture = new Trie<String>(); 
     1317        fixture.train(sequence, 3); 
     1318        List<String> subSequence = new ArrayList<String>(); 
     1319        subSequence.add("a"); 
     1320        subSequence.add("b"); 
     1321 
     1322        int result = fixture.getCount(subSequence); 
     1323 
     1324        assertEquals(2, result); 
     1325    } 
     1326 
     1327    @Test 
     1328    public void testGetCount_3() throws Exception { 
     1329        Trie<String> fixture = new Trie<String>(); 
     1330        fixture.train(sequence, 3); 
     1331        List<String> subSequence = new ArrayList<String>(); 
     1332        subSequence.add("x"); 
     1333 
     1334        int result = fixture.getCount(subSequence); 
     1335 
     1336        assertEquals(0, result); 
     1337    } 
     1338 
     1339    @Test 
     1340    public void testGetCount_4() throws Exception { 
     1341        Trie<String> fixture = new Trie<String>(); 
     1342        fixture.train(sequence, 3); 
     1343        List<String> subSequence = new ArrayList<String>(); 
     1344 
     1345        int result = fixture.getCount(subSequence, "a"); 
     1346 
     1347        assertEquals(5, result); 
     1348    } 
     1349 
     1350    @Test 
     1351    public void testGetCount_5() throws Exception { 
     1352        Trie<String> fixture = new Trie<String>(); 
     1353        fixture.train(sequence, 3); 
     1354        List<String> subSequence = new ArrayList<String>(); 
     1355        subSequence.add("a"); 
     1356        subSequence.add("b"); 
     1357 
     1358        int result = fixture.getCount(subSequence, "r"); 
     1359 
     1360        assertEquals(2, result); 
     1361    } 
     1362 
     1363    @Test 
     1364    public void testGetCount_6() throws Exception { 
     1365        Trie<String> fixture = new Trie<String>(); 
     1366        fixture.train(sequence, 3); 
     1367        List<String> subSequence = new ArrayList<String>(); 
     1368 
     1369        int result = fixture.getCount(subSequence, "x"); 
     1370 
     1371        assertEquals(0, result); 
     1372    } 
     1373 
     1374    @Test 
     1375    public void testGetFollowingSymbols_1() throws Exception { 
     1376        Trie<String> fixture = new Trie<String>(); 
     1377        fixture.train(sequence, 3); 
     1378        List<String> subSequence = new ArrayList<String>(); 
     1379        subSequence.add("a"); 
     1380        Collection<String> expected = new ArrayList<String>(); 
     1381        expected.add("b"); 
     1382        expected.add("c"); 
     1383        expected.add("d"); 
     1384 
     1385        Collection<String> result = fixture.getFollowingSymbols(subSequence); 
     1386 
     1387        assertCollectionContent(expected, result); 
     1388    } 
     1389 
     1390    @Test 
     1391    public void testGetFollowingSymbols_2() throws Exception { 
     1392        Trie<String> fixture = new Trie<String>(); 
     1393        fixture.train(sequence, 3); 
     1394        List<String> subSequence = new ArrayList<String>(); 
     1395        subSequence.add("a"); 
     1396        subSequence.add("b"); 
     1397        subSequence.add("r"); 
     1398 
     1399        Collection<String> result = fixture.getFollowingSymbols(subSequence); 
     1400 
     1401        assertEquals(0, result.size()); 
     1402    } 
     1403 
     1404    @Test 
     1405    public void testGetFollowingSymbols_3() throws Exception { 
     1406        Trie<String> fixture = new Trie<String>(); 
     1407        fixture.train(sequence, 3); 
     1408        List<String> subSequence = new ArrayList<String>(); 
     1409        subSequence.add("x"); 
     1410 
     1411        Collection<String> result = fixture.getFollowingSymbols(subSequence); 
     1412 
     1413        assertEquals(0, result.size()); 
     1414    } 
     1415 
     1416    @Test 
     1417    public void testGetNumLeafAncestors_1() throws Exception { 
     1418        Trie<String> fixture = new Trie<String>(); 
     1419        fixture.train(sequence, 3); 
     1420 
     1421        int result = fixture.getNumLeafAncestors(); 
     1422 
     1423        assertEquals(7, result); 
     1424    } 
     1425 
     1426    @Test 
     1427    public void testGetNumLeafs_1() throws Exception { 
     1428        Trie<String> fixture = new Trie<String>(); 
     1429        fixture.train(sequence, 3); 
     1430 
     1431        int result = fixture.getNumLeafs(); 
     1432 
     1433        assertEquals(7, result); 
     1434    } 
     1435 
     1436    @Test 
     1437    public void testGetNumSymbols_1() throws Exception { 
     1438        Trie<String> fixture = new Trie<String>(); 
     1439        fixture.train(sequence, 3); 
     1440 
     1441        int result = fixture.getNumSymbols(); 
     1442 
     1443        assertEquals(5, result); 
     1444    } 
     1445 
     1446    @Test 
     1447    public void testTrain_1() throws Exception { 
     1448        Trie<String> fixture = new Trie<String>(); 
     1449        int maxOrder = 3; 
     1450 
     1451        fixture.train(sequence, maxOrder); 
     1452 
     1453        // check if symbols are correct 
     1454        assertCollectionContent(symbols, fixture.getKnownSymbols()); 
     1455 
     1456        // check if counters are correct and only the correct nodes exist 
     1457        TrieNode<String> root = fixture.find(new ArrayList<String>()); 
     1458        TrieNode<String> root_a = root.getChild("a"); 
     1459        TrieNode<String> root_a_a = root_a.getChild("a"); 
     1460        TrieNode<String> root_a_b = root_a.getChild("b"); 
     1461        TrieNode<String> root_a_b_a = root_a_b.getChild("a"); 
     1462        TrieNode<String> root_a_b_b = root_a_b.getChild("b"); 
     1463        TrieNode<String> root_a_b_c = root_a_b.getChild("c"); 
     1464        TrieNode<String> root_a_b_d = root_a_b.getChild("d"); 
     1465        TrieNode<String> root_a_b_r = root_a_b.getChild("r"); 
     1466        TrieNode<String> root_a_c = root_a.getChild("c"); 
     1467        TrieNode<String> root_a_c_a = root_a_c.getChild("a"); 
     1468        TrieNode<String> root_a_c_b = root_a_c.getChild("b"); 
     1469        TrieNode<String> root_a_c_c = root_a_c.getChild("c"); 
     1470        TrieNode<String> root_a_c_d = root_a_c.getChild("d"); 
     1471        TrieNode<String> root_a_c_r = root_a_c.getChild("r"); 
     1472        TrieNode<String> root_a_d = root_a.getChild("d"); 
     1473        TrieNode<String> root_a_d_a = root_a_d.getChild("a"); 
     1474        TrieNode<String> root_a_d_b = root_a_d.getChild("b"); 
     1475        TrieNode<String> root_a_d_c = root_a_d.getChild("c"); 
     1476        TrieNode<String> root_a_d_d = root_a_d.getChild("d"); 
     1477        TrieNode<String> root_a_d_r = root_a_d.getChild("r"); 
     1478        TrieNode<String> root_a_r = root_a.getChild("r"); 
     1479        TrieNode<String> root_b = root.getChild("b"); 
     1480        TrieNode<String> root_b_a = root_b.getChild("a"); 
     1481        TrieNode<String> root_b_b = root_b.getChild("b"); 
     1482        TrieNode<String> root_b_c = root_b.getChild("c"); 
     1483        TrieNode<String> root_b_d = root_b.getChild("d"); 
     1484        TrieNode<String> root_b_r = root_b.getChild("r"); 
     1485        TrieNode<String> root_b_r_a = root_b_r.getChild("a"); 
     1486        TrieNode<String> root_b_r_b = root_b_r.getChild("b"); 
     1487        TrieNode<String> root_b_r_c = root_b_r.getChild("c"); 
     1488        TrieNode<String> root_b_r_d = root_b_r.getChild("d"); 
     1489        TrieNode<String> root_b_r_r = root_b_r.getChild("r"); 
     1490        TrieNode<String> root_c = root.getChild("c"); 
     1491        TrieNode<String> root_c_a = root_c.getChild("a"); 
     1492        TrieNode<String> root_c_a_a = root_c_a.getChild("a"); 
     1493        TrieNode<String> root_c_a_b = root_c_a.getChild("b"); 
     1494        TrieNode<String> root_c_a_c = root_c_a.getChild("c"); 
     1495        TrieNode<String> root_c_a_d = root_c_a.getChild("d"); 
     1496        TrieNode<String> root_c_a_r = root_c_a.getChild("r"); 
     1497        TrieNode<String> root_c_b = root_c.getChild("b"); 
     1498        TrieNode<String> root_c_c = root_c.getChild("c"); 
     1499        TrieNode<String> root_c_d = root_c.getChild("d"); 
     1500        TrieNode<String> root_c_r = root_c.getChild("r"); 
     1501        TrieNode<String> root_d = root.getChild("d"); 
     1502        TrieNode<String> root_d_a = root_d.getChild("a"); 
     1503        TrieNode<String> root_d_a_a = root_d_a.getChild("a"); 
     1504        TrieNode<String> root_d_a_b = root_d_a.getChild("b"); 
     1505        TrieNode<String> root_d_a_c = root_d_a.getChild("c"); 
     1506        TrieNode<String> root_d_a_d = root_d_a.getChild("d"); 
     1507        TrieNode<String> root_d_a_r = root_d_a.getChild("r"); 
     1508        TrieNode<String> root_d_b = root_d.getChild("b"); 
     1509        TrieNode<String> root_d_c = root_d.getChild("c"); 
     1510        TrieNode<String> root_d_d = root_d.getChild("d"); 
     1511        TrieNode<String> root_d_r = root_d.getChild("r"); 
     1512        TrieNode<String> root_r = root.getChild("r"); 
     1513        TrieNode<String> root_r_a = root_r.getChild("a"); 
     1514        TrieNode<String> root_r_a_a = root_r_a.getChild("a"); 
     1515        TrieNode<String> root_r_a_b = root_r_a.getChild("b"); 
     1516        TrieNode<String> root_r_a_c = root_r_a.getChild("c"); 
     1517        TrieNode<String> root_r_a_d = root_r_a.getChild("d"); 
     1518        TrieNode<String> root_r_a_r = root_r_a.getChild("r"); 
     1519        TrieNode<String> root_r_b = root_r.getChild("b"); 
     1520        TrieNode<String> root_r_c = root_r.getChild("c"); 
     1521        TrieNode<String> root_r_d = root_r.getChild("d"); 
     1522        TrieNode<String> root_r_r = root_r.getChild("r"); 
     1523 
     1524        assertEquals(5, root_a.getCount()); 
     1525        assertNull(root_a_a); 
     1526        assertEquals(2, root_a_b.getCount()); 
     1527        assertNull(root_a_b_a); 
     1528        assertNull(root_a_b_b); 
     1529        assertNull(root_a_b_c); 
     1530        assertNull(root_a_b_d); 
     1531        assertEquals(2, root_a_b_r.getCount()); 
     1532        assertEquals(1, root_a_c.getCount()); 
     1533        assertEquals(1, root_a_c_a.getCount()); 
     1534        assertNull(root_a_c_b); 
     1535        assertNull(root_a_c_c); 
     1536        assertNull(root_a_c_d); 
     1537        assertNull(root_a_c_r); 
     1538        assertEquals(1, root_a_d.getCount()); 
     1539        assertEquals(1, root_a_d_a.getCount()); 
     1540        assertNull(root_a_d_b); 
     1541        assertNull(root_a_d_c); 
     1542        assertNull(root_a_d_d); 
     1543        assertNull(root_a_d_r); 
     1544        assertNull(root_a_r); 
     1545 
     1546        assertEquals(2, root_b.getCount()); 
     1547        assertNull(root_b_a); 
     1548        assertNull(root_b_b); 
     1549        assertNull(root_b_c); 
     1550        assertNull(root_b_d); 
     1551        assertEquals(2, root_b_r.getCount()); 
     1552        assertEquals(2, root_b_r_a.getCount()); 
     1553        assertNull(root_b_r_b); 
     1554        assertNull(root_b_r_c); 
     1555        assertNull(root_b_r_d); 
     1556        assertNull(root_b_r_r); 
     1557 
     1558        assertEquals(1, root_c.getCount()); 
     1559        assertEquals(1, root_c_a.getCount()); 
     1560        assertNull(root_c_a_a); 
     1561        assertNull(root_c_a_b); 
     1562        assertNull(root_c_a_c); 
     1563        assertEquals(1, root_c_a_d.getCount()); 
     1564        assertNull(root_c_a_r); 
     1565        assertNull(root_c_b); 
     1566        assertNull(root_c_c); 
     1567        assertNull(root_c_d); 
     1568        assertNull(root_c_r); 
     1569 
     1570        assertEquals(1, root_d.getCount()); 
     1571        assertEquals(1, root_d_a.getCount()); 
     1572        assertNull(root_d_a_a); 
     1573        assertEquals(1, root_d_a_b.getCount()); 
     1574        assertNull(root_d_a_c); 
     1575        assertNull(root_d_a_d); 
     1576        assertNull(root_d_a_r); 
     1577        assertNull(root_d_b); 
     1578        assertNull(root_d_c); 
     1579        assertNull(root_d_d); 
     1580        assertNull(root_d_r); 
     1581 
     1582        assertEquals(2, root_r.getCount()); 
     1583        assertEquals(2, root_r_a.getCount()); 
     1584        assertNull(root_r_a_a); 
     1585        assertNull(root_r_a_b); 
     1586        assertEquals(1, root_r_a_c.getCount()); 
     1587        assertNull(root_r_a_d); 
     1588        assertNull(root_r_a_r); 
     1589        assertNull(root_r_b); 
     1590        assertNull(root_r_c); 
     1591        assertNull(root_r_d); 
     1592        assertNull(root_r_r); 
     1593 
     1594        // check if leafs are really leafs 
     1595        assertTrue(root_a_b_r.isLeaf()); 
     1596        assertTrue(root_a_c_a.isLeaf()); 
     1597        assertTrue(root_a_d_a.isLeaf()); 
     1598        assertTrue(root_b_r_a.isLeaf()); 
     1599        assertTrue(root_c_a_d.isLeaf()); 
     1600        assertTrue(root_d_a_b.isLeaf()); 
     1601        assertTrue(root_r_a_c.isLeaf()); 
     1602    } 
     1603 
     1604    @Test 
     1605    public void testTrain_2() throws Exception { 
     1606        Trie<String> fixture = new Trie<String>(); 
     1607        int maxOrder = 0; 
     1608 
     1609        fixture.train(sequence, maxOrder); 
     1610 
     1611        assertTrue(fixture.getKnownSymbols().isEmpty()); 
     1612    } 
     1613 
     1614    @Test 
     1615    public void testTrain_3() throws Exception { 
     1616        Trie<Object> fixture = new Trie<Object>(); 
     1617        List<Object> sequence = new ArrayList<Object>(); 
     1618        int maxOrder = 1; 
     1619 
     1620        fixture.train(sequence, maxOrder); 
     1621 
     1622        assertTrue(fixture.getKnownSymbols().isEmpty()); 
     1623    } 
     1624 
     1625    @Test 
     1626    public void testTrain_4() throws Exception { 
     1627        Trie<String> fixture = new Trie<String>(); 
     1628        List<String> sequence = new ArrayList<String>(); 
     1629        sequence.add("a"); 
     1630        sequence.add("b"); 
     1631        int maxOrder = 3; 
     1632 
     1633        fixture.train(sequence, maxOrder); 
     1634 
     1635        assertCollectionContent(sequence, fixture.getKnownSymbols()); 
     1636        TrieNode<String> root = fixture.find(new ArrayList<String>()); 
     1637        TrieNode<String> root_a = root.getChild("a"); 
     1638        TrieNode<String> root_a_a = root_a.getChild("a"); 
     1639        TrieNode<String> root_a_b = root_a.getChild("b"); 
     1640        TrieNode<String> root_b = root.getChild("b"); 
     1641        TrieNode<String> root_b_a = root_b.getChild("a"); 
     1642        TrieNode<String> root_b_b = root_b.getChild("b"); 
     1643 
     1644        assertEquals(1, root_a.getCount()); 
     1645        assertNull(root_a_a); 
     1646        assertEquals(1, root_a_b.getCount()); 
     1647        assertEquals(1, root_b.getCount()); 
     1648        assertNull(root_b_a); 
     1649        assertNull(root_b_b); 
     1650 
     1651        assertTrue(root_a_b.isLeaf()); 
     1652        assertTrue(root_b.isLeaf()); 
     1653    } 
     1654 
     1655    @Test 
     1656    public void testEdgeEdge_1() throws Exception { 
     1657        Edge result = new Edge(); 
     1658 
     1659        assertNotNull(result); 
     1660    } 
     1661 
     1662    @Test 
     1663    public void testTrieVertexTrieVertex_1() throws Exception { 
     1664        String id = "idString"; 
     1665 
     1666        TrieVertex result = new TrieVertex(id); 
     1667 
     1668        assertNotNull(result); 
     1669    } 
     1670 
     1671    @Test 
     1672    public void testTrieVertexToString_1() throws Exception { 
     1673        String id = "idString"; 
     1674        TrieVertex fixture = new TrieVertex(id); 
     1675 
     1676        String result = fixture.toString(); 
     1677 
     1678        assertEquals(id, result); 
     1679    } 
     1680 
     1681    @Test 
     1682    public void testEquals_1() throws Exception { 
     1683        Trie<String> trieOther = new Trie<String>(); 
     1684        Trie<String> fixture = new Trie<String>(); 
     1685 
     1686        boolean result = fixture.equals(trieOther); 
     1687 
     1688        assertEquals(true, result); 
     1689    } 
     1690 
     1691    @Test 
     1692    public void testEquals_2() throws Exception { 
     1693        Trie<String> trieOther = new Trie<String>(); 
     1694        trieOther.train(sequence, 2); 
     1695        Trie<String> fixture = new Trie<String>(); 
     1696        fixture.train(sequence, 2); 
     1697 
     1698        boolean result = fixture.equals(trieOther); 
     1699 
     1700        assertEquals(true, result); 
     1701    } 
     1702 
     1703    @Test 
     1704    public void testEquals_3() throws Exception { 
     1705        Trie<String> trieOther = new Trie<String>(); 
     1706        trieOther.train(sequence, 2); 
     1707        Trie<String> fixture = new Trie<String>(); 
     1708        fixture.train(sequence, 3); 
     1709 
     1710        boolean result = fixture.equals(trieOther); 
     1711 
     1712        assertEquals(false, result); 
     1713    } 
     1714 
     1715    @Test 
     1716    public void testEquals_4() throws Exception { 
     1717        Trie<String> trieOther = new Trie<String>(); 
     1718        Trie<String> fixture = new Trie<String>(); 
     1719        fixture.train(sequence, 2); 
     1720 
     1721        boolean result = fixture.equals(trieOther); 
     1722 
     1723        assertEquals(false, result); 
     1724    } 
     1725 
     1726    @Test 
     1727    public void testEquals_5() throws Exception { 
     1728        Trie<String> trieOther = new Trie<String>(); 
     1729        trieOther.train(sequence, 2); 
     1730        Trie<String> fixture = new Trie<String>(); 
     1731 
     1732        boolean result = fixture.equals(trieOther); 
     1733 
     1734        assertEquals(false, result); 
     1735    } 
     1736 
     1737    @Test 
     1738    public void testEquals_6() throws Exception { 
     1739        Trie<String> fixture = new Trie<String>(); 
     1740        fixture.train(sequence, 2); 
     1741 
     1742        boolean result = fixture.equals(fixture); 
     1743 
     1744        assertEquals(true, result); 
     1745    } 
     1746 
     1747    @Test 
     1748    public void testEquals_7() throws Exception { 
     1749        Trie<String> fixture = new Trie<String>(); 
     1750        fixture.train(sequence, 2); 
     1751 
     1752        boolean result = fixture.equals(null); 
     1753 
     1754        assertEquals(false, result); 
     1755    } 
     1756 
     1757    @Before 
     1758    public void setUp() throws Exception { 
     1759        sequence = new ArrayList<String>(); 
     1760        sequence.add("a"); 
     1761        sequence.add("b"); 
     1762        sequence.add("r"); 
     1763        sequence.add("a"); 
     1764        sequence.add("c"); 
     1765        sequence.add("a"); 
     1766        sequence.add("d"); 
     1767        sequence.add("a"); 
     1768        sequence.add("b"); 
     1769        sequence.add("r"); 
     1770        sequence.add("a"); 
     1771 
     1772        symbols = new HashSet<String>(); 
     1773        symbols.add("a"); 
     1774        symbols.add("b"); 
     1775        symbols.add("c"); 
     1776        symbols.add("d"); 
     1777        symbols.add("r"); 
     1778    } 
     1779 
     1780    public static void main(String[] args) { 
     1781        new org.junit.runner.JUnitCore().run(TrieTest.class); 
     1782    } 
     1783 
    17871784} 
Note: See TracChangeset for help on using the changeset viewer.