All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jboss.arquillian.drone.spi.DronePoint Maven / Gradle / Ivy

/*
 * JBoss, Home of Professional Open Source
 * Copyright 2014 Red Hat Inc. and/or its affiliates and other contributors
 * as indicated by the @authors tag. All rights reserved.
 * See the copyright.txt in the distribution for a
 * full listing of individual contributors.
 *
 * Licensed 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.jboss.arquillian.drone.spi;

import java.lang.annotation.Annotation;

/**
 * Injection point is an unique description of a drone in code.
 *
 * @author Tadeas Kriz
 */
public interface DronePoint {

    /**
     * @return Type of drone to be injected.
     */
    Class getDroneType();

    /**
     * @return An array of all annotations the drone is annotated with except {@link Drone} one.
     */
    Annotation[] getAnnotations();

    /**
     * @return Lifecycle of the drone.
     */
    Lifecycle getLifecycle();

    /**
     * Searches {@link DronePoint#getAnnotations()} and returns class of qualifier annotation.
     */
    @Deprecated
    Class getQualifier();

    /**
     * @return True of the underlying drone type can be cast to {@code droneClass} parameter.
     */
    boolean conformsTo(Class droneClass);

    enum Lifecycle {
        /**
         * Method lifecycle means the drone will be prepared in {@link Before} and destroyed in {@link After}.
         */
        METHOD,

        /**
         * Class lifecycle means the drone will be prepared in {@link BeforeClass} and destroyed in {@link AfterClass}.
         */
        CLASS,

        /**
         * Deployment lifecycle means the drone will be prepared in {@link BeforeClass} and destroyed in
         * {@link BeforeUnDeploy}.
         */
        DEPLOYMENT
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy