1 //===- unittest/Format/FormatTestJava.cpp - Formatting tests for Java -----===// 2 // 3 // The LLVM Compiler Infrastructure 4 // 5 // This file is distributed under the University of Illinois Open Source 6 // License. See LICENSE.TXT for details. 7 // 8 //===----------------------------------------------------------------------===// 9 10 #include "FormatTestUtils.h" 11 #include "clang/Format/Format.h" 12 #include "llvm/Support/Debug.h" 13 #include "gtest/gtest.h" 14 15 #define DEBUG_TYPE "format-test" 16 17 namespace clang { 18 namespace format { 19 20 class FormatTestJava : public ::testing::Test { 21 protected: 22 static std::string format(llvm::StringRef Code, unsigned Offset, 23 unsigned Length, const FormatStyle &Style) { 24 DEBUG(llvm::errs() << "---\n"); 25 DEBUG(llvm::errs() << Code << "\n\n"); 26 std::vector<tooling::Range> Ranges(1, tooling::Range(Offset, Length)); 27 tooling::Replacements Replaces = reformat(Style, Code, Ranges); 28 std::string Result = applyAllReplacements(Code, Replaces); 29 EXPECT_NE("", Result); 30 DEBUG(llvm::errs() << "\n" << Result << "\n\n"); 31 return Result; 32 } 33 34 static std::string 35 format(llvm::StringRef Code, 36 const FormatStyle &Style = getGoogleStyle(FormatStyle::LK_Java)) { 37 return format(Code, 0, Code.size(), Style); 38 } 39 40 static FormatStyle getStyleWithColumns(unsigned ColumnLimit) { 41 FormatStyle Style = getGoogleStyle(FormatStyle::LK_Java); 42 Style.ColumnLimit = ColumnLimit; 43 return Style; 44 } 45 46 static void verifyFormat( 47 llvm::StringRef Code, 48 const FormatStyle &Style = getGoogleStyle(FormatStyle::LK_Java)) { 49 EXPECT_EQ(Code.str(), format(test::messUp(Code), Style)); 50 } 51 }; 52 53 TEST_F(FormatTestJava, NoAlternativeOperatorNames) { 54 verifyFormat("someObject.and();"); 55 } 56 57 TEST_F(FormatTestJava, UnderstandsCasts) { 58 verifyFormat("a[b >> 1] = (byte) (c() << 4);"); 59 } 60 61 TEST_F(FormatTestJava, FormatsInstanceOfLikeOperators) { 62 FormatStyle Style = getStyleWithColumns(50); 63 verifyFormat("return aaaaaaaaaaaaaaaaaaaaaaaaaaaaa\n" 64 " instanceof bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb;", 65 Style); 66 Style.BreakBeforeBinaryOperators = FormatStyle::BOS_None; 67 verifyFormat("return aaaaaaaaaaaaaaaaaaaaaaaaaaaaa instanceof\n" 68 " bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb;", 69 Style); 70 verifyFormat("return aaaaaaaaaaaaaaaaaaa instanceof bbbbbbbbbbbbbbbbbbbbbbb\n" 71 " && ccccccccccccccccccc instanceof dddddddddddddddddddddd;"); 72 } 73 74 TEST_F(FormatTestJava, Chromium) { 75 verifyFormat("class SomeClass {\n" 76 " void f() {}\n" 77 " int g() {\n" 78 " return 0;\n" 79 " }\n" 80 " void h() {\n" 81 " while (true) f();\n" 82 " for (;;) f();\n" 83 " if (true) f();\n" 84 " }\n" 85 "}", 86 getChromiumStyle(FormatStyle::LK_Java)); 87 } 88 89 TEST_F(FormatTestJava, QualifiedNames) { 90 verifyFormat("public some.package.Type someFunction( // comment\n" 91 " int parameter) {}"); 92 } 93 94 TEST_F(FormatTestJava, ClassKeyword) { 95 verifyFormat("SomeClass.class.getName();"); 96 verifyFormat("Class c = SomeClass.class;"); 97 } 98 99 TEST_F(FormatTestJava, ClassDeclarations) { 100 verifyFormat("public class SomeClass {\n" 101 " private int a;\n" 102 " private int b;\n" 103 "}"); 104 verifyFormat("public class A {\n" 105 " class B {\n" 106 " int i;\n" 107 " }\n" 108 " class C {\n" 109 " int j;\n" 110 " }\n" 111 "}"); 112 verifyFormat("public class A extends B.C {}"); 113 114 verifyFormat("abstract class SomeClass\n" 115 " extends SomeOtherClass implements SomeInterface {}", 116 getStyleWithColumns(60)); 117 verifyFormat("abstract class SomeClass extends SomeOtherClass\n" 118 " implements SomeInterfaceeeeeeeeeeeee {}", 119 getStyleWithColumns(60)); 120 verifyFormat("abstract class SomeClass\n" 121 " extends SomeOtherClass\n" 122 " implements SomeInterface {}", 123 getStyleWithColumns(40)); 124 verifyFormat("abstract class SomeClass\n" 125 " extends SomeOtherClass\n" 126 " implements SomeInterface,\n" 127 " AnotherInterface {}", 128 getStyleWithColumns(40)); 129 verifyFormat("abstract class SomeClass\n" 130 " implements SomeInterface, AnotherInterface {}", 131 getStyleWithColumns(60)); 132 verifyFormat("@SomeAnnotation()\n" 133 "abstract class aaaaaaaaaaaa\n" 134 " extends bbbbbbbbbbbbbbb implements cccccccccccc {}", 135 getStyleWithColumns(76)); 136 verifyFormat("@SomeAnnotation()\n" 137 "abstract class aaaaaaaaa<a>\n" 138 " extends bbbbbbbbbbbb<b> implements cccccccccccc {}", 139 getStyleWithColumns(76)); 140 verifyFormat("interface SomeInterface<A> extends Foo, Bar {\n" 141 " void doStuff(int theStuff);\n" 142 " void doMoreStuff(int moreStuff);\n" 143 "}"); 144 verifyFormat("public interface SomeInterface {\n" 145 " void doStuff(int theStuff);\n" 146 " void doMoreStuff(int moreStuff);\n" 147 "}"); 148 verifyFormat("@interface SomeInterface {\n" 149 " void doStuff(int theStuff);\n" 150 " void doMoreStuff(int moreStuff);\n" 151 "}"); 152 verifyFormat("public @interface SomeInterface {\n" 153 " void doStuff(int theStuff);\n" 154 " void doMoreStuff(int moreStuff);\n" 155 "}"); 156 } 157 158 TEST_F(FormatTestJava, AnonymousClasses) { 159 verifyFormat("return new A() {\n" 160 " public String toString() {\n" 161 " return \"NotReallyA\";\n" 162 " }\n" 163 "};"); 164 verifyFormat("A a = new A() {\n" 165 " public String toString() {\n" 166 " return \"NotReallyA\";\n" 167 " }\n" 168 "};"); 169 } 170 171 TEST_F(FormatTestJava, EnumDeclarations) { 172 verifyFormat("enum SomeThing { ABC, CDE }"); 173 verifyFormat("enum SomeThing {\n" 174 " ABC,\n" 175 " CDE,\n" 176 "}"); 177 verifyFormat("public class SomeClass {\n" 178 " enum SomeThing { ABC, CDE }\n" 179 " void f() {}\n" 180 "}"); 181 verifyFormat("public class SomeClass implements SomeInterface {\n" 182 " enum SomeThing { ABC, CDE }\n" 183 " void f() {}\n" 184 "}"); 185 verifyFormat("enum SomeThing {\n" 186 " ABC,\n" 187 " CDE;\n" 188 " void f() {}\n" 189 "}"); 190 verifyFormat("enum SomeThing {\n" 191 " ABC(1, \"ABC\"),\n" 192 " CDE(2, \"CDE\");\n" 193 " Something(int i, String s) {}\n" 194 "}"); 195 verifyFormat("enum SomeThing {\n" 196 " ABC(new int[] {1, 2}),\n" 197 " CDE(new int[] {2, 3});\n" 198 " Something(int[] i) {}\n" 199 "}"); 200 verifyFormat("public enum SomeThing {\n" 201 " ABC {\n" 202 " public String toString() {\n" 203 " return \"ABC\";\n" 204 " }\n" 205 " },\n" 206 " CDE {\n" 207 " @Override\n" 208 " public String toString() {\n" 209 " return \"CDE\";\n" 210 " }\n" 211 " };\n" 212 " public void f() {}\n" 213 "}"); 214 verifyFormat("private enum SomeEnum implements Foo<?, B> {\n" 215 " ABC {\n" 216 " @Override\n" 217 " public String toString() {\n" 218 " return \"ABC\";\n" 219 " }\n" 220 " },\n" 221 " CDE {\n" 222 " @Override\n" 223 " public String toString() {\n" 224 " return \"CDE\";\n" 225 " }\n" 226 " };\n" 227 "}"); 228 } 229 230 TEST_F(FormatTestJava, ArrayInitializers) { 231 verifyFormat("new int[] {1, 2, 3, 4};"); 232 verifyFormat("new int[] {\n" 233 " 1, 2, 3, 4,\n" 234 "};"); 235 236 FormatStyle Style = getStyleWithColumns(65); 237 Style.Cpp11BracedListStyle = false; 238 verifyFormat( 239 "expected = new int[] { 10, 10, 10, 10, 10, 10, 10, 10, 10, 10,\n" 240 " 100, 100, 100, 100, 100, 100, 100, 100, 100, 100 };", 241 Style); 242 } 243 244 TEST_F(FormatTestJava, ThrowsDeclarations) { 245 verifyFormat("public void doSooooooooooooooooooooooooooomething()\n" 246 " throws LooooooooooooooooooooooooooooongException {}"); 247 verifyFormat("public void doSooooooooooooooooooooooooooomething()\n" 248 " throws LoooooooooongException, LooooooooooongException {}"); 249 } 250 251 TEST_F(FormatTestJava, Annotations) { 252 verifyFormat("@Override\n" 253 "public String toString() {}"); 254 verifyFormat("@Override\n" 255 "@Nullable\n" 256 "public String getNameIfPresent() {}"); 257 verifyFormat("@Override // comment\n" 258 "@Nullable\n" 259 "public String getNameIfPresent() {}"); 260 verifyFormat("@java.lang.Override // comment\n" 261 "@Nullable\n" 262 "public String getNameIfPresent() {}"); 263 264 verifyFormat("@SuppressWarnings(value = \"unchecked\")\n" 265 "public void doSomething() {}"); 266 verifyFormat("@SuppressWarnings(value = \"unchecked\")\n" 267 "@Author(name = \"abc\")\n" 268 "public void doSomething() {}"); 269 270 verifyFormat("DoSomething(new A() {\n" 271 " @Override\n" 272 " public String toString() {}\n" 273 "});"); 274 275 verifyFormat("void SomeFunction(@Nullable String something) {}"); 276 verifyFormat("void SomeFunction(@org.llvm.Nullable String something) {}"); 277 278 verifyFormat("@Partial @Mock DataLoader loader;"); 279 verifyFormat("@SuppressWarnings(value = \"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaa\")\n" 280 "public static int iiiiiiiiiiiiiiiiiiiiiiii;"); 281 282 verifyFormat("@SomeAnnotation(\"With some really looooooooooooooong text\")\n" 283 "private static final long something = 0L;"); 284 verifyFormat("@org.llvm.Qualified(\"With some really looooooooooong text\")\n" 285 "private static final long something = 0L;"); 286 verifyFormat("@Mock\n" 287 "DataLoader loooooooooooooooooooooooader =\n" 288 " aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa;", 289 getStyleWithColumns(60)); 290 verifyFormat("@org.llvm.QualifiedMock\n" 291 "DataLoader loooooooooooooooooooooooader =\n" 292 " aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa;", 293 getStyleWithColumns(60)); 294 verifyFormat("@Test(a)\n" 295 "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa =\n" 296 " aaaaaaaaaaaaaaaaaaaaaaaaaaaa(aaaaaaaaaaaaaaaaaaaaaaa);"); 297 verifyFormat("@SomeAnnotation(\n" 298 " aaaaaaaaaaaaaaaaa, aaaaaaaaaaaaaaaaaaaa)\n" 299 "int i;", 300 getStyleWithColumns(50)); 301 verifyFormat("@Test\n" 302 "ReturnType doSomething(\n" 303 " String aaaaaaaaaaaaa, String bbbbbbbbbbbbbbb) {}", 304 getStyleWithColumns(60)); 305 verifyFormat("{\n" 306 " boolean someFunction(\n" 307 " @Param(aaaaaaaaaaaaaaaa) String aaaaa,\n" 308 " String bbbbbbbbbbbbbbb) {}\n" 309 "}", 310 getStyleWithColumns(60)); 311 } 312 313 TEST_F(FormatTestJava, Generics) { 314 verifyFormat("Iterable<?> a;"); 315 verifyFormat("Iterable<?> a;"); 316 verifyFormat("Iterable<? extends SomeObject> a;"); 317 318 verifyFormat("A.<B>doSomething();"); 319 320 verifyFormat("@Override\n" 321 "public Map<String, ?> getAll() {}"); 322 323 verifyFormat("public <R> ArrayList<R> get() {}"); 324 verifyFormat("protected <R> ArrayList<R> get() {}"); 325 verifyFormat("private <R> ArrayList<R> get() {}"); 326 verifyFormat("public static <R> ArrayList<R> get() {}"); 327 verifyFormat("public static native <R> ArrayList<R> get();"); 328 verifyFormat("public final <X> Foo foo() {}"); 329 verifyFormat("public abstract <X> Foo foo();"); 330 verifyFormat("<T extends B> T getInstance(Class<T> type);"); 331 verifyFormat("Function<F, ? extends T> function;"); 332 333 verifyFormat("private Foo<X, Y>[] foos;"); 334 verifyFormat("Foo<X, Y>[] foos = this.foos;"); 335 verifyFormat("return (a instanceof List<?>)\n" 336 " ? aaaaaaaaaaaaaaaaaaaaaaa(aaaaaaaaaaaaaaaaaaaaa)\n" 337 " : aaaaaaaaaaaaaaaaaaaaaaa;", 338 getStyleWithColumns(60)); 339 340 verifyFormat( 341 "SomeLoooooooooooooooooooooongType name =\n" 342 " SomeType.foo(someArgument)\n" 343 " .<X>method()\n" 344 " .aaaaaaaaaaaaaaaaaaa()\n" 345 " .aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa();"); 346 } 347 348 TEST_F(FormatTestJava, StringConcatenation) { 349 verifyFormat("String someString = \"abc\"\n" 350 " + \"cde\";"); 351 } 352 353 TEST_F(FormatTestJava, TryCatchFinally) { 354 verifyFormat("try {\n" 355 " Something();\n" 356 "} catch (SomeException e) {\n" 357 " HandleException(e);\n" 358 "}"); 359 verifyFormat("try {\n" 360 " Something();\n" 361 "} finally {\n" 362 " AlwaysDoThis();\n" 363 "}"); 364 verifyFormat("try {\n" 365 " Something();\n" 366 "} catch (SomeException e) {\n" 367 " HandleException(e);\n" 368 "} finally {\n" 369 " AlwaysDoThis();\n" 370 "}"); 371 372 verifyFormat("try {\n" 373 " Something();\n" 374 "} catch (SomeException | OtherException e) {\n" 375 " HandleException(e);\n" 376 "}"); 377 } 378 379 TEST_F(FormatTestJava, TryWithResources) { 380 verifyFormat("try (SomeResource rs = someFunction()) {\n" 381 " Something();\n" 382 "}"); 383 verifyFormat("try (SomeResource rs = someFunction()) {\n" 384 " Something();\n" 385 "} catch (SomeException e) {\n" 386 " HandleException(e);\n" 387 "}"); 388 } 389 390 TEST_F(FormatTestJava, SynchronizedKeyword) { 391 verifyFormat("synchronized (mData) {\n" 392 " // ...\n" 393 "}"); 394 } 395 396 TEST_F(FormatTestJava, AssertKeyword) { 397 verifyFormat("assert a && b;"); 398 } 399 400 401 TEST_F(FormatTestJava, PackageDeclarations) { 402 verifyFormat("package some.really.loooooooooooooooooooooong.package;", 403 getStyleWithColumns(50)); 404 } 405 406 TEST_F(FormatTestJava, ImportDeclarations) { 407 verifyFormat("import some.really.loooooooooooooooooooooong.imported.Class;", 408 getStyleWithColumns(50)); 409 verifyFormat("import static some.really.looooooooooooooooong.imported.Class;", 410 getStyleWithColumns(50)); 411 } 412 413 TEST_F(FormatTestJava, MethodDeclarations) { 414 verifyFormat("void methodName(Object arg1,\n" 415 " Object arg2, Object arg3) {}", 416 getStyleWithColumns(40)); 417 verifyFormat("void methodName(\n" 418 " Object arg1, Object arg2) {}", 419 getStyleWithColumns(40)); 420 } 421 422 TEST_F(FormatTestJava, CppKeywords) { 423 verifyFormat("public void union(Type a, Type b);"); 424 verifyFormat("public void struct(Object o);"); 425 verifyFormat("public void delete(Object o);"); 426 } 427 428 TEST_F(FormatTestJava, NeverAlignAfterReturn) { 429 verifyFormat("return aaaaaaaaaaaaaaaaaaa\n" 430 " && bbbbbbbbbbbbbbbbbbb\n" 431 " && ccccccccccccccccccc;", 432 getStyleWithColumns(40)); 433 verifyFormat("return (result == null)\n" 434 " ? aaaaaaaaaaaaaaaaa\n" 435 " : bbbbbbbbbbbbbbbbb;", 436 getStyleWithColumns(40)); 437 verifyFormat("return aaaaaaaaaaaaaaaaaaa()\n" 438 " .bbbbbbbbbbbbbbbbbbb()\n" 439 " .ccccccccccccccccccc();", 440 getStyleWithColumns(40)); 441 verifyFormat("return aaaaaaaaaaaaaaaaaaa()\n" 442 " .bbbbbbbbbbbbbbbbbbb(\n" 443 " ccccccccccccccc)\n" 444 " .ccccccccccccccccccc();", 445 getStyleWithColumns(40)); 446 } 447 448 TEST_F(FormatTestJava, FormatsInnerBlocks) { 449 verifyFormat("someObject.someFunction(new Runnable() {\n" 450 " @Override\n" 451 " public void run() {\n" 452 " System.out.println(42);\n" 453 " }\n" 454 "}, someOtherParameter);"); 455 verifyFormat("someFunction(new Runnable() {\n" 456 " public void run() {\n" 457 " System.out.println(42);\n" 458 " }\n" 459 "});"); 460 verifyFormat("someObject.someFunction(\n" 461 " new Runnable() {\n" 462 " @Override\n" 463 " public void run() {\n" 464 " System.out.println(42);\n" 465 " }\n" 466 " },\n" 467 " new Runnable() {\n" 468 " @Override\n" 469 " public void run() {\n" 470 " System.out.println(43);\n" 471 " }\n" 472 " },\n" 473 " someOtherParameter);"); 474 } 475 476 TEST_F(FormatTestJava, FormatsLambdas) { 477 verifyFormat("(aaaaaaaaaa, bbbbbbbbbb) -> aaaaaaaaaa + bbbbbbbbbb;"); 478 verifyFormat("(aaaaaaaaaa, bbbbbbbbbb)\n" 479 " -> aaaaaaaaaa + bbbbbbbbbb;", 480 getStyleWithColumns(40)); 481 verifyFormat("Runnable someLambda = () -> DoSomething();"); 482 verifyFormat("Runnable someLambda = () -> {\n" 483 " DoSomething();\n" 484 "}"); 485 486 verifyFormat("Runnable someLambda =\n" 487 " (int aaaaa) -> DoSomething(aaaaa);", 488 getStyleWithColumns(40)); 489 } 490 491 TEST_F(FormatTestJava, BreaksStringLiterals) { 492 // FIXME: String literal breaking is currently disabled for Java and JS, as it 493 // requires strings to be merged using "+" which we don't support. 494 EXPECT_EQ("\"some text other\";", 495 format("\"some text other\";", getStyleWithColumns(14))); 496 } 497 498 TEST_F(FormatTestJava, AlignsBlockComments) { 499 EXPECT_EQ("/*\n" 500 " * Really multi-line\n" 501 " * comment.\n" 502 " */\n" 503 "void f() {}", 504 format(" /*\n" 505 " * Really multi-line\n" 506 " * comment.\n" 507 " */\n" 508 " void f() {}")); 509 } 510 511 } // end namespace tooling 512 } // end namespace clang 513