blob: 235441aceba9c3fcfeadf84a724c4036cd965bd9 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.harmony.security.tests.java.security;
import java.security.AccessControlContext;
import java.security.AccessControlException;
import java.security.AccessController;
import java.security.AllPermission;
import java.security.Permission;
import java.security.PrivilegedAction;
import java.security.PrivilegedActionException;
import java.security.PrivilegedExceptionAction;
import dalvik.annotation.KnownFailure;
import dalvik.annotation.TestLevel;
import dalvik.annotation.TestTargetClass;
import dalvik.annotation.TestTargetNew;
@TestTargetClass(AccessController.class)
public class AccessController2Test extends junit.framework.TestCase {
PrivilegedAction<Boolean> privAction = new PrivilegedAction<Boolean>() {
public Boolean run() {
try {
AccessController.checkPermission(new AllPermission());
return new Boolean(false);
} catch (SecurityException ex) {
return new Boolean(true);
}
}
};
PrivilegedExceptionAction<Boolean> privExceptAction =
new PrivilegedExceptionAction<Boolean>() {
public Boolean run() {
try {
AccessController.checkPermission(new AllPermission());
return new Boolean(false);
} catch (SecurityException ex) {
return new Boolean(true);
}
}
};
/**
* @tests java.security.AccessController#doPrivileged(java.security.PrivilegedAction,
* java.security.AccessControlContext))
*/
@TestTargetNew(
level = TestLevel.COMPLETE,
method = "doPrivileged",
args = {java.security.PrivilegedAction.class, java.security.AccessControlContext.class}
)
@KnownFailure("Fails (probably) because no protection domain is set.")
public void test_doPrivilegedLjava_security_PrivilegedActionLjava_security_AccessControlContext() {
Boolean pass;
try {
AccessController.doPrivileged((PrivilegedAction<?>) null, null);
fail("Test 1: NullPointerException expected.");
} catch (NullPointerException e) {
// Expected.
}
pass = AccessController.doPrivileged(privAction, null);
assertTrue("Test 2: Got AllPermission when providing a null " +
"AccessControlContext.", pass.booleanValue());
AccessControlContext acc = AccessController.getContext();
assertNotNull("Test 3: AccessControlContext must not be null", acc);
pass = AccessController.doPrivileged(privAction, acc);
assertTrue("Test 4: Got AllPermission when providing a non-null " +
"AccessControlContext.", pass.booleanValue());
}
/**
* @tests java.security.AccessController#doPrivileged(java.security.PrivilegedAction))
*/
@TestTargetNew(
level = TestLevel.PARTIAL_COMPLETE,
method = "doPrivileged",
args = {java.security.PrivilegedAction.class}
)
@KnownFailure("Fails (probably) because no protection domain is set.")
public void test_doPrivilegedLjava_security_PrivilegedAction() {
Boolean pass;
try {
AccessController.doPrivileged((PrivilegedAction<?>) null);
fail("Test 1: NullPointerException expected.");
} catch (NullPointerException e) {
// Expected.
}
pass = AccessController.doPrivileged(privAction);
assertTrue("Test 2: Got AllPermission when providing no " +
"AccessControlContext.", pass.booleanValue());
}
/**
* @tests java.security.AccessController#doPrivileged(java.security.PrivilegedExceptionAction,
* java.security.AccessControlContext))
*/
@TestTargetNew(
level = TestLevel.COMPLETE,
method = "doPrivileged",
args = {java.security.PrivilegedExceptionAction.class, java.security.AccessControlContext.class}
)
@KnownFailure("Fails (probably) because no protection domain is set.")
public void test_doPrivilegedLjava_security_PrivilegedExceptionActionLjava_security_AccessControlContext() {
Boolean pass;
try {
AccessController.doPrivileged((PrivilegedExceptionAction<?>) null);
fail("Test 1: NullPointerException expected.");
} catch (NullPointerException e) {
// Expected.
} catch (PrivilegedActionException e) {
fail("Test 2: Unexpected PrivilegedActionException " +
e.getMessage());
}
try {
pass = AccessController.doPrivileged(privExceptAction, null);
assertTrue("Test 3: Got AllPermission when providing a null " +
"AccessControlContext.", pass.booleanValue());
} catch (PrivilegedActionException e) {
fail("Test 4: Unexpected PrivilegedActionException " +
e.getMessage());
}
AccessControlContext acc = AccessController.getContext();
assertNotNull("Test 5: AccessControlContext must not be null", acc);
try {
pass = AccessController.doPrivileged(privExceptAction, acc);
assertTrue("Test 6: Got AllPermission when providing non-null " +
"AccessControlContext.", pass.booleanValue());
} catch (PrivilegedActionException e) {
fail("Test 7: Unexpected PrivilegedActionException " +
e.getMessage());
}
}
/**
* @tests java.security.AccessController#doPrivileged(java.security.PrivilegedExceptionAction))
*/
@TestTargetNew(
level = TestLevel.COMPLETE,
method = "doPrivileged",
args = {java.security.PrivilegedExceptionAction.class}
)
@KnownFailure("Fails (probably) because no protection domain is set.")
public void test_doPrivilegedLjava_security_PrivilegedExceptionAction() {
Boolean pass;
try {
AccessController.doPrivileged((PrivilegedExceptionAction<?>) null);
fail("Test 1: NullPointerException expected.");
} catch (NullPointerException e) {
// Expected.
} catch (PrivilegedActionException e) {
fail("Test 2: Unexpected PrivilegedActionException " +
e.getMessage());
}
try {
pass = AccessController.doPrivileged(privExceptAction);
assertTrue("Test 3: Got AllPermission when providing no " +
"AccessControlContext.", pass.booleanValue());
} catch (PrivilegedActionException e) {
fail("Test 4: Unexpected exception " + e.getMessage());
}
}
/**
* @tests java.security.AccessController#checkPermission(Permission perm)
*/
@TestTargetNew(
level = TestLevel.PARTIAL_COMPLETE,
notes = "",
method = "checkPermission",
args = {java.security.Permission.class}
)
public void test_checkPermission_NullParameter() {
//Null parameter
try {
AccessController.checkPermission(null);
fail("Test 1: NullPointerException expected.");
} catch (NullPointerException npe) {
//expected
}
}
/**
* @tests java.security.AccessController#checkPermission(Permission perm)
*/
@TestTargetNew(
level = TestLevel.PARTIAL_COMPLETE,
notes = "",
method = "checkPermission",
args = {java.security.Permission.class}
)
@KnownFailure("Fails (probably) because no protection domain is set.")
public void test_checkPermission_InvalidPermission() {
String[] perm_invalid = {null, "1", "", "invalid", "bla-bla", "testCtor123^%$#&^ &^$"};
Permission perm;
//Null parameter
try {
AccessController.checkPermission(null);
fail("NullPointerException should be thrown for NULL parameter");
} catch (NullPointerException npe) {
//expected
}
//Invalid parameter
for (int i = 0; i < perm_invalid.length; i++) {
try {
perm = new RealPermission(perm_invalid[i]);
AccessController.checkPermission(perm);
fail("AccessControlException should be thrown for INVALID parameter " + perm_invalid[i]);
} catch (AccessControlException ace) {
//expected
} catch (Exception e) {
fail("Unexpected exception caught: " + e.toString());
}
}
}
/**
* @tests java.security.AccessController#getContext()
*/
@TestTargetNew(
level = TestLevel.COMPLETE,
notes = "",
method = "getContext",
args = {}
)
public void test_getContext() {
try {
AccessControlContext acc = AccessController.getContext();
assertNotNull(acc);
assertTrue(acc instanceof AccessControlContext);
} catch (Exception e) {
fail("Unexpected exception");
}
}
// Bare extension to instantiate abstract Permission class
static final class RealPermission extends Permission {
private static final long serialVersionUID = 1L;
public RealPermission(String name) {
super(name);
}
public boolean equals(Object obj) {
return false;
}
public String getActions() {
return null;
}
public int hashCode() {
return 0;
}
public boolean implies(Permission permission) {
return false;
}
}
}