Path: blob/aarch64-shenandoah-jdk8u272-b10/jdk/test/java/util/TimeZone/Bug5097350.java
38812 views
/*1* Copyright (c) 2004, 2016, Oracle and/or its affiliates. All rights reserved.2* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.3*4* This code is free software; you can redistribute it and/or modify it5* under the terms of the GNU General Public License version 2 only, as6* published by the Free Software Foundation.7*8* This code is distributed in the hope that it will be useful, but WITHOUT9* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or10* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License11* version 2 for more details (a copy is included in the LICENSE file that12* accompanied this code).13*14* You should have received a copy of the GNU General Public License version15* 2 along with this work; if not, write to the Free Software Foundation,16* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.17*18* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA19* or visit www.oracle.com if you need additional information or have any20* questions.21*/2223/*24* @test25* @bug 509735026* @summary Make sure that TimeZone.getTimeZone returns a clone of a cached TimeZone instance.27*/2829import java.util.*;30import java.text.*;3132public class Bug5097350 {33public static void main(String[] args) {34String[] tzids = TimeZone.getAvailableIDs();35List<String> ids = new ArrayList<>(tzids.length + 10);36ids.addAll(Arrays.asList(tzids));37// add some custom ids38ids.add("GMT+1");39ids.add("GMT-7:00");40ids.add("GMT+10:20");41ids.add("GMT-00:00");42ids.add("GMT+00:00");4344for (String id : ids) {45test(id);46}47}4849private static void test(String id) {50TimeZone tz1 = TimeZone.getTimeZone(id);51int offset1 = tz1.getRawOffset();52tz1.setRawOffset(offset1 + 13 * 60 * 60 * 1000);5354TimeZone tz2 = TimeZone.getTimeZone(id);55if (tz1 == tz2) {56throw new RuntimeException("TimeZones are identical: " + id);57}58if (offset1 != tz2.getRawOffset()) {59throw new RuntimeException("Offset changed through aliasing: " + id);60}61}62}636465