Subversion Repositories mkgmap

Rev

Rev 3408 | Blame | Compare with Previous | Last modification | View Log | RSS feed

/*
 * Copyright (C) 2014.
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 3 or
 * version 2 as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * General Public License for more details.
 */

package uk.me.parabola.imgfmt.app.srt;

import java.text.Collator;

import uk.me.parabola.mkgmap.srt.SrtTextReader;

import org.junit.Before;
import org.junit.Test;

import static org.junit.Assert.*;

public class SrtCollatorTest {

        private Collator collator;

        @Before
        public void setUp() {
                Sort sort = SrtTextReader.sortForCodepage(1252);
                collator = sort.getCollator();
        }

        /**
         * Test primary strength comparisons.
         */

        @Test
        public void testPrimary() {
                collator.setStrength(Collator.PRIMARY);
                assertEquals("prim: different case", 0, collator.compare("AabBb", "aabbb"));
                assertEquals("prim: different case", 0, collator.compare("aabBb", "aabbb"));
                assertEquals("prim: different length", -1, collator.compare("AabB", "aabbb"));
                assertEquals("prim: different letter", -1, collator.compare("aaac", "aaad"));
                assertEquals("prim: different letter", 1, collator.compare("aaae", "aaad"));
                assertEquals(0, collator.compare("aaaa", "aaaa"));
                assertEquals(0, collator.compare("aáÄâ", "aaaa"));
        }

        @Test
        public void testSecondary() {
                collator.setStrength(Collator.SECONDARY);
                assertEquals(0, collator.compare("AabBb", "aabbb"));
                assertEquals(0, collator.compare("aabBb", "aabBb"));
                assertEquals(0, collator.compare("aabbB", "aabBb"));
                assertEquals(1, collator.compare("aáÄâ", "aaaa"));
                assertEquals("prim len diff", -1, collator.compare("aáÄâ", "aaaaa"));
                assertEquals(-1, collator.compare("aáÄâa", "aaaab"));
        }

        @Test
        public void testTertiary() {
                collator.setStrength(Collator.TERTIARY);
                assertEquals("prim: different case", 1, collator.compare("AabBb", "aabbb"));
                assertEquals(1, collator.compare("AabBb", "aabbb"));
                assertEquals(0, collator.compare("aabBb", "aabBb"));
                assertEquals(-1, collator.compare("aabbB", "aabBb"));
                assertEquals(-1, collator.compare("aAbb", "aabbb"));
                assertEquals(1, collator.compare("t", "a"));
                assertEquals(1, collator.compare("ß", "a"));
                assertEquals(-1, collator.compare("ESA", "Eß"));
                assertEquals(-1, collator.compare(":.e", "\u007fæ"));
                assertEquals(-1, collator.compare(";œ", ";Œ"));
                assertEquals(-1, collator.compare("œ;", "Œ;"));
        }

        /**
         * Test that ignorable characters do not affect the result in otherwise identical strings.
         */

        @Test
        public void testIgnoreable() throws Exception {
                assertEquals("ignorable at beginning", 0, collator.compare("\u0008fred", "fred"));
                assertEquals("ignorable at end", 0, collator.compare("fred\u0008", "fred"));
                assertEquals("ignorable in middle", 0, collator.compare("fr\u0008ed", "fred"));
                assertEquals(1, collator.compare("\u0001A", "A\u0008"));

                collator.setStrength(Collator.PRIMARY);
                assertEquals("prim: different case", 0, collator.compare("AabBb\u0008", "aabbb"));
        }

        @Test
        public void testSecondaryIgnorable() {
                assertEquals(-1, collator.compare("A", "A\u0001"));
        }

        @Test
        public void testLengths() {
                assertEquals(-1, collator.compare("-Û", "-ü:X"));
                assertEquals(-1, collator.compare("-Û", "-Û$"));
                assertEquals(-1, collator.compare("-ü:X", "-Û$"));
                assertEquals(-1, collator.compare("–", "–X"));
                assertEquals(1, collator.compare("–TÛ‡²", "–"));
        }

        @Test
        public void testSpaces() {
                assertEquals(1, collator.compare("øþõ Ñ", "õþO"));
        }

        /**
         * Test using the java collator, to experiment. Note that our implementation is not
         * meant to be identical to the java one.
         */

        @Test
        public void testJavaRules() {
                Collator collator = Collator.getInstance();

                // Testing ignorable
                assertEquals(0, collator.compare("\u0001fred", "fred"));
                assertEquals(0, collator.compare("fre\u0001d", "fred"));

                collator.setStrength(Collator.PRIMARY);
                assertEquals("prim: different case", 0, collator.compare("AabBb", "aabbb"));
                assertEquals("prim: different case", 0, collator.compare("aabBb", "aabbb"));
                assertEquals("prim: different length", -1, collator.compare("AabB", "aabbb"));
                assertEquals("prim: different letter", -1, collator.compare("aaac", "aaad"));
                assertEquals("prim: different letter", 1, collator.compare("aaae", "aaad"));
                assertEquals(0, collator.compare("aaaa", "aaaa"));
                assertEquals(0, collator.compare("aáÄâ", "aaaa"));

                collator.setStrength(Collator.SECONDARY);
                assertEquals(0, collator.compare("AabBb", "aabbb"));
                assertEquals(0, collator.compare("aabBb", "aabBb"));
                assertEquals(0, collator.compare("aabbB", "aabBb"));
                assertEquals(1, collator.compare("aáÄâ", "aaaa"));
                assertEquals("prim len diff", -1, collator.compare("aáÄâ", "aaaaa"));
                assertEquals(-1, collator.compare("aáÄâa", "aaaab"));

                collator.setStrength(Collator.TERTIARY);
                assertEquals("prim: different case", 1, collator.compare("AabBb", "aabbb"));
                assertEquals(1, collator.compare("AabBb", "aabbb"));
                assertEquals(0, collator.compare("aabBb", "aabBb"));
                assertEquals(-1, collator.compare("aabbB", "aabBb"));
                assertEquals(-1, collator.compare("aAbb", "aabbb"));
                assertEquals(1, collator.compare("t", "a"));
        }

}