Initial version
authorDenis Zhdanov <Denis.Zhdanov@jetbrains.com>
Tue, 27 Apr 2010 14:54:55 +0000 (18:54 +0400)
committerDenis Zhdanov <Denis.Zhdanov@jetbrains.com>
Tue, 27 Apr 2010 14:54:55 +0000 (18:54 +0400)
java/java-tests/testSrc/com/intellij/psi/formatter/JavaFormatterAlignmentTest.java [new file with mode: 0644]
java/java-tests/testSrc/com/intellij/psi/formatter/JavaFormattingBlankLinesTest.java [new file with mode: 0644]
java/java-tests/testSrc/com/intellij/psi/formatter/JavaFormattingBracesTest.java [new file with mode: 0644]

diff --git a/java/java-tests/testSrc/com/intellij/psi/formatter/JavaFormatterAlignmentTest.java b/java/java-tests/testSrc/com/intellij/psi/formatter/JavaFormatterAlignmentTest.java
new file mode 100644 (file)
index 0000000..6c500db
--- /dev/null
@@ -0,0 +1,38 @@
+/*
+ * Copyright 2000-2010 JetBrains s.r.o.
+ *
+ * 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.
+ */
+package com.intellij.psi.formatter;
+
+import com.intellij.openapi.fileTypes.StdFileTypes;
+import com.intellij.psi.codeStyle.CodeStyleSettings;
+
+/**
+ * Is intended to hold specific java formatting tests for alignment settings (
+ * <code>Project Settings - Code Style - Alignment and Braces</code>).
+ *
+ * @author Denis Zhdanov
+ * @since Apr 27, 2010 6:42:00 PM
+ */
+public class JavaFormatterAlignmentTest extends AbstractJavaFormattingTest {
+
+  public void testChainedMethodsAlignment() throws Exception {
+    // Inspired by IDEA-30369
+    getSettings().ALIGN_MULTILINE_CHAINED_METHODS = true;
+    getSettings().METHOD_CALL_CHAIN_WRAP = CodeStyleSettings.WRAP_AS_NEEDED;
+    getSettings().getIndentOptions(StdFileTypes.JAVA).CONTINUATION_INDENT_SIZE = 8;
+    doTest();
+  }
+
+}
diff --git a/java/java-tests/testSrc/com/intellij/psi/formatter/JavaFormattingBlankLinesTest.java b/java/java-tests/testSrc/com/intellij/psi/formatter/JavaFormattingBlankLinesTest.java
new file mode 100644 (file)
index 0000000..8a4f916
--- /dev/null
@@ -0,0 +1,48 @@
+/*
+ * Copyright 2000-2010 JetBrains s.r.o.
+ *
+ * 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.
+ */
+package com.intellij.psi.formatter;
+
+/**
+ * Is intended to hold specific java formatting tests for 'blank lines' settings.
+ *
+ * @author Denis Zhdanov
+ * @since Apr 27, 2010 6:33:00 PM
+ */
+public class JavaFormattingBlankLinesTest extends AbstractJavaFormattingTest {
+
+  public void testBlankLinesAroundClassInitializationBlock() throws Exception {
+    getSettings().BLANK_LINES_AROUND_METHOD = 3;
+    doTextTest(
+      "class T {\n" +
+      "    private final DecimalFormat fmt = new DecimalFormat();\n" +
+      "    {\n" +
+      "        fmt.setGroupingUsed(false);\n" +
+      "        fmt.setDecimalFormatSymbols(new DecimalFormatSymbols(Locale.US));\n" +
+      "    }\n" +
+      "}",
+      "class T {\n" +
+      "    private final DecimalFormat fmt = new DecimalFormat();\n" +
+      "\n" +
+      "\n" +
+      "\n" +
+      "    {\n" +
+      "        fmt.setGroupingUsed(false);\n" +
+      "        fmt.setDecimalFormatSymbols(new DecimalFormatSymbols(Locale.US));\n" +
+      "    }\n" +
+      "}");
+  }
+
+}
diff --git a/java/java-tests/testSrc/com/intellij/psi/formatter/JavaFormattingBracesTest.java b/java/java-tests/testSrc/com/intellij/psi/formatter/JavaFormattingBracesTest.java
new file mode 100644 (file)
index 0000000..b88c527
--- /dev/null
@@ -0,0 +1,120 @@
+/*
+ * Copyright 2000-2010 JetBrains s.r.o.
+ *
+ * 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.
+ */
+package com.intellij.psi.formatter;
+
+import com.intellij.openapi.fileTypes.StdFileTypes;
+
+/**
+ * Is intended to hold specific java formatting tests for 'braces placement' settings (
+ * <code>Project Settings - Code Style - Alignment and Braces</code>).
+ *
+ * @author Denis Zhdanov
+ * @since Apr 27, 2010 6:39:24 PM
+ */
+public class JavaFormattingBracesTest extends AbstractJavaFormattingTest {
+
+  public void testFlyingGeeseBraces() {
+    // Inspired by IDEA-52305
+
+    getSettings().USE_FLYING_GEESE_BRACES = true;
+    getSettings().FLYING_GEESE_BRACES_GAP = 1;
+    getSettings().BLANK_LINES_AROUND_METHOD = 0; // controls number of blank lines between instance initialization block and field. Very strange
+    getSettings().KEEP_SIMPLE_METHODS_IN_ONE_LINE = true; // allow methods like 'void foo() {}'
+    getSettings().getIndentOptions(StdFileTypes.JAVA).INDENT_SIZE = 2;
+
+    // Flying gees style for class initialization and instance initialization block when there are no fields/methods.
+    doTextTest(
+      "class FormattingTest {\n" +
+      "  {\n" +
+      "  } \n" +
+      "}",
+      "class FormattingTest { {\n" +
+      "} }"
+    );
+
+    // Flying gees style for class initialization and instance initialization block when there are fields after the block.
+    doTextTest(
+      "class FormattingTest {\n" +
+      "  {\n" +
+      "  } \n" +
+      "  int i;\n" +
+      "}",
+      "class FormattingTest {\n" +
+      "  {\n" +
+      "  } \n" +
+      "  int i;\n" +
+      "}"
+    );
+
+    // Flying gees style for class initialization and instance initialization block when there are fields before the block.
+    doTextTest(
+      "class FormattingTest {\n" +
+      "  int i;\n" +
+      "  {\n" +
+      "  } \n" +
+      "}",
+      "class FormattingTest {\n" +
+      "  int i;\n" +
+      "  {\n" +
+      "  } \n" +
+      "}"
+    );
+
+    // Flying gees style for class initialization and instance initialization block when there are methods after the block.
+    doTextTest(
+      "class FormattingTest {\n" +
+      "  {\n" +
+      "  } \n" +
+      "  void foo() {}\n" +
+      "}",
+      "class FormattingTest {\n" +
+      "  {\n" +
+      "  } \n" +
+      "  void foo() {}\n" +
+      "}"
+    );
+
+    // Flying gees style for class initialization and instance initialization block when there are methods before the block.
+    doTextTest(
+      "class FormattingTest {\n" +
+      "  void foo() {}\n" +
+      "  {\n" +
+      "  } \n" +
+      "}",
+      "class FormattingTest {\n" +
+      "  void foo() {}\n" +
+      "  {\n" +
+      "  } \n" +
+      "}"
+    );
+
+    // Flying gees style for class initialization and multiple instance initialization blocks.
+    doTextTest(
+      "class FormattingTest {\n" +
+      "  {\n" +
+      "  } \n" +
+      "  {\n" +
+      "  }\n" +
+      "}",
+      "class FormattingTest {\n" +
+      "  {\n" +
+      "  } \n" +
+      "  {\n" +
+      "  }\n" +
+      "}"
+    );
+  }
+}