blob: 9f1a85ea81b1a55f23cc47d9ac5963506867ee79 [file] [log] [blame]
/*****************************************************************************
* Copyright (c) 2000, 2003 IBM Corporation and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Common Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/cpl-v10.html
*
* Contributors:
* IBM Corporation - initial API and implementation
*****************************************************************************/
package org.eclipse.jdt.text.tests.comments;
import java.util.HashMap;
import java.util.Map;
import junit.framework.Test;
import junit.framework.TestSuite;
import org.eclipse.jdt.core.JavaCore;
import org.eclipse.jdt.core.formatter.DefaultCodeFormatterConstants;
import org.eclipse.jdt.ui.PreferenceConstants;
import org.eclipse.jdt.internal.ui.text.IJavaPartitions;
import org.eclipse.jdt.internal.ui.text.comment.JavaDocLine;
import org.eclipse.jdt.internal.ui.text.comment.MultiCommentLine;
public class JavaDocTestCase extends CommentTestCase {
protected static final String INFIX= MultiCommentLine.MULTI_COMMENT_CONTENT_PREFIX;
protected static final String POSTFIX= MultiCommentLine.MULTI_COMMENT_END_PREFIX;
protected static final String PREFIX= JavaDocLine.JAVADOC_START_PREFIX;
private Map fUserOptions;
public static Test suite() {
return new TestSuite(JavaDocTestCase.class);
}
public JavaDocTestCase(String name) {
super(name);
}
/**
* {@inheritDoc}
*/
protected void tearDown() throws Exception {
fUserOptions= null;
}
protected String getCommentType() {
return IJavaPartitions.JAVA_DOC;
}
protected Map getUserOptions() {
return fUserOptions;
}
protected void setUserOption(String name, String value) {
if (fUserOptions == null)
fUserOptions= new HashMap();
fUserOptions.put(name, value);
}
public void testSingleLineComment1() {
assertEquals(PREFIX + DELIMITER + INFIX + "test" + DELIMITER + POSTFIX, testFormat(PREFIX + "\t\t" + DELIMITER + "*\t test*/")); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$
}
public void testSingleLineComment2() {
assertEquals(PREFIX + DELIMITER + INFIX + "test" + DELIMITER + POSTFIX, testFormat(PREFIX + "test" + DELIMITER + "\t" + POSTFIX)); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$
}
public void testSingleLineComment3() {
assertEquals(PREFIX + DELIMITER + INFIX + "test" + DELIMITER + POSTFIX, testFormat(PREFIX + DELIMITER + "* test\t*/")); //$NON-NLS-1$ //$NON-NLS-2$
}
public void testSingleLineComment4() {
assertEquals(PREFIX + DELIMITER + INFIX + "test" + DELIMITER + POSTFIX, testFormat(PREFIX + "test" + DELIMITER + POSTFIX)); //$NON-NLS-1$ //$NON-NLS-2$
}
public void testSingleLineCommentSpace1() {
assertEquals(PREFIX + " test" + POSTFIX, testFormat(PREFIX + "test*/")); //$NON-NLS-1$ //$NON-NLS-2$
}
public void testSingleLineCommentSpace2() {
assertEquals(PREFIX + " test" + POSTFIX, testFormat(PREFIX + "test" + POSTFIX)); //$NON-NLS-1$ //$NON-NLS-2$
}
public void testSingleLineCommentSpace3() {
assertEquals(PREFIX + " test" + POSTFIX, testFormat(PREFIX + "test*/")); //$NON-NLS-1$ //$NON-NLS-2$
}
public void testSingleLineCommentSpace4() {
assertEquals(PREFIX + " test test" + POSTFIX, testFormat(PREFIX + " test test*/")); //$NON-NLS-1$ //$NON-NLS-2$
}
public void testSingleLineCommentTabs1() {
assertEquals(PREFIX + " test test" + POSTFIX, testFormat(PREFIX + "\ttest\ttest" + POSTFIX)); //$NON-NLS-1$ //$NON-NLS-2$
}
public void testSingleLineCommentTabs2() {
assertEquals(PREFIX + " test test" + POSTFIX, testFormat(PREFIX + "\ttest\ttest*/")); //$NON-NLS-1$ //$NON-NLS-2$
}
public void testMultiLineCommentBreak1() {
String input= PREFIX + " test<br>test" + POSTFIX; //$NON-NLS-1$
String expected= PREFIX + DELIMITER + INFIX + "test <br>" + DELIMITER + INFIX + "test" + DELIMITER + POSTFIX; //$NON-NLS-1$ //$NON-NLS-2$
assertEquals(expected, testFormat(input));
}
public void testMultiLineCommentCodeSnippet1() {
String prefix= PREFIX + DELIMITER + INFIX + "<pre>" + DELIMITER + INFIX; //$NON-NLS-1$
String postfix= DELIMITER + INFIX + "</pre>" + DELIMITER + POSTFIX; //$NON-NLS-1$
String input= prefix + "while (i != 0) i--;" + postfix; //$NON-NLS-1$
String expected= prefix + "while (i != 0)" + DELIMITER + INFIX + "\ti--;" + postfix; //$NON-NLS-1$//$NON-NLS-2$
assertEquals(expected, testFormat(input));
}
/**
* [formatting] Error in formatting parts of java code snippets in comment
* https://bugs.eclipse.org/bugs/show_bug.cgi?id=44035
*/
public void testMultiLineCommentCodeSnippet2() {
String prefix= PREFIX + DELIMITER + INFIX + "<pre>" + DELIMITER + INFIX; //$NON-NLS-1$
String postfix= DELIMITER + INFIX + "</pre>" + DELIMITER + POSTFIX; //$NON-NLS-1$
String input= prefix + "while (i != 0) { i--; }" + postfix; //$NON-NLS-1$
String expected= prefix + "while (i != 0) {" + DELIMITER + INFIX + "\ti--;" + DELIMITER + INFIX + "}" + postfix; //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$
assertEquals(expected, testFormat(input));
}
public void testMultiLineCommentCodeSnippet3() {
String input= PREFIX + DELIMITER + "<pre>" + DELIMITER + "while (i != 0)" + DELIMITER + "i--;" + DELIMITER + "</pre>" + DELIMITER + POSTFIX; //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$
String expected= PREFIX + DELIMITER + INFIX + "<pre>" + DELIMITER + INFIX + "while (i != 0)" + DELIMITER + INFIX + "\ti--;" + DELIMITER + INFIX + "</pre>" + DELIMITER + POSTFIX; //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$
assertEquals(expected, testFormat(input));
}
public void testMultiLineCommentCodeSnippetHtmlEntities1() {
String prefix= PREFIX + DELIMITER + INFIX + "<pre>" + DELIMITER + INFIX; //$NON-NLS-1$
String postfix= DELIMITER + INFIX + "</pre>" + DELIMITER + POSTFIX; //$NON-NLS-1$
String input= prefix + "System.out.println(\"test\");" + postfix; //$NON-NLS-1$
String expected= prefix + "System.out.println(&quot;test&quot;);" + postfix; //$NON-NLS-1$
assertEquals(expected, testFormat(input));
}
public void testMultiLineCommentIndentTabs1() {
String prefix= "public class Test {" + DELIMITER + "\t\t"; //$NON-NLS-1$ //$NON-NLS-2$
String content= PREFIX + DELIMITER + "\t\t\t" + INFIX + "test test" + DELIMITER + "\t\t\t\t" + POSTFIX; //$NON-NLS-1$//$NON-NLS-2$ //$NON-NLS-3$
String postfix= DELIMITER + "}"; //$NON-NLS-1$
String expected= PREFIX + DELIMITER + "\t\t" + INFIX + "test test" + DELIMITER + "\t\t" + POSTFIX; //$NON-NLS-1$//$NON-NLS-2$ //$NON-NLS-3$
setUserOption(DefaultCodeFormatterConstants.FORMATTER_TAB_CHAR, JavaCore.TAB);
assertEquals(prefix + expected + postfix, testFormat(prefix + content + postfix, prefix.length(), content.length()));
}
/**
* [formatting] Comments formatter inserts tabs when it should use spaces
* https://bugs.eclipse.org/bugs/show_bug.cgi?id=47491
*/
public void testMultiLineCommentIndentSpaces1() {
String prefix= "public class Test {" + DELIMITER + "\t"; //$NON-NLS-1$ //$NON-NLS-2$
String content= PREFIX + DELIMITER + "\t\t" + INFIX + "test test" + DELIMITER + " " + POSTFIX; //$NON-NLS-1$//$NON-NLS-2$ //$NON-NLS-3$
String postfix= DELIMITER + "}"; //$NON-NLS-1$
String expected= PREFIX + DELIMITER + " " + INFIX + "test test" + DELIMITER + " " + POSTFIX; //$NON-NLS-1$//$NON-NLS-2$ //$NON-NLS-3$
setUserOption(DefaultCodeFormatterConstants.FORMATTER_TAB_CHAR, JavaCore.SPACE);
setUserOption(DefaultCodeFormatterConstants.FORMATTER_TAB_SIZE, "3"); //$NON-NLS-1$
assertEquals(prefix + expected + postfix, testFormat(prefix + content + postfix, prefix.length(), content.length()));
}
/**
* [formatting] Repeated insertion of new line when formatting javadoc comment
* https://bugs.eclipse.org/bugs/show_bug.cgi?id=50212
*/
public void testMultiLineCommentBlankLineAfterPre1() {
String input= PREFIX + DELIMITER + INFIX + "<pre></pre>" + DELIMITER + INFIX + "test" + DELIMITER + POSTFIX; //$NON-NLS-1$ //$NON-NLS-2$
String expected= PREFIX + DELIMITER + INFIX + "<pre></pre>" + DELIMITER + INFIX + DELIMITER + INFIX + "test" + DELIMITER + POSTFIX; //$NON-NLS-1$ //$NON-NLS-2$
String result= testFormat(input);
assertEquals(expected, result);
result= testFormat(result);
assertEquals(expected, result);
}
/**
* [formatting][implementation] comment line length not correctly applied
* https://bugs.eclipse.org/bugs/show_bug.cgi?id=46341
* Do not wrap.
*/
public void testMultiLineCommentLineBreakBeforeImmutableRegions1() {
setUserOption(PreferenceConstants.FORMATTER_COMMENT_LINELENGTH, "22"); //$NON-NLS-1$
String input= PREFIX + DELIMITER + INFIX + "a <code>test</code>" + DELIMITER + POSTFIX; //$NON-NLS-1$
String expected= input;
String result= testFormat(input);
assertEquals(expected, result);
}
/**
* [formatting][implementation] comment line length not correctly applied
* https://bugs.eclipse.org/bugs/show_bug.cgi?id=46341
* Do wrap.
*/
public void testMultiLineCommentLineBreakBeforeImmutableRegions2() {
setUserOption(PreferenceConstants.FORMATTER_COMMENT_LINELENGTH, "21"); //$NON-NLS-1$
String input= PREFIX + DELIMITER + INFIX + "a <code>test</code>" + DELIMITER + POSTFIX; //$NON-NLS-1$
String expected= PREFIX + DELIMITER + INFIX + "a" + DELIMITER + INFIX + "<code>test</code>" + DELIMITER + POSTFIX; //$NON-NLS-1$ //$NON-NLS-2$
String result= testFormat(input);
assertEquals(expected, result);
}
/**
* [formatting][implementation] comment line length not correctly applied
* https://bugs.eclipse.org/bugs/show_bug.cgi?id=46341
* Do not wrap. (Consecutive immutable regions on multiple lines.)
*/
public void testMultiLineCommentLineBreakBeforeImmutableRegions3() {
setUserOption(PreferenceConstants.FORMATTER_COMMENT_LINELENGTH, "20"); //$NON-NLS-1$
String input= PREFIX + DELIMITER + INFIX + "a <code>" + DELIMITER + INFIX + "testestestestestestestestestest" + DELIMITER + INFIX + "</code>" + DELIMITER + POSTFIX; //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$
String expected= input;
String result= testFormat(input);
assertEquals(expected, result);
}
/**
* Prefs > Java > Code Formatter > Comments: Preview incorrect
* https://bugs.eclipse.org/bugs/show_bug.cgi?id=55204
* Do not insert blank line before Javadoc tags
*/
public void testMultiLineCommentBlankLineBeforeJavadoctags1() {
setUserOption(PreferenceConstants.FORMATTER_COMMENT_SEPARATEROOTTAGS, "false"); //$NON-NLS-1$
setUserOption(PreferenceConstants.FORMATTER_COMMENT_CLEARBLANKLINES, "false"); //$NON-NLS-1$
String input= PREFIX + DELIMITER + INFIX + "Description" + DELIMITER + INFIX + "@param test" + DELIMITER + POSTFIX; //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$
String expected= input;
String result= testFormat(input);
assertEquals(expected, result);
}
/**
* Prefs > Java > Code Formatter > Comments: Preview incorrect
* https://bugs.eclipse.org/bugs/show_bug.cgi?id=55204
* Do insert blank line before Javadoc tags
*/
public void testMultiLineCommentBlankLineBeforeJavadoctags2() {
setUserOption(PreferenceConstants.FORMATTER_COMMENT_SEPARATEROOTTAGS, "true"); //$NON-NLS-1$
setUserOption(PreferenceConstants.FORMATTER_COMMENT_CLEARBLANKLINES, "true"); //$NON-NLS-1$
String prefix= PREFIX + DELIMITER + INFIX + "Description"; //$NON-NLS-1$
String postfix= DELIMITER + INFIX + "@param test" + DELIMITER + POSTFIX; //$NON-NLS-1$
String input= prefix + postfix;
String expected= prefix + DELIMITER + INFIX + postfix;
String result= testFormat(input);
assertEquals(expected, result);
}
/**
* Prefs > Java > Code Formatter > Comments: Preview incorrect
* https://bugs.eclipse.org/bugs/show_bug.cgi?id=55204
* Do not remove blank line before Javadoc tags
*/
public void testMultiLineCommentBlankLineBeforeJavadoctags3() {
setUserOption(PreferenceConstants.FORMATTER_COMMENT_SEPARATEROOTTAGS, "true"); //$NON-NLS-1$
setUserOption(PreferenceConstants.FORMATTER_COMMENT_CLEARBLANKLINES, "true"); //$NON-NLS-1$
String input= PREFIX + DELIMITER + INFIX + "Description" + DELIMITER + INFIX + DELIMITER + INFIX + "@param test" + DELIMITER + POSTFIX; //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$
String expected= input;
String result= testFormat(input);
assertEquals(expected, result);
}
/**
* Prefs > Java > Code Formatter > Comments: Preview incorrect
* https://bugs.eclipse.org/bugs/show_bug.cgi?id=55204
* Do remove blank line before Javadoc tags
*/
public void testMultiLineCommentBlankLineBeforeJavadoctags4() {
setUserOption(PreferenceConstants.FORMATTER_COMMENT_SEPARATEROOTTAGS, "false"); //$NON-NLS-1$
setUserOption(PreferenceConstants.FORMATTER_COMMENT_CLEARBLANKLINES, "true"); //$NON-NLS-1$
String prefix= PREFIX + DELIMITER + INFIX + "Description"; //$NON-NLS-1$
String postfix= DELIMITER + INFIX + "@param test" + DELIMITER + POSTFIX; //$NON-NLS-1$
String input= prefix + DELIMITER + INFIX + postfix;
String expected= prefix + postfix;
String result= testFormat(input);
assertEquals(expected, result);
}
}