1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135
|
// Tags: JDK1.4
// Uses: TestLogger TestResourceBundle TestSecurityManager
// Copyright (C) 2004 Sascha Brawer <brawer@dandelis.ch>
// This file is part of Mauve.
// Mauve is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 2, or (at your option)
// any later version.
// Mauve 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.
// You should have received a copy of the GNU General Public License
// along with Mauve; see the file COPYING. If not, write to
// the Free Software Foundation, 59 Temple Place - Suite 330,
// Boston, MA 02111-1307, USA.
package gnu.testlet.java.util.logging.Logger;
import gnu.testlet.Testlet;
import gnu.testlet.TestHarness;
import java.util.logging.Logger;
import java.util.MissingResourceException;
/**
* @author <a href="mailto:brawer@dandelis.ch">Sascha Brawer</a>
*/
public class getLogger
implements Testlet
{
TestSecurityManager sec = new TestSecurityManager();
public void test(TestHarness h)
{
Logger fooLogger = null;
Logger barLogger = null;
Throwable caught;
final String loggerName = TestLogger.class.getName();
try
{
sec.install();
// Check #1.
sec.setGrantLoggingControl(false);
h.check(Logger.getLogger("global") == Logger.global);
// Check #2.
sec.setGrantLoggingControl(false);
caught = null;
try
{
fooLogger = Logger.getLogger(
"gnu.testlet.java.util.logging.Logger.TestLogger");
}
catch (Exception ex)
{
caught = ex;
}
h.check(caught instanceof SecurityException);
// Check #3.
sec.setGrantLoggingControl(true);
try
{
fooLogger = Logger.getLogger(loggerName);
h.check(true);
}
catch (Exception ex)
{
h.check(false);
h.debug(ex);
}
// Check #4.
sec.setGrantLoggingControl(false);
h.check(fooLogger.getName(), loggerName);
// Check #5.
sec.setGrantLoggingControl(false);
h.check(fooLogger.getResourceBundle() == null);
// Check #6: Can retrieve existing logger without LoggingPermission.
sec.setGrantLoggingControl(false);
h.check(Logger.getLogger(loggerName) == fooLogger);
// Check #7.
sec.setGrantLoggingControl(false);
try
{
Logger.getLogger(loggerName, "NonexistingResource");
h.check(false);
}
catch (MissingResourceException _)
{
h.check(true);
}
catch (Exception ex)
{
h.check(false);
h.debug(ex);
}
// Check #8.
sec.setGrantLoggingControl(false);
barLogger = Logger.getLogger(loggerName,
TestResourceBundle.class.getName());
h.check(barLogger == fooLogger);
// Check #9.
//
// Sun J2SE 1.4.1_01 fails this test. However, it seems wrong
// that a call to getLogger should be able to install a
// ResourceBundle into a pre-existing logger if the caller
// does not have LoggingPermission.
//
// Sun Microsystems has been informed about this security-related
// bug in the reference implementation by submitting a bug report.
// Sun bug review ID: 240615.
h.check(fooLogger.getResourceBundle() == null);
}
finally
{
sec.uninstall();
}
}
}
|