// ================================================================================================= // Copyright 2011 Twitter, Inc. // ------------------------------------------------------------------------------------------------- // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this work except in compliance with the License. // You may obtain a copy of the License in the LICENSE file, or at: // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // ================================================================================================= package com.twitter.common.text.combiner; import static org.junit.Assert.assertEquals; import org.junit.Before; import org.junit.Test; import com.google.common.collect.Lists; import com.twitter.common.text.token.TokenStream; import com.twitter.common.text.tokenizer.LatinTokenizer; public class DotContractedTokenCombinerTest { private TokenStream stream; @Before public void setup() { stream = new DotContractedTokenCombiner( new LatinTokenizer.Builder().setKeepPunctuation(true).build()); } @Test public void test() { test("Dr. Fujii works at Twitter Inc.", "Dr.", "Fujii", "works", "at", "Twitter", "Inc."); test("Mr. Fujii and Mrs. Fujii are married.", "Mr.", "Fujii", "and", "Mrs.", "Fujii", "are", "married", "."); test("no contracted word.", "no", "contracted", "word", "."); test("Mr Fujii and Mrs Fujii are married.", "Mr", "Fujii", "and", "Mrs", "Fujii", "are", "married", "."); } private void test(String text, String... tokens) { stream.reset(text); assertEquals(Lists.newArrayList(tokens), stream.toStringList()); } }