view src/test/java/org/icedrobot/daneel/rewriter/AnnotationTest.java @ 122:1f55b68e19b0

Implemented rewriting of parameter annotations. * dex/AnnotationsDirectory.java: Tested parameter annotation parsing now. * rewriter/DexRewriter.java (visitParameterAnnotation): Implemented. * rewriter/AnnotationTest.java: Extended test case accordingly.
author Michael Starzinger <michi@complang.tuwien.ac.at>
date Fri, 08 Apr 2011 18:41:22 +0200
parents 03ad7dd3dec1
children
line wrap: on
line source

/*
 * Daneel - Dalvik to Java bytecode compiler
 * Copyright (C) 2011  IcedRobot team
 *
 * This program 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 3 of the License, or
 * (at your option) any later version.
 *
 * This program 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 this program.  If not, see <http://www.gnu.org/licenses/>.
 *
 * This file is subject to the "Classpath" exception:
 *
 * Linking this library statically or dynamically with other modules is
 * making a combined work based on this library.  Thus, the terms and
 * conditions of the GNU General Public License cover the whole
 * combination.
 *
 * As a special exception, the copyright holders of this library give you
 * permission to link this library with independent modules to produce an
 * executable, regardless of the license terms of these independent
 * modules, and to copy and distribute the resulting executable under terms
 * of your choice, provided that you also meet, for each linked independent
 * module, the terms and conditions of the license of that module.  An
 * independent module is a module which is not derived from or based on
 * this library.  If you modify this library, you may extend this exception
 * to your version of the library, but you are not obligated to do so.  If
 * you do not wish to do so, delete this exception statement from your
 * version.
 */

package org.icedrobot.daneel.rewriter;

import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertSame;

import java.lang.annotation.Annotation;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import java.lang.reflect.Method;

import org.icedrobot.daneel.DexifyingRunner;
import org.junit.Test;
import org.junit.runner.RunWith;

@RunWith(DexifyingRunner.class)
public class AnnotationTest {

    @Test
    public void testClassAnnotation() {
        Annotation[] a = DEXCode.class.getAnnotations();
        assertEquals(1, a.length);
        assertSame(TestAnnotationA.class, a[0].annotationType());
    }

    @Test
    public void testFieldAnnotation() throws Exception {
        Annotation[] a = DEXCode.class.getField("field").getAnnotations();
        assertEquals(1, a.length);
        assertSame(TestAnnotationB.class, a[0].annotationType());
    }

    @Test
    public void testMethodAnnotation() throws Exception {
        Annotation[] a = DEXCode.class.getMethod("method").getAnnotations();
        assertEquals(1, a.length);
        assertSame(TestAnnotationC.class, a[0].annotationType());
    }

    @Test
    public void testParameterAnnotation() throws Exception {
        Method m = DEXCode.class.getMethod("params", int.class, int.class);
        Annotation[][] a = m.getParameterAnnotations();
        assertEquals(2, a.length);
        assertEquals(0, a[0].length);
        assertEquals(1, a[1].length);
        assertSame(TestAnnotationD.class, a[1][0].annotationType());
    }

    @Retention(RetentionPolicy.RUNTIME)
    @Target({ ElementType.TYPE })
    private static @interface TestAnnotationA {
    };

    @Retention(RetentionPolicy.RUNTIME)
    @Target({ ElementType.FIELD })
    private static @interface TestAnnotationB {
    };

    @Retention(RetentionPolicy.RUNTIME)
    @Target({ ElementType.METHOD })
    private static @interface TestAnnotationC {
    };

    @Retention(RetentionPolicy.RUNTIME)
    @Target({ ElementType.PARAMETER })
    private static @interface TestAnnotationD {
    };

    // Keep this class named "DEXCode" to push it through Daneel.
    @TestAnnotationA
    public static class DEXCode {

        @TestAnnotationB
        public int field;

        @TestAnnotationC
        public void method() {
        }

        public void params(int param1, @TestAnnotationD int param2) {
        }
    };
}