001/*
002 * (C) Copyright 2019 Nuxeo (http://nuxeo.com/) and others.
003 *
004 * Licensed under the Apache License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 *     http://www.apache.org/licenses/LICENSE-2.0
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 *
016 * Contributors:
017 *     Salem Aouana
018 */
019
020package org.nuxeo.runtime.test.runner;
021
022import java.lang.annotation.ElementType;
023import java.lang.annotation.Inherited;
024import java.lang.annotation.Retention;
025import java.lang.annotation.RetentionPolicy;
026import java.lang.annotation.Target;
027
028/**
029 * Annotation to define a console log level threshold on the root logger, which allows us to hide console log messages
030 * when launching tests. Any {@code Class} or {@code Method} can be annotated, when a {@code Method} is marked then the
031 * console level will override the {@code Class} level if it is defined and it will be restored after the end of the
032 * execution of this {@code Method} otherwise it will inherit the {@code Class} defined level.
033 * <p>
034 * The default level value is {@link java.util.logging.Level#OFF} which means all console log messages will be hidden.
035 *
036 * @since 11.1
037 */
038@Inherited
039@Retention(RetentionPolicy.RUNTIME)
040@Target({ ElementType.TYPE, ElementType.METHOD })
041public @interface ConsoleLogLevelThreshold {
042
043    String value() default "OFF";
044}