patterntesting.runtime.annotation.Broken Maven / Gradle / Ivy
/*
* $Id: Broken.java,v 1.20 2016/03/06 13:21:39 oboehm Exp $
*
* Copyright (c) 2009 by Oliver Boehm
*
* 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 orimplied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* (c)reated 23.11.2009 by oliver ([email protected])
*/
package patterntesting.runtime.annotation;
import static patterntesting.runtime.NullConstants.NULL_STRING;
import java.lang.annotation.*;
/**
* If you want to mark JUnit tests which does not work for the moment as
* "broken" you can use this annotation. The tests will be skipped if you
* run JUnit. You can also add a date till when you want to fix this "broken"
* test. If the date is reached then the test will fail if it is not fixed
* (and the @Broken removed).
*
* Before 1.0.0 this annotation was handled by BrokenAspect. But since 1.0.0
* it is handled now by the {@link patterntesting.runtime.junit.SmokeRunner} class.
* You should use this annotation together with {@code @RunWith(SmokeRunner.class)},
* also for JUnit 3 tests.
*
*
* You can also use this annotation to mark a method or constructor as
* "broken". If assertions are enabled an AssertionError will be thrown if
* you call such a broken method. If not only a error message will be logged.
*
*
* What is the difference to @SkipTestOn
?
* "Broken" means, the test does not work for the moment and should be
* (temporarily) skipped. "SkipTestOn" means, this test is not constructed
* for that platform and should be therefore skipped on it.
*
*
* @author oliver
* @see SkipTestOn
* @since 23.11.2009
*/
@Documented
@Target({ElementType.METHOD, ElementType.CONSTRUCTOR, ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
public @interface Broken {
/**
* You can change the default string to give a reason why the test is
* marked as "broken".
* You can use 'value=...' or 'wyh=...' to change it.
*
* @return the string
*/
String value() default "marked as @Broken";
/**
* You can change the default string to give a reason why the test is
* marked as "broken".
* You can use 'value=...' or 'why=...' to change it.
*
* @return the string
*/
String why() default NULL_STRING;
/**
* Use this attribute to mark the begin of the broken area, when it
* was detected that your JUnit test or method does not work as expected.
*
* The format of the date is "dd-MMM-yyyy".
*
*
* @return the string
*/
String since() default NULL_STRING;
/**
* Use this attribute till you want the broken JUnit test to be fixed.
*
* The format of the date is "dd-MMM-yyyy" or "dd-MMM-yyyy H:mm".
*
*
* @return the string
*/
String till() default NULL_STRING;
/**
* Does the test break only for user "Bob" and you can't fix it for him at
* the moment? Use user="bob"
to mark it as broken for user
* account "bob".
*
* Damn, the new member of the team, Bill, has the same problem and nobody
* is able to fix it. Ok, use user={"bob", "bill"}
to mark the
* code as broken for both user.
*
*
* @return the string[]
* @since 1.0
*/
String[] user() default NULL_STRING;
/**
* Should a test be skipped on a single platform e.g. for Linux?
* Use "Linux" to mark it as broken only for the Linux platform.
* Instead of "Linux" you can use any other operation system. The
* format must be the same as returned by the system property "os.name".
* Valid values are:
*
* - "Linux"
* - "Mac OS X" (for Mac),
* - "Windows XP"
* - and others
* (see http://lopica.sourceforge.net/os.html).
*
*
*
* Multiple values like { "Linux", "Mac OS X" }
are allowed.
* If no operation system is given you will get an IllegalArgumentException.
*
*
* The format of this attribute must be the same as returned by system
* property "os.name".
*
* Note: this attribute replaces the old 'os' attribute which was removed
* in 1.6.
*
*
* @return the string[]
* @since 1.1
*/
String[] osName() default NULL_STRING;
/**
* The test is broken only for the Intel architecture?
* Then you can use this attribute to limit it on this platform.
* You can define a single platform like "x86_64"
for an
* Intel-Mac with 64 bit or multiple platform like
* { "x86_32", "x86_64" }
for Intel Mac with 42 or 64 bit.
*
* The format of this attribute must be the same as returned by the system
* property "os.arch".
*
*
* @return the string[]
* @since 1.1
*/
String[] osArch() default NULL_STRING;
/**
* The test breaks only on a special version of the
* operating system? Use this attribute to limit it.
* In contradiction to the other attributes the real version must start
* with the given version. I.e. if you define "10.6" as version this would
* match only real version "10.6.1" or "10.6.2".
*
* You can't define a range of skipped versions. But several versions are
* allowed. So if you want to skip the tests in version 10.6.1 till 10.6.3
* define { "10.6.1", "10.6.2", "10.6.3" } as values.
* The format of this attribute must be the same as returned by the system
* property "osVersion".
*
*
* @return the string[]
* @since 1.1
*/
String[] osVersion() default NULL_STRING;
/**
* With this attribute you can express that the test is broken for
* the given host(s). Perhaps these hosts have not enough memory.
* You can define the host by its name or by its IP address.
*
* @return the string[]
* @since 1.1
*/
String[] host() default NULL_STRING;
/**
* You want to mark the test as broken on a special version of the VM, e.g. on
* version "1.6.0_17" because you know that on this version there is a bug
* that caused your test not to work? Then use this attribute.
*
* You can't define a range of skipped versions. But you regex (regular
* expressions) are allowed. And you can define more than one version
* (or regex).
*
*
* The format of this attribute must be the same as returned by the
* system property "java.version".
*
*
* @return the string[]
* @since 1.1
*/
String[] javaVersion() default NULL_STRING;
/**
* The test is broken for a special vendor VM? Use this attribute
* here. The format of this attribute must be the same as returned by the
* system property "java.vendor".
* Valid values are:
*
* - "Apple Inc."
* - and others
*
*
* @return the string[]
* @since 1.1
*/
String[] javaVendor() default NULL_STRING;
/**
* You have some tests that are broken if some proxy properties are set?
* Define the property here (e.g. property="proxy.host"
).
* If this property is set (and its value is
* not "false") the test will be skipped if this property is set as
* system property.
*
* You can control more than property with this attribute. Then all
* properties must be "true" to skip the test.
*
*
* @return the string[]
* @since 1.1
*/
String[] property() default NULL_STRING;
/**
* Normally a test would be listed as "ignore" if it is marked as broken. If
* you must pass some quality gates which do not allow ignored tests (e.g.
* if you use Sonar that can be a quality gate) fix the bug and remove the
* {@link Broken} annotation.
*
* Nevertheless you can set this flag to true. This can be useful if you
* want to fix the bug in a later release but must pass now some quality
* gates.
*
*
* @return true, if successful
* @since 1.7
*/
boolean hide() default false;
}