/* * Copyright (c) 2006, 2007, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code 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 * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ /* * @test * @bug 5017980 6576055 * @summary Test parsing methods * @author Joseph D. Darcy */ import sun.misc.SharedSecrets; import sun.misc.JavaLangAccess; /** * There are six methods in java.lang.Long which transform strings * into a long or Long value: * * public Long(String s) * public static Long decode(String nm) * public static long parseLong(String s, int radix) * public static long parseLong(String s) * public static Long valueOf(String s, int radix) * public static Long valueOf(String s) * * Besides decode, all the methods and constructor call down into * parseLong(String, int) to do the actual work. Therefore, the * behavior of parseLong(String, int) will be tested here. * * Internally, parseLong(String, int, int, int) has been added to * support parsing subsequences without explicit substrings. These will also * be tested here */ public class ParsingTest { private static JavaLangAccess jla = SharedSecrets.getJavaLangAccess(); public static void main(String... argv) { check("+100", +100L); check("-100", -100L); check("+0", 0L); check("-0", 0L); check("+00000", 0L); check("-00000", 0L); check("0", 0L); check("1", 1L); check("9", 9L); checkFailure("\u0000"); checkFailure("\u002f"); checkFailure("+"); checkFailure("-"); checkFailure("++"); checkFailure("+-"); checkFailure("-+"); checkFailure("--"); checkFailure("++100"); checkFailure("--100"); checkFailure("+-6"); checkFailure("-+6"); checkFailure("*100"); check("test-00000", 0L, 4, 10); check("test-12345", -12345L, 4, 10); check("xx12345yy", 12345L, 2, 7); check("xx123456789012345yy", 123456789012345L, 2, 17); checkFailure("+00000", 0, 7); checkFailure("-00000", 0, 7); checkFailure("-00000", 6, 6); checkFailure("-00000", 6, 0); checkFailure("+-6", 0, 3); } private static void check(String val, long expected) { long n = Long.parseLong(val); if (n != expected) throw new RuntimeException("Long.parseLong failed. String:" + val + " Result:" + n); } private static void checkFailure(String val) { long n = 0L; try { n = Long.parseLong(val); System.err.println("parseLong(" + val + ") incorrectly returned " + n); throw new RuntimeException(); } catch (NumberFormatException nfe) { ; // Expected } } private static void checkFailure(String val, int start, int end) { long n = 0L; try { n = jla.parseLong(val, 10, start, end); System.err.println("parseLong(" + val + ") incorrectly returned " + n); throw new RuntimeException(); } catch (NumberFormatException nfe) { ; // Expected } } private static void check(String val, long expected, int start, int end) { long n = jla.parseLong(val, 10, start, end); if (n != expected) throw new RuntimeException("Long.parseLong failed. String:" + val + " Result:" + n); } }