FileDocCategorySizeDatePackage
LoggingPermissionTest.javaAPI DocAndroid 1.5 API3301Wed May 06 22:41:04 BST 2009org.apache.harmony.logging.tests.java.util.logging

LoggingPermissionTest.java

/* 
 * 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.logging.tests.java.util.logging;

import dalvik.annotation.TestTargets;
import dalvik.annotation.TestLevel;
import dalvik.annotation.TestTargetNew;
import dalvik.annotation.TestTargetClass;

import java.util.logging.LoggingPermission;

import junit.framework.TestCase;

import org.apache.harmony.testframework.serialization.SerializationTest;

@TestTargetClass(LoggingPermission.class) 
public class LoggingPermissionTest extends TestCase {

    /**
     * @tests serialization/deserialization compatibility.
     */
    @TestTargetNew(
        level = TestLevel.COMPLETE,
        notes = "",
        method = "!SerializationSelf",
        args = {}
    )
    public void testSerializationSelf() throws Exception {
        SerializationTest.verifySelf(new LoggingPermission("control", ""));
    }

    /**
     * @tests serialization/deserialization compatibility with RI.
     */
    @TestTargetNew(
        level = TestLevel.COMPLETE,
        notes = "",
        method = "!SerializationGolden",
        args = {}
    )
    public void testSerializationCompatibility() throws Exception {

        SerializationTest.verifyGolden(this, new LoggingPermission("control",
                ""));
    }

    @TestTargetNew(
        level = TestLevel.COMPLETE,
        notes = "",
        method = "LoggingPermission",
        args = {java.lang.String.class, java.lang.String.class}
    )
    public void testLoggingPermission() {
        try {
            new LoggingPermission(null, null);
            fail("should throw IllegalArgumentException");
        } catch (NullPointerException e) {
        }
        try {
            new LoggingPermission("", null);
            fail("should throw IllegalArgumentException");
        } catch (IllegalArgumentException e) {
        }
        try {
            new LoggingPermission("bad name", null);
            fail("should throw IllegalArgumentException");
        } catch (IllegalArgumentException e) {
        }
        try {
            new LoggingPermission("Control", null);
            fail("should throw IllegalArgumentException");
        } catch (IllegalArgumentException e) {
        }
        try {
            new LoggingPermission("control",
                    "bad action");
            fail("should throw IllegalArgumentException");
        } catch (IllegalArgumentException e) {
        }
        
        new LoggingPermission("control", "");
        
        new LoggingPermission("control", null);
    }

}