1 /*
   2  * Copyright (c) 2012, 2016, Oracle and/or its affiliates. All rights reserved.
   3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
   4  *
   5  * This code is free software; you can redistribute it and/or modify it
   6  * under the terms of the GNU General Public License version 2 only, as
   7  * published by the Free Software Foundation.
   8  *
   9  * This code is distributed in the hope that it will be useful, but WITHOUT
  10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  11  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
  12  * version 2 for more details (a copy is included in the LICENSE file that
  13  * accompanied this code).
  14  *
  15  * You should have received a copy of the GNU General Public License version
  16  * 2 along with this work; if not, write to the Free Software Foundation,
  17  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
  18  *
  19  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
  20  * or visit www.oracle.com if you need additional information or have any
  21  * questions.
  22  */
  23 
  24 /*
  25  * This file is available under and governed by the GNU General Public
  26  * License version 2 only, as published by the Free Software Foundation.
  27  * However, the following notice accompanied the original version of this
  28  * file:
  29  *
  30  * Copyright (c) 2008-2012, Stephen Colebourne & Michael Nascimento Santos
  31  *
  32  * All rights reserved.
  33  *
  34  * Redistribution and use in source and binary forms, with or without
  35  * modification, are permitted provided that the following conditions are met:
  36  *
  37  *  * Redistributions of source code must retain the above copyright notice,
  38  *    this list of conditions and the following disclaimer.
  39  *
  40  *  * Redistributions in binary form must reproduce the above copyright notice,
  41  *    this list of conditions and the following disclaimer in the documentation
  42  *    and/or other materials provided with the distribution.
  43  *
  44  *  * Neither the name of JSR-310 nor the names of its contributors
  45  *    may be used to endorse or promote products derived from this software
  46  *    without specific prior written permission.
  47  *
  48  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  49  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  50  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  51  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
  52  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
  53  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  54  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
  55  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
  56  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
  57  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
  58  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  59  */
  60 
  61 /*
  62  * @test
  63  * @modules jdk.localedata
  64  */
  65 
  66 package test.java.time.format;
  67 
  68 import java.text.ParsePosition;
  69 import java.time.DayOfWeek;
  70 import java.time.format.DateTimeFormatter;
  71 import java.time.format.TextStyle;
  72 import java.time.temporal.TemporalField;
  73 import java.util.Locale;
  74 
  75 import org.testng.annotations.DataProvider;
  76 import org.testng.annotations.Test;
  77 
  78 import static java.time.temporal.ChronoField.DAY_OF_WEEK;
  79 import static java.time.temporal.ChronoField.MONTH_OF_YEAR;
  80 import static org.testng.Assert.assertEquals;
  81 
  82 /**
  83  * Test TextPrinterParser.
  84  */
  85 @Test
  86 public class TestTextParserWithLocale extends AbstractTestPrinterParser {
  87     static final Locale RUSSIAN = new Locale("ru");
  88     static final Locale FINNISH = new Locale("fi");
  89 
  90     @DataProvider(name="parseDayOfWeekText")
  91     Object[][] providerDayOfWeekData() {
  92         return new Object[][] {
  93             // Locale, pattern, input text, expected DayOfWeek
  94             {Locale.US, "e",  "1",  DayOfWeek.SUNDAY},
  95             {Locale.US, "ee", "01", DayOfWeek.SUNDAY},
  96             {Locale.US, "c",  "1",  DayOfWeek.SUNDAY},
  97 
  98             {Locale.UK, "e",  "1",  DayOfWeek.MONDAY},
  99             {Locale.UK, "ee", "01", DayOfWeek.MONDAY},
 100             {Locale.UK, "c",  "1",  DayOfWeek.MONDAY},
 101         };
 102     }
 103 
 104     @Test(dataProvider="parseDayOfWeekText")
 105     public void test_parseDayOfWeekText(Locale locale, String pattern, String input, DayOfWeek expected) {
 106         DateTimeFormatter formatter = getPatternFormatter(pattern).withLocale(locale);
 107         ParsePosition pos = new ParsePosition(0);
 108         assertEquals(DayOfWeek.from(formatter.parse(input, pos)), expected);
 109         assertEquals(pos.getIndex(), input.length());
 110     }
 111 
 112     //--------------------------------------------------------------------
 113     // Test data is dependent on localized resources.
 114     @DataProvider(name="parseStandaloneText")
 115     Object[][] providerStandaloneText() {
 116         // Locale, TemporalField, TextStyle, expected value, input text
 117         return new Object[][] {
 118             {RUSSIAN, MONTH_OF_YEAR, TextStyle.FULL_STANDALONE,   1, "\u044f\u043d\u0432\u0430\u0440\u044c"},
 119             {RUSSIAN, MONTH_OF_YEAR, TextStyle.FULL_STANDALONE,  12, "\u0434\u0435\u043a\u0430\u0431\u0440\u044c"},
 120             {RUSSIAN, MONTH_OF_YEAR, TextStyle.SHORT_STANDALONE,  1, "\u044f\u043d\u0432."},
 121             {RUSSIAN, MONTH_OF_YEAR, TextStyle.SHORT_STANDALONE, 12, "\u0434\u0435\u043a."},
 122             {FINNISH, DAY_OF_WEEK,   TextStyle.FULL_STANDALONE,   2, "tiistai"},
 123             {FINNISH, DAY_OF_WEEK,   TextStyle.SHORT_STANDALONE,  2, "ti"},
 124         };
 125     }
 126 
 127     // Test data is dependent on localized resources.
 128     @DataProvider(name="parseLenientText")
 129     Object[][] providerLenientText() {
 130         // Locale, TemporalField, expected value, input text
 131         return new Object[][] {
 132             {RUSSIAN, MONTH_OF_YEAR, 1, "\u044f\u043d\u0432\u0430\u0440\u044f"}, // full format
 133             {RUSSIAN, MONTH_OF_YEAR, 1, "\u044f\u043d\u0432\u0430\u0440\u044c"}, // full standalone
 134             {RUSSIAN, MONTH_OF_YEAR, 1, "\u044f\u043d\u0432."}, // short format
 135             {RUSSIAN, MONTH_OF_YEAR, 1, "\u044f\u043d\u0432."}, // short standalone
 136         };
 137     }
 138 
 139     @Test(dataProvider="parseStandaloneText")
 140     public void test_parseStandaloneText(Locale locale, TemporalField field, TextStyle style, int expectedValue, String input) {
 141         DateTimeFormatter formatter = getFormatter(field, style).withLocale(locale);
 142         ParsePosition pos = new ParsePosition(0);
 143         assertEquals(formatter.parseUnresolved(input, pos).getLong(field), (long) expectedValue);
 144         assertEquals(pos.getIndex(), input.length());
 145     }
 146 
 147     //-----------------------------------------------------------------------
 148     public void test_parse_french_short_strict_full_noMatch() throws Exception {
 149         setStrict(true);
 150         ParsePosition pos = new ParsePosition(0);
 151         getFormatter(MONTH_OF_YEAR, TextStyle.SHORT).withLocale(Locale.FRENCH)
 152                                                     .parseUnresolved("janvier", pos);
 153         assertEquals(pos.getErrorIndex(), 0);
 154     }
 155 
 156     public void test_parse_french_short_strict_short_match() throws Exception {
 157         setStrict(true);
 158         ParsePosition pos = new ParsePosition(0);
 159         assertEquals(getFormatter(MONTH_OF_YEAR, TextStyle.SHORT).withLocale(Locale.FRENCH)
 160                                                                  .parseUnresolved("janv.", pos)
 161                                                                  .getLong(MONTH_OF_YEAR),
 162                      1L);
 163         assertEquals(pos.getIndex(), 5);
 164     }
 165 
 166     //-----------------------------------------------------------------------
 167 
 168     @Test(dataProvider="parseLenientText")
 169     public void test_parseLenientText(Locale locale, TemporalField field, int expectedValue, String input) {
 170         setStrict(false);
 171         ParsePosition pos = new ParsePosition(0);
 172         DateTimeFormatter formatter = getFormatter(field).withLocale(locale);
 173         assertEquals(formatter.parseUnresolved(input, pos).getLong(field), (long) expectedValue);
 174         assertEquals(pos.getIndex(), input.length());
 175     }
 176 
 177 }