2015-11-28 18:52:17 -08:00
/ *
2017-03-15 16:12:20 -07:00
* Copyright ( c ) 2003 , 2017 , Oracle and / or its affiliates . All rights reserved .
2015-11-28 18:52:17 -08:00
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER .
*
* This code is free software ; you can redistribute it and / or modify it
* under the terms of the GNU General Public License version 2 only , as
* published by the Free Software Foundation .
*
* This code 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
* version 2 for more details ( a copy is included in the LICENSE file that
* accompanied this code ) .
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work ; if not , write to the Free Software Foundation ,
* Inc . , 51 Franklin St , Fifth Floor , Boston , MA 02110 - 1301 USA .
*
* Please contact Oracle , 500 Oracle Parkway , Redwood Shores , CA 94065 USA
* or visit www . oracle . com if you need additional information or have any
* questions .
* /
/ *
* @test
2017-12-07 14:15:14 -08:00
* @bug 4927552 8026567 8071982 8162674 8175200 8175218 8183511 8186332
* 8169819 8074407 8191030
2017-11-16 15:01:45 -08:00
* @summary test generated docs for deprecated items
2015-11-28 18:52:17 -08:00
* @author jamieh
* @library . . / lib
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Jan Lahoda <jan.lahoda@oracle.com>
Co-authored-by: Vicente Romero <vicente.romero@oracle.com>
Co-authored-by: Andreas Lundblad <andreas.lundblad@oracle.com>
Co-authored-by: Andrey Nazarov <andrey.x.nazarov@oracle.com>
Co-authored-by: Chris Hegarty <chris.hegarty@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: Kumar Srinivasan <kumar.x.srinivasan@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: jjg, jlahoda, vromero, mcimadamore, bpatel, ksrini, darcy, anazarov, dfuchs
2016-03-17 19:04:28 +00:00
* @modules jdk . javadoc / jdk . javadoc . internal . tool
2015-11-28 18:52:17 -08:00
* @build JavadocTester
* @run main TestDeprecatedDocs
* /
public class TestDeprecatedDocs extends JavadocTester {
public static void main ( String . . . args ) throws Exception {
TestDeprecatedDocs tester = new TestDeprecatedDocs ( ) ;
tester . runTests ( ) ;
}
@Test
void test ( ) {
javadoc ( " -d " , " out " ,
" -sourcepath " , testSrc ,
" pkg " ) ;
checkExit ( Exit . OK ) ;
checkOutput ( " deprecated-list.html " , true ,
" annotation_test1 passes " ,
" annotation_test2 passes " ,
" annotation_test3 passes " ,
2016-03-14 15:04:57 -07:00
" annotation_test4 passes. " ,
2015-11-28 18:52:17 -08:00
" class_test1 passes " ,
" class_test2 passes " ,
" class_test3 passes " ,
" class_test4 passes " ,
" enum_test1 passes " ,
" enum_test2 passes " ,
" error_test1 passes " ,
" error_test2 passes " ,
" error_test3 passes " ,
" error_test4 passes " ,
" exception_test1 passes " ,
" exception_test2 passes " ,
" exception_test3 passes " ,
" exception_test4 passes " ,
" interface_test1 passes " ,
" interface_test2 passes " ,
" interface_test3 passes " ,
" interface_test4 passes " ,
" pkg.DeprecatedClassByAnnotation " ,
" pkg.DeprecatedClassByAnnotation() " ,
" pkg.DeprecatedClassByAnnotation.method() " ,
" pkg.DeprecatedClassByAnnotation.field "
) ;
checkOutput ( " pkg/DeprecatedClassByAnnotation.html " , true ,
" <pre>@Deprecated \ n "
+ " public class <span class= \" typeNameLabel \" >DeprecatedClassByAnnotation</span> \ n "
+ " extends java.lang.Object</pre> " ,
2016-12-13 12:25:58 -08:00
" <pre>@Deprecated(forRemoval=true) \ n "
2015-11-28 18:52:17 -08:00
+ " public int field</pre> \ n "
2017-10-03 12:58:49 -07:00
+ " <div class= \" deprecationBlock \" ><span class= \" deprecatedLabel \" >Deprecated, for removal: This API element is subject to removal in a future version.</span></div> " ,
2016-12-13 12:25:58 -08:00
" <pre>@Deprecated(forRemoval=true) \ n "
2017-09-27 16:47:07 -07:00
+ " public DeprecatedClassByAnnotation()</pre> \ n "
2017-10-03 12:58:49 -07:00
+ " <div class= \" deprecationBlock \" ><span class= \" deprecatedLabel \" >Deprecated, for removal: This API element is subject to removal in a future version.</span></div> " ,
2015-11-28 18:52:17 -08:00
" <pre>@Deprecated \ n "
2017-09-27 16:47:07 -07:00
+ " public void method()</pre> \ n "
2017-10-03 12:58:49 -07:00
+ " <div class= \" deprecationBlock \" ><span class= \" deprecatedLabel \" >Deprecated.</span></div> " ) ;
2016-12-13 12:25:58 -08:00
checkOutput ( " pkg/TestAnnotationType.html " , true ,
2017-09-26 20:03:48 -07:00
" <hr> \ n "
2016-12-13 12:25:58 -08:00
+ " <pre>@Deprecated(forRemoval=true) \ n "
+ " @Documented \ n "
2017-09-26 20:03:48 -07:00
+ " public @interface <span class= \" memberNameLabel \" >TestAnnotationType</span></pre> \ n "
2017-10-03 12:58:49 -07:00
+ " <div class= \" deprecationBlock \" ><span class= \" deprecatedLabel \" >Deprecated, for removal: This API element is subject to removal in a future version.</span> \ n "
+ " <div class= \" deprecationComment \" >annotation_test1 passes.</div> \ n "
+ " </div> " ,
2016-12-13 12:25:58 -08:00
" <pre>@Deprecated(forRemoval=true) \ n "
+ " static final int field</pre> \ n "
2017-09-26 20:03:48 -07:00
+ " <div class= \" deprecationBlock \" ><span class= \" deprecatedLabel \" >Deprecated, for removal: This "
2017-10-03 12:58:49 -07:00
+ " API element is subject to removal in a future version.</span> \ n "
+ " <div class= \" deprecationComment \" >annotation_test4 passes.</div> \ n "
+ " </div> " ,
2016-12-13 12:25:58 -08:00
" <pre>@Deprecated(forRemoval=true) \ n "
+ " int required</pre> \ n "
2017-10-03 12:58:49 -07:00
+ " <div class= \" deprecationBlock \" ><span class= \" deprecatedLabel \" >Deprecated, for removal: This API element is subject to removal in a future version.</span> \ n "
+ " <div class= \" deprecationComment \" >annotation_test3 passes.</div> \ n "
+ " </div> " ,
2016-12-13 12:25:58 -08:00
" <pre>java.lang.String optional</pre> \ n "
2017-10-03 12:58:49 -07:00
+ " <div class= \" deprecationBlock \" ><span class= \" deprecatedLabel \" >Deprecated.</span> \ n "
+ " <div class= \" deprecationComment \" >annotation_test2 passes.</div> \ n "
+ " </div> " ) ;
2016-12-13 12:25:58 -08:00
checkOutput ( " pkg/TestClass.html " , true ,
2017-09-26 20:03:48 -07:00
" <hr> \ n "
2016-12-13 12:25:58 -08:00
+ " <pre>@Deprecated(forRemoval=true) \ n "
+ " public class <span class= \" typeNameLabel \" >TestClass</span> \ n "
2017-09-26 20:03:48 -07:00
+ " extends java.lang.Object</pre> \ n "
2017-10-03 12:58:49 -07:00
+ " <div class= \" deprecationBlock \" ><span class= \" deprecatedLabel \" >Deprecated, for removal: This API element is subject to removal in a future version.</span> \ n "
+ " <div class= \" deprecationComment \" >class_test1 passes.</div> \ n "
2017-09-26 20:03:48 -07:00
+ " </div> " ,
2016-12-13 12:25:58 -08:00
" <pre>@Deprecated(forRemoval=true) \ n "
2017-09-27 16:47:07 -07:00
+ " public TestClass()</pre> \ n "
2017-10-03 12:58:49 -07:00
+ " <div class= \" deprecationBlock \" ><span class= \" deprecatedLabel \" >Deprecated, for removal: This API element is subject to removal in a future version.</span> \ n "
+ " <div class= \" deprecationComment \" >class_test3 passes. This is the second sentence of deprecated description for a constructor.</div> \ n "
+ " </div> " ,
" <td class= \" colLast \" > \ n "
+ " <div class= \" block \" ><span class= \" deprecatedLabel \" >Deprecated.</span> \ n "
+ " <div class= \" deprecationComment \" >class_test2 passes.</div> \ n "
+ " </div> \ n "
+ " </td> " ,
" <td class= \" colLast \" > \ n "
+ " <div class= \" block \" ><span class= \" deprecatedLabel \" >Deprecated, for removal: This API element is subject to removal in a future version.</span> \ n "
+ " <div class= \" deprecationComment \" >class_test3 passes.</div> \ n "
+ " </div> \ n "
+ " </td> " ,
" <td class= \" colLast \" > \ n "
+ " <div class= \" block \" ><span class= \" deprecatedLabel \" >Deprecated.</span> \ n "
+ " <div class= \" deprecationComment \" >class_test4 passes.</div> \ n "
+ " </div> \ n "
+ " </td> " ) ;
checkOutput ( " pkg/TestClass.html " , false ,
" <div class= \" deprecationComment \" >class_test2 passes. This is the second sentence of deprecated description for a field.</div> \ n "
+ " </div> \ n "
+ " </td> " ,
" <div class= \" deprecationComment \" >class_test3 passes. This is the second sentence of deprecated description for a constructor.</div> \ n "
+ " </div> \ n "
+ " </td> " ,
" <div class= \" deprecationComment \" >class_test4 passes. This is the second sentence of deprecated description for a method.</div> \ n "
+ " </div> \ n "
+ " </td> " ) ;
2016-12-13 12:25:58 -08:00
checkOutput ( " pkg/TestEnum.html " , true ,
2017-09-26 20:03:48 -07:00
" <hr> \ n "
2016-12-13 12:25:58 -08:00
+ " <pre>@Deprecated(forRemoval=true) \ n "
+ " public enum <span class= \" typeNameLabel \" >TestEnum</span> \ n "
2017-09-26 20:03:48 -07:00
+ " extends java.lang.Enum<<a href= \" ../pkg/TestEnum.html \" title= \" enum in pkg \" >TestEnum</a>></pre> \ n "
2017-10-03 12:58:49 -07:00
+ " <div class= \" deprecationBlock \" ><span class= \" deprecatedLabel \" >Deprecated, for removal: This API element is subject to removal in a future version.</span> \ n "
+ " <div class= \" deprecationComment \" >enum_test1 passes.</div> \ n "
2017-09-26 20:03:48 -07:00
+ " </div> " ,
2016-12-13 12:25:58 -08:00
" <pre>@Deprecated(forRemoval=true) \ n "
+ " public static final <a href= \" ../pkg/TestEnum.html \" title= \" enum in pkg \" >TestEnum</a> FOR_REMOVAL</pre> \ n "
2017-10-03 12:58:49 -07:00
+ " <div class= \" deprecationBlock \" ><span class= \" deprecatedLabel \" >Deprecated, for removal: This API element is subject to removal in a future version.</span> \ n "
+ " <div class= \" deprecationComment \" >enum_test3 passes.</div> \ n "
+ " </div> " ) ;
2016-12-13 12:25:58 -08:00
checkOutput ( " pkg/TestError.html " , true ,
2017-09-26 20:03:48 -07:00
" <hr> \ n "
2016-12-13 12:25:58 -08:00
+ " <pre>@Deprecated(forRemoval=true) \ n "
+ " public class <span class= \" typeNameLabel \" >TestError</span> \ n "
2017-09-26 20:03:48 -07:00
+ " extends java.lang.Error</pre> \ n "
2017-10-03 12:58:49 -07:00
+ " <div class= \" deprecationBlock \" ><span class= \" deprecatedLabel \" >Deprecated, for removal: This API element is subject to removal in a future version.</span> \ n "
+ " <div class= \" deprecationComment \" >error_test1 passes.</div> \ n "
2017-09-26 20:03:48 -07:00
+ " </div> " ) ;
2016-12-13 12:25:58 -08:00
checkOutput ( " pkg/TestException.html " , true ,
2017-09-26 20:03:48 -07:00
" <hr> \ n "
2016-12-13 12:25:58 -08:00
+ " <pre>@Deprecated(forRemoval=true) \ n "
+ " public class <span class= \" typeNameLabel \" >TestException</span> \ n "
2017-09-26 20:03:48 -07:00
+ " extends java.lang.Exception</pre> \ n "
2017-10-03 12:58:49 -07:00
+ " <div class= \" deprecationBlock \" ><span class= \" deprecatedLabel \" >Deprecated, for removal: This API element is subject to removal in a future version.</span> \ n "
+ " <div class= \" deprecationComment \" >exception_test1 passes.</div> \ n "
2017-09-26 20:03:48 -07:00
+ " </div> " ) ;
2016-12-13 12:25:58 -08:00
checkOutput ( " pkg/TestInterface.html " , true ,
2017-09-26 20:03:48 -07:00
" <hr> \ n "
2016-12-13 12:25:58 -08:00
+ " <pre>@Deprecated(forRemoval=true) \ n "
+ " public class <span class= \" typeNameLabel \" >TestInterface</span> \ n "
2017-09-26 20:03:48 -07:00
+ " extends java.lang.Object</pre> \ n "
2017-10-03 12:58:49 -07:00
+ " <div class= \" deprecationBlock \" ><span class= \" deprecatedLabel \" >Deprecated, for removal: This API element is subject to removal in a future version.</span> \ n "
+ " <div class= \" deprecationComment \" >interface_test1 passes.</div> \ n "
2017-09-26 20:03:48 -07:00
+ " </div> " ) ;
2016-12-13 12:25:58 -08:00
checkOutput ( " deprecated-list.html " , true ,
" <ul> \ n "
2017-10-02 14:49:46 -07:00
+ " <li><a href= \" #forRemoval \" >For Removal</a></li> \ n "
+ " <li><a href= \" #class \" >Classes</a></li> \ n "
+ " <li><a href= \" #enum \" >Enums</a></li> \ n "
+ " <li><a href= \" #exception \" >Exceptions</a></li> \ n "
+ " <li><a href= \" #error \" >Errors</a></li> \ n "
+ " <li><a href= \" #annotation.type \" >Annotation Types</a></li> \ n "
+ " <li><a href= \" #field \" >Fields</a></li> \ n "
+ " <li><a href= \" #method \" >Methods</a></li> \ n "
+ " <li><a href= \" #constructor \" >Constructors</a></li> \ n "
+ " <li><a href= \" #enum.constant \" >Enum Constants</a></li> \ n "
+ " <li><a href= \" #annotation.type.member \" >Annotation Type Elements</a></li> \ n "
2016-12-13 12:25:58 -08:00
+ " </ul> " ,
" <a name= \" forRemoval \" > " ,
2017-10-02 14:49:46 -07:00
" <table class= \" deprecatedSummary \" summary= \" For Removal table, listing for removal, and an explanation \" > \ n "
+ " <caption><span>For Removal</span><span class= \" tabEnd \" > </span></caption> \ n "
2016-12-13 12:25:58 -08:00
+ " <tr> \ n "
+ " <th class= \" colFirst \" scope= \" col \" >Element</th> \ n "
+ " <th class= \" colLast \" scope= \" col \" >Description</th> \ n "
+ " </tr> " ,
2017-10-02 14:49:46 -07:00
" <table class= \" deprecatedSummary \" summary= \" Enums table, listing enums, and an explanation \" > \ n "
+ " <caption><span>Enums</span><span class= \" tabEnd \" > </span></caption> \ n "
2016-12-13 12:25:58 -08:00
+ " <tr> \ n "
+ " <th class= \" colFirst \" scope= \" col \" >Enum</th> \ n "
+ " <th class= \" colLast \" scope= \" col \" >Description</th> \ n "
+ " </tr> \ n "
+ " <tbody> \ n "
+ " <tr class= \" altColor \" > \ n "
2017-10-02 14:49:46 -07:00
+ " <th class= \" colDeprecatedItemName \" scope= \" row \" ><a href= \" pkg/TestEnum.html \" title= \" enum in pkg \" >pkg.TestEnum</a></th> \ n "
2016-12-13 12:25:58 -08:00
+ " <td class= \" colLast \" > \ n "
2017-10-03 12:58:49 -07:00
+ " <div class= \" deprecationComment \" >enum_test1 passes.</div> \ n "
2016-12-13 12:25:58 -08:00
+ " </td> \ n "
+ " </tr> \ n "
+ " </tbody> \ n "
+ " </table> " ,
2017-10-02 14:49:46 -07:00
" <table class= \" deprecatedSummary \" summary= \" Exceptions table, listing exceptions, and an explanation \" > \ n "
+ " <caption><span>Exceptions</span><span class= \" tabEnd \" > </span></caption> \ n "
2016-12-13 12:25:58 -08:00
+ " <tr> \ n "
+ " <th class= \" colFirst \" scope= \" col \" >Exceptions</th> \ n "
+ " <th class= \" colLast \" scope= \" col \" >Description</th> \ n "
+ " </tr> \ n "
+ " <tbody> \ n "
+ " <tr class= \" altColor \" > \ n "
2017-10-02 14:49:46 -07:00
+ " <th class= \" colDeprecatedItemName \" scope= \" row \" ><a href= \" pkg/TestException.html \" title= \" class in pkg \" >pkg.TestException</a></th> \ n "
2016-12-13 12:25:58 -08:00
+ " <td class= \" colLast \" > \ n "
2017-10-03 12:58:49 -07:00
+ " <div class= \" deprecationComment \" >exception_test1 passes.</div> \ n "
2016-12-13 12:25:58 -08:00
+ " </td> \ n "
+ " </tr> \ n "
+ " </tbody> \ n "
2017-10-02 14:49:46 -07:00
+ " </table> " ,
" <table class= \" deprecatedSummary \" summary= \" Fields table, listing fields, and an explanation \" > \ n "
+ " <caption><span>Fields</span><span class= \" tabEnd \" > </span></caption> \ n "
+ " <tr> \ n "
+ " <th class= \" colFirst \" scope= \" col \" >Field</th> \ n "
+ " <th class= \" colLast \" scope= \" col \" >Description</th> \ n "
+ " </tr> \ n "
+ " <tbody> \ n "
+ " <tr class= \" altColor \" > \ n "
+ " <th class= \" colDeprecatedItemName \" scope= \" row \" ><a href= \" pkg/DeprecatedClassByAnnotation.html#field \" >pkg.DeprecatedClassByAnnotation.field</a></th> \ n "
2017-11-16 15:01:45 -08:00
+ " <td class= \" colLast \" ></td> \ n "
2017-10-02 14:49:46 -07:00
+ " </tr> \ n "
+ " <tr class= \" rowColor \" > \ n "
2017-12-07 14:15:14 -08:00
+ " <th class= \" colDeprecatedItemName \" scope= \" row \" ><a href= \" pkg/TestAnnotationType.html#field \" >pkg.TestAnnotationType.field</a></th> \ n "
+ " <td class= \" colLast \" > \ n "
+ " <div class= \" deprecationComment \" >annotation_test4 passes.</div> \ n "
+ " </td> \ n "
+ " </tr> \ n "
+ " <tr class= \" altColor \" > \ n "
2017-10-02 14:49:46 -07:00
+ " <th class= \" colDeprecatedItemName \" scope= \" row \" ><a href= \" pkg/TestClass.html#field \" >pkg.TestClass.field</a></th> \ n "
+ " <td class= \" colLast \" > \ n "
2017-10-03 12:58:49 -07:00
+ " <div class= \" deprecationComment \" >class_test2 passes. This is the second sentence of deprecated description for a field.</div> \ n "
2017-10-02 14:49:46 -07:00
+ " </td> \ n "
+ " </tr> \ n "
2017-12-07 14:15:14 -08:00
+ " <tr class= \" rowColor \" > \ n "
2017-10-02 14:49:46 -07:00
+ " <th class= \" colDeprecatedItemName \" scope= \" row \" ><a href= \" pkg/TestError.html#field \" >pkg.TestError.field</a></th> \ n "
+ " <td class= \" colLast \" > \ n "
2017-10-03 12:58:49 -07:00
+ " <div class= \" deprecationComment \" >error_test2 passes.</div> \ n "
2017-10-02 14:49:46 -07:00
+ " </td> \ n "
+ " </tr> \ n "
2017-12-07 14:15:14 -08:00
+ " <tr class= \" altColor \" > \ n "
2017-10-02 14:49:46 -07:00
+ " <th class= \" colDeprecatedItemName \" scope= \" row \" ><a href= \" pkg/TestException.html#field \" >pkg.TestException.field</a></th> \ n "
+ " <td class= \" colLast \" > \ n "
2017-10-03 12:58:49 -07:00
+ " <div class= \" deprecationComment \" >exception_test2 passes.</div> \ n "
2017-10-02 14:49:46 -07:00
+ " </td> \ n "
+ " </tr> \ n "
2017-12-07 14:15:14 -08:00
+ " <tr class= \" rowColor \" > \ n "
2017-10-02 14:49:46 -07:00
+ " <th class= \" colDeprecatedItemName \" scope= \" row \" ><a href= \" pkg/TestInterface.html#field \" >pkg.TestInterface.field</a></th> \ n "
+ " <td class= \" colLast \" > \ n "
2017-10-03 12:58:49 -07:00
+ " <div class= \" deprecationComment \" >interface_test2 passes.</div> \ n "
2017-10-02 14:49:46 -07:00
+ " </td> \ n "
+ " </tr> \ n "
+ " </tbody> \ n "
2016-12-13 12:25:58 -08:00
+ " </table> " ) ;
2015-11-28 18:52:17 -08:00
}
}