177 lines
6.7 KiB
Java
177 lines
6.7 KiB
Java
|
/*
|
||
|
* Copyright (c) 2007 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
||
|
* CA 95054 USA or visit www.sun.com if you need additional information or
|
||
|
* have any questions.
|
||
|
*/
|
||
|
/*
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
/*
|
||
|
* This class is used by ExpirationTest.sh. See the timing information in
|
||
|
* the shell script.
|
||
|
*/
|
||
|
|
||
|
import java.util.*;
|
||
|
|
||
|
public class ExpirationTest {
|
||
|
static final Locale AUSTRIA = new Locale("de", "AT");
|
||
|
static String format;
|
||
|
static String fileType;
|
||
|
|
||
|
public static void main(String[] args) {
|
||
|
// If -latency is specified, try sleeping for 3 seconds 3
|
||
|
// times to see its latency. If the latency is too large, then
|
||
|
// the program exits with 2. (See sleep())
|
||
|
if ("-latency".equals(args[0])) {
|
||
|
System.out.print("Checking latency... ");
|
||
|
for (int i = 0; i < 3; i++) {
|
||
|
sleep(3);
|
||
|
}
|
||
|
System.out.println("done");
|
||
|
System.exit(0);
|
||
|
}
|
||
|
|
||
|
format = args[0];
|
||
|
fileType = args[1];
|
||
|
|
||
|
Locale loc = Locale.getDefault();
|
||
|
try {
|
||
|
Locale.setDefault(Locale.JAPAN);
|
||
|
ResourceBundle.Control control = new TestControl();
|
||
|
ResourceBundle rb = ResourceBundle.getBundle("ExpirationData", Locale.GERMAN,
|
||
|
control);
|
||
|
check(rb.getString("data"), "German");
|
||
|
|
||
|
rb = ResourceBundle.getBundle("ExpirationData", AUSTRIA, control);
|
||
|
check(rb.getString("january"), "Januar");
|
||
|
|
||
|
// Wait until the instance gets expired in the cache in 7 seconds.
|
||
|
sleep(7);
|
||
|
|
||
|
// At this point, it should be determined that reloading is not needed.
|
||
|
rb = ResourceBundle.getBundle("ExpirationData", Locale.GERMAN, control);
|
||
|
check(rb.getString("data"), "German");
|
||
|
|
||
|
rb = ResourceBundle.getBundle("ExpirationData", AUSTRIA, control);
|
||
|
check(rb.getString("january"), "Januar");
|
||
|
|
||
|
// Wait until the instance in the cache gets expired again and
|
||
|
// ExpirationData_de gets updated.
|
||
|
// 33 = 40 - 7 (See the timing chart in ExpirationTest.sh)
|
||
|
sleep(33);
|
||
|
|
||
|
// At this point, getBundle must reload the updated
|
||
|
// ExpirationData_de and ExpirationData_de_AT must be
|
||
|
// avaible.
|
||
|
|
||
|
rb = ResourceBundle.getBundle("ExpirationData", Locale.GERMAN, control);
|
||
|
try {
|
||
|
check(rb.getString("data"), "Deutsch");
|
||
|
} catch (RuntimeException e) {
|
||
|
if (format.equals("class")) {
|
||
|
// Class loader doesn't load updated classes.
|
||
|
System.out.println("Known class limitation: " + e.getMessage());
|
||
|
}
|
||
|
}
|
||
|
|
||
|
rb = ResourceBundle.getBundle("ExpirationData", AUSTRIA, control);
|
||
|
try {
|
||
|
check(rb.getString("january"), "J\u00e4nner");
|
||
|
} catch (RuntimeException e) {
|
||
|
if (fileType.equals("jar")) {
|
||
|
// Jar doesn't load new entries.
|
||
|
System.out.println("Known jar limitation: " + e.getMessage());
|
||
|
} else {
|
||
|
throw e;
|
||
|
}
|
||
|
}
|
||
|
} finally {
|
||
|
Locale.setDefault(loc);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
private static void check(String s, String expected) {
|
||
|
String time = getTime();
|
||
|
if (!s.equals(expected)) {
|
||
|
throw new RuntimeException("got '" + s + "', expected '" + expected + "' at "
|
||
|
+ time);
|
||
|
}
|
||
|
System.out.println("ExpirationTest: got '" + s + "' at " + time);
|
||
|
}
|
||
|
|
||
|
private static void sleep(int seconds) {
|
||
|
long millis = seconds * 1000;
|
||
|
long start = System.currentTimeMillis();
|
||
|
try {
|
||
|
Thread.sleep(millis);
|
||
|
} catch (InterruptedException e) {
|
||
|
}
|
||
|
long end = System.currentTimeMillis();
|
||
|
long latency = end - start - millis;
|
||
|
// If the latecy is more than 1% of the requested sleep time,
|
||
|
// then give up the testing.
|
||
|
if (latency > millis/100) {
|
||
|
System.err.printf("Latency is too large: slept for %d [ms], "
|
||
|
+ "expected %d [ms] latency rate: %+.2f%% (expected not more than 1%%)%n"
|
||
|
+ "exiting...%n",
|
||
|
end - start, millis, (double)latency*100.0/millis);
|
||
|
System.exit(2);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
private static final String getTime() {
|
||
|
return new Date().toString().substring(11, 19);
|
||
|
}
|
||
|
|
||
|
private static class TestControl extends ResourceBundle.Control {
|
||
|
@Override
|
||
|
public long getTimeToLive(String name, Locale loc) {
|
||
|
return 5000; // 5 seconds
|
||
|
}
|
||
|
|
||
|
@Override
|
||
|
public ResourceBundle newBundle(String name, Locale loc,
|
||
|
String fmt, ClassLoader cl, boolean reload)
|
||
|
throws IllegalAccessException, InstantiationException, java.io.IOException {
|
||
|
ResourceBundle bundle = super.newBundle(name, loc, fmt, cl, reload);
|
||
|
if (bundle != null) {
|
||
|
System.out.println("newBundle: " + (reload ? "**re" : "")
|
||
|
+ "loaded '" + toName(name, loc , fmt) + "' at " + getTime());
|
||
|
}
|
||
|
return bundle;
|
||
|
}
|
||
|
|
||
|
@Override
|
||
|
public boolean needsReload(String name, Locale loc,
|
||
|
String fmt, ClassLoader cl,
|
||
|
ResourceBundle rb, long time) {
|
||
|
boolean b = super.needsReload(name, loc, fmt, cl, rb, time);
|
||
|
System.out.println("needsReload: '" + b + "' for " + toName(name, loc, fmt)
|
||
|
+ " at " + getTime());
|
||
|
return b;
|
||
|
}
|
||
|
|
||
|
private String toName(String name, Locale loc, String fmt) {
|
||
|
return toResourceName(toBundleName(name, loc), fmt.substring(5));
|
||
|
}
|
||
|
}
|
||
|
}
|