Mercurial > hg > Members > kono > jpf-core
diff src/classes/org/junit/Test.java @ 0:61d41facf527
initial v8 import (history reset)
author | Peter Mehlitz <Peter.C.Mehlitz@nasa.gov> |
---|---|
date | Fri, 23 Jan 2015 10:14:01 -0800 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/classes/org/junit/Test.java Fri Jan 23 10:14:01 2015 -0800 @@ -0,0 +1,54 @@ +/* + * Copyright (C) 2014, United States Government, as represented by the + * Administrator of the National Aeronautics and Space Administration. + * All rights reserved. + * + * The Java Pathfinder core (jpf-core) platform is 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. + */ + +/** + * this annotation type is shamelessly lifted from JUnit. + * + * The only reason it is here is that we don't want to pull the whole of JUnit into + * our 'classpath' when executing TestJPF classes under JPF, just because some of + * the test SUT methods have a @Test annotation. + * + * Lifting/masking classes in general is not a good practice, but it seems to + * be the lesser of two evils in this case, given that we really don't need + * anything but just the simple annotation type. + * + * NOTE - this might be different if we execute junit under JPF, which is the + * reason why we include the @Test features here. However - this assumes that @Test + * is such a basic JUnit type that it won't change + */ + +package org.junit; + +import java.lang.annotation.ElementType; +import java.lang.annotation.Retention; +import java.lang.annotation.RetentionPolicy; +import java.lang.annotation.Target; + +@Retention(RetentionPolicy.RUNTIME) +@Target({ElementType.METHOD}) +public @interface Test { + + static class None extends Throwable { + private static final long serialVersionUID= 1L; + private None() {} + } + + Class<? extends Throwable> expected() default None.class; + + long timeout() default 0L; +}