diff options
| author | 2020-08-03 15:06:44 +0000 | |
|---|---|---|
| committer | 2020-08-03 15:06:44 +0000 | |
| commit | b64793999546ed8adebaeebd9d8345d18db8927d (patch) | |
| tree | 4357c27b561d73b0e089727c6ed659f2ceff5f47 /gnu/llvm/tools/clang/unittests/Format/FormatTestProto.cpp | |
| parent | Add support for UTF-8 DISPLAY-HINTs with octet length. For now only (diff) | |
| download | wireguard-openbsd-b64793999546ed8adebaeebd9d8345d18db8927d.tar.xz wireguard-openbsd-b64793999546ed8adebaeebd9d8345d18db8927d.zip | |
Remove LLVM 8.0.1 files.
Diffstat (limited to 'gnu/llvm/tools/clang/unittests/Format/FormatTestProto.cpp')
| -rw-r--r-- | gnu/llvm/tools/clang/unittests/Format/FormatTestProto.cpp | 653 |
1 files changed, 0 insertions, 653 deletions
diff --git a/gnu/llvm/tools/clang/unittests/Format/FormatTestProto.cpp b/gnu/llvm/tools/clang/unittests/Format/FormatTestProto.cpp deleted file mode 100644 index 70ef2d2f134..00000000000 --- a/gnu/llvm/tools/clang/unittests/Format/FormatTestProto.cpp +++ /dev/null @@ -1,653 +0,0 @@ -//===- unittest/Format/FormatTestProto.cpp --------------------------------===// -// -// The LLVM Compiler Infrastructure -// -// This file is distributed under the University of Illinois Open Source -// License. See LICENSE.TXT for details. -// -//===----------------------------------------------------------------------===// - -#include "FormatTestUtils.h" -#include "clang/Format/Format.h" -#include "llvm/Support/Debug.h" -#include "gtest/gtest.h" - -#define DEBUG_TYPE "format-test" - -namespace clang { -namespace format { - -class FormatTestProto : public ::testing::Test { -protected: - static std::string format(llvm::StringRef Code, unsigned Offset, - unsigned Length, const FormatStyle &Style) { - LLVM_DEBUG(llvm::errs() << "---\n"); - LLVM_DEBUG(llvm::errs() << Code << "\n\n"); - std::vector<tooling::Range> Ranges(1, tooling::Range(Offset, Length)); - tooling::Replacements Replaces = reformat(Style, Code, Ranges); - auto Result = applyAllReplacements(Code, Replaces); - EXPECT_TRUE(static_cast<bool>(Result)); - LLVM_DEBUG(llvm::errs() << "\n" << *Result << "\n\n"); - return *Result; - } - - static std::string format(llvm::StringRef Code) { - FormatStyle Style = getGoogleStyle(FormatStyle::LK_Proto); - Style.ColumnLimit = 60; // To make writing tests easier. - return format(Code, 0, Code.size(), Style); - } - - static void verifyFormat(llvm::StringRef Code) { - EXPECT_EQ(Code.str(), format(Code)) << "Expected code is not stable"; - EXPECT_EQ(Code.str(), format(test::messUp(Code))); - } -}; - -TEST_F(FormatTestProto, FormatsMessages) { - verifyFormat("message SomeMessage {\n" - " required int32 field1 = 1;\n" - "}"); - verifyFormat("message SomeMessage {\n" - " required .absolute.Reference field1 = 1;\n" - "}"); - verifyFormat("message SomeMessage {\n" - " required int32 field1 = 1;\n" - " optional string field2 = 2 [default = \"2\"]\n" - "}"); - - verifyFormat("message SomeMessage {\n" - " optional really.really.long.qualified.type.aaa.aaaaaaa\n" - " fiiiiiiiiiiiiiiiiiiiiiiiiield = 1;\n" - " optional\n" - " really.really.long.qualified.type.aaa.aaaaaaa.aaaaaaaa\n" - " another_fiiiiiiiiiiiiiiiiiiiiield = 2;\n" - "}"); - verifyFormat("message SomeMessage {\n" - " map<string, Project> projects = 1;\n" - " optional map<string, int32> size_projects = 2;\n" - " map<int, really.really.really.long.qualified.type.nameeee>\n" - " projects = 3;\n" - " map<int, really.really.really.really.long.qualified.type\n" - " .nameeee> projects = 4;\n" - " map<int,\n" - " reallyreallyreallyreallyreallyreallyreallylongname>\n" - " projects = 5;\n" - " map<int, Project>\n" - " longlonglonglonglonglonglonglonglonglongonglon = 6;\n" - " map<releleallyreallyreallyreallyreallyreallyreallylongname,\n" - " int> projects = 7;\n" - " map<releleallyreallyreallyreallyreallyreallyreallylongname,\n" - " releleallyreallyreallyreallyreallyreallyreallylongname>\n" - " releleallyreallyreallyreallyreallyreallyreallylongnam =\n" - " 8;\n" - " map<relele.llyreal.yreallyr.allyreally.eallyreal\n" - " .sauenirylongname,\n" - " really.really.really.really.long.qualified.type\n" - " .nameeee> projects = 9;\n" - "}"); -} - -TEST_F(FormatTestProto, KeywordsInOtherLanguages) { - verifyFormat("optional string operator = 1;"); -} - -TEST_F(FormatTestProto, FormatsEnums) { - verifyFormat("enum Type {\n" - " UNKNOWN = 0;\n" - " TYPE_A = 1;\n" - " TYPE_B = 2;\n" - "};"); - verifyFormat("enum Type {\n" - " UNKNOWN = 0 [(some_options) = { a: aa, b: bb }];\n" - "};"); - verifyFormat("enum Type {\n" - " UNKNOWN = 0 [(some_options) = {\n" - " a: aa, // wrap\n" - " b: bb\n" - " }];\n" - "};"); -} - -TEST_F(FormatTestProto, UnderstandsReturns) { - verifyFormat("rpc Search(SearchRequest) returns (SearchResponse);"); -} - -TEST_F(FormatTestProto, MessageFieldAttributes) { - verifyFormat("optional string test = 1 [default = \"test\"];"); - verifyFormat("optional bool a = 1 [default = true, deprecated = true];"); - verifyFormat("optional LongMessageType long_proto_field = 1 [\n" - " default = REALLY_REALLY_LONG_CONSTANT_VALUE,\n" - " deprecated = true\n" - "];"); - verifyFormat("optional LongMessageType long_proto_field = 1\n" - " [default = REALLY_REALLY_LONG_CONSTANT_VALUE];"); - verifyFormat("repeated double value = 1\n" - " [(aaaaaaa.aaaaaaaaa) = { aaaaaaaaaaaaaaaaa: AAAAAAAA }];"); - verifyFormat("repeated double value = 1 [(aaaaaaa.aaaaaaaaa) = {\n" - " aaaaaaaaaaaaaaaa: AAAAAAAAAA,\n" - " bbbbbbbbbbbbbbbb: BBBBBBBBBB\n" - "}];"); - verifyFormat("repeated double value = 1 [(aaaaaaa.aaaaaaaaa) = {\n" - " aaaaaaaaaaaaaaaa: AAAAAAAAAA\n" - " bbbbbbbbbbbbbbbb: BBBBBBBBBB\n" - "}];"); - verifyFormat("repeated double value = 1 [\n" - " (aaaaaaa.aaaaaaaaa) = {\n" - " aaaaaaaaaaaaaaaa: AAAAAAAAAA\n" - " bbbbbbbbbbbbbbbb: BBBBBBBBBB\n" - " },\n" - " (bbbbbbb.bbbbbbbbb) = {\n" - " aaaaaaaaaaaaaaaa: AAAAAAAAAA\n" - " bbbbbbbbbbbbbbbb: BBBBBBBBBB\n" - " }\n" - "];"); - verifyFormat("repeated double value = 1 [(aaaaaaa.aaaaaaaaa) = {\n" - " type: \"AAAAAAAAAA\"\n" - " is: \"AAAAAAAAAA\"\n" - " or: \"BBBBBBBBBB\"\n" - "}];"); - verifyFormat("repeated double value = 1 [(aaaaaaa.aaaaaaaaa) = {\n" - " aaaaaaaaaaaaaaaa: AAAAAAAAAA,\n" - " bbbbbbb: BBBB,\n" - " bbbb: BBB\n" - "}];"); - verifyFormat("optional AAA aaa = 1 [\n" - " foo = {\n" - " key: 'a' //\n" - " },\n" - " bar = {\n" - " key: 'a' //\n" - " }\n" - "];"); - verifyFormat("optional string test = 1 [default = \"test\"\n" - " \"test\"];"); - verifyFormat("optional Aaaaaaaa aaaaaaaa = 12 [\n" - " (aaa) = aaaa,\n" - " (bbbbbbbbbbbbbbbbbbbbbbbbbb) = {\n" - " aaaaaaaaaaaaaaaaa: true,\n" - " aaaaaaaaaaaaaaaa: true\n" - " }\n" - "];"); - verifyFormat("extensions 20 [(proto2.type) = 'Aaaa.bbbb'];"); - verifyFormat("extensions 20\n" - " [(proto3.type) = 'Aaaa.bbbb', (aaa.Aaa) = 'aaa.bbb'];"); - verifyFormat("extensions 123 [\n" - " (aaa) = aaaa,\n" - " (bbbbbbbbbbbbbbbbbbbbbbbbbb) = {\n" - " aaaaaaaaaaaaaaaaa: true,\n" - " aaaaaaaaaaaaaaaa: true\n" - " }\n" - "];"); -} - -TEST_F(FormatTestProto, DoesntWrapFileOptions) { - EXPECT_EQ( - "option java_package = " - "\"some.really.long.package.that.exceeds.the.column.limit\";", - format("option java_package = " - "\"some.really.long.package.that.exceeds.the.column.limit\";")); -} - -TEST_F(FormatTestProto, FormatsOptions) { - verifyFormat("option (MyProto.options) = {\n" - " field_a: OK\n" - " field_b: \"OK\"\n" - " field_c: \"OK\"\n" - " msg_field: { field_d: 123 }\n" - "};"); - verifyFormat("option (MyProto.options) = {\n" - " field_a: OK\n" - " field_b: \"OK\"\n" - " field_c: \"OK\"\n" - " msg_field: { field_d: 123 field_e: OK }\n" - "};"); - verifyFormat("option (MyProto.options) = {\n" - " field_a: OK // Comment\n" - " field_b: \"OK\"\n" - " field_c: \"OK\"\n" - " msg_field: { field_d: 123 }\n" - "};"); - verifyFormat("option (MyProto.options) = {\n" - " field_c: \"OK\"\n" - " msg_field { field_d: 123 }\n" - "};"); - verifyFormat("option (MyProto.options) = {\n" - " field_a: OK\n" - " field_b { field_c: OK }\n" - " field_d: OKOKOK\n" - " field_e: OK\n" - "}"); - - // Support syntax with <> instead of {}. - verifyFormat("option (MyProto.options) = {\n" - " field_c: \"OK\",\n" - " msg_field: < field_d: 123 >\n" - " empty: <>\n" - " empty <>\n" - "};"); - - verifyFormat("option (MyProto.options) = {\n" - " field_a: OK\n" - " field_b < field_c: OK >\n" - " field_d: OKOKOK\n" - " field_e: OK\n" - "}"); - - verifyFormat("option (MyProto.options) = {\n" - " msg_field: <>\n" - " field_c: \"OK\",\n" - " msg_field: < field_d: 123 >\n" - " field_e: OK\n" - " msg_field: < field_d: 12 >\n" - "};"); - - verifyFormat("option (MyProto.options) = <\n" - " field_a: OK\n" - " field_b: \"OK\"\n" - " field_c: 1\n" - " field_d: 12.5\n" - " field_e: OK\n" - ">;"); - - verifyFormat("option (MyProto.options) = <\n" - " field_a: OK,\n" - " field_b: \"OK\",\n" - " field_c: 1,\n" - " field_d: 12.5,\n" - " field_e: OK,\n" - ">;"); - - verifyFormat("option (MyProto.options) = <\n" - " field_a: \"OK\"\n" - " msg_field: { field_b: OK }\n" - " field_g: OK\n" - " field_g: OK\n" - " field_g: OK\n" - ">;"); - - verifyFormat("option (MyProto.options) = <\n" - " field_a: \"OK\"\n" - " msg_field <\n" - " field_b: OK\n" - " field_c: OK\n" - " field_d: OK\n" - " field_e: OK\n" - " field_f: OK\n" - " >\n" - " field_g: OK\n" - ">;"); - - verifyFormat("option (MyProto.options) = <\n" - " field_a: \"OK\"\n" - " msg_field <\n" - " field_b: OK,\n" - " field_c: OK,\n" - " field_d: OK,\n" - " field_e: OK,\n" - " field_f: OK\n" - " >\n" - " field_g: OK\n" - ">;"); - - verifyFormat("option (MyProto.options) = <\n" - " field_a: \"OK\"\n" - " msg_field: <\n" - " field_b: OK\n" - " field_c: OK\n" - " field_d: OK\n" - " field_e: OK\n" - " field_f: OK\n" - " >\n" - " field_g: OK\n" - ">;"); - - verifyFormat("option (MyProto.options) = <\n" - " field_a: \"OK\"\n" - " msg_field: {\n" - " field_b: OK\n" - " field_c: OK\n" - " field_d: OK\n" - " field_e: OK\n" - " field_f: OK\n" - " }\n" - " field_g: OK\n" - ">;"); - - verifyFormat("option (MyProto.options) = <\n" - " field_a: \"OK\"\n" - " msg_field {\n" - " field_b: OK\n" - " field_c: OK\n" - " field_d: OK\n" - " field_e: OK\n" - " field_f: OK\n" - " }\n" - " field_g: OK\n" - ">;"); - - verifyFormat("option (MyProto.options) = {\n" - " field_a: \"OK\"\n" - " msg_field <\n" - " field_b: OK\n" - " field_c: OK\n" - " field_d: OK\n" - " field_e: OK\n" - " field_f: OK\n" - " >\n" - " field_g: OK\n" - "};"); - - verifyFormat("option (MyProto.options) = {\n" - " field_a: \"OK\"\n" - " msg_field: <\n" - " field_b: OK\n" - " field_c: OK\n" - " field_d: OK\n" - " field_e: OK\n" - " field_f: OK\n" - " >\n" - " field_g: OK\n" - "};"); - - verifyFormat("option (MyProto.options) = <\n" - " field_a: \"OK\"\n" - " msg_field {\n" - " field_b: OK\n" - " field_c: OK\n" - " field_d: OK\n" - " msg_field <\n" - " field_A: 1\n" - " field_B: 2\n" - " field_C: 3\n" - " field_D: 4\n" - " field_E: 5\n" - " >\n" - " msg_field < field_A: 1 field_B: 2 field_C: 3 f_D: 4 >\n" - " field_e: OK\n" - " field_f: OK\n" - " }\n" - " field_g: OK\n" - ">;"); - - verifyFormat("option (MyProto.options) = <\n" - " data1 < key1: value1 >\n" - " data2 { key2: value2 }\n" - ">;"); - - verifyFormat("option (MyProto.options) = <\n" - " app_id: 'com.javax.swing.salsa.latino'\n" - " head_id: 1\n" - " data < key: value >\n" - ">;"); - - verifyFormat("option (MyProto.options) = {\n" - " app_id: 'com.javax.swing.salsa.latino'\n" - " head_id: 1\n" - " headheadheadheadheadhead_id: 1\n" - " product_data { product { 1 } }\n" - "};"); -} - -TEST_F(FormatTestProto, FormatsService) { - verifyFormat("service SearchService {\n" - " rpc Search(SearchRequest) returns (SearchResponse) {\n" - " option foo = true;\n" - " }\n" - "};"); -} - -TEST_F(FormatTestProto, ExtendingMessage) { - verifyFormat("extend .foo.Bar {}"); -} - -TEST_F(FormatTestProto, FormatsImports) { - verifyFormat("import \"a.proto\";\n" - "import \"b.proto\";\n" - "// comment\n" - "message A {}"); - - verifyFormat("import public \"a.proto\";\n" - "import \"b.proto\";\n" - "// comment\n" - "message A {}"); - - // Missing semicolons should not confuse clang-format. - verifyFormat("import \"a.proto\"\n" - "import \"b.proto\"\n" - "// comment\n" - "message A {}"); -} - -TEST_F(FormatTestProto, KeepsLongStringLiteralsOnSameLine) { - verifyFormat( - "option (MyProto.options) = {\n" - " foo: {\n" - " text: \"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaasaaaaaaaa\"\n" - " }\n" - "}"); -} - -TEST_F(FormatTestProto, FormatsOptionsExtensions) { - verifyFormat("option (MyProto.options) = {\n" - " msg_field: { field_d: 123 }\n" - " [ext.t/u] { key: value }\n" - " key: value\n" - " [t.u/v] <\n" - " [ext] { key: value }\n" - " >\n" - "};"); -} - -TEST_F(FormatTestProto, SpacesAroundPercents) { - verifyFormat("option (MyProto.options) = {\n" - " key: %lld\n" - " key: 0x%04x\n" - " key: \"%d %d\"\n" - "};"); -} - -TEST_F(FormatTestProto, FormatsRepeatedListInitializersInOptions) { - verifyFormat("option (MyProto.options) = {\n" - " key: item\n" - " keys: [\n" - " 'ala',\n" - " 'bala',\n" - " 'porto',\n" - " 'kala',\n" - " 'too',\n" - " 'long',\n" - " 'long',\n" - " 'long'\n" - " ]\n" - " key: [ item ]\n" - " msg {\n" - " key: item\n" - " keys: [\n" - " 'ala',\n" - " 'bala',\n" - " 'porto',\n" - " 'kala',\n" - " 'too',\n" - " 'long',\n" - " 'long'\n" - " ]\n" - " }\n" - " key: value\n" - "};"); -} - -TEST_F(FormatTestProto, AcceptsOperatorAsKeyInOptions) { - verifyFormat("option (MyProto.options) = {\n" - " bbbbbbbbb: <\n" - " ccccccccccccccccccccccc: <\n" - " operator: 1\n" - " operator: 2\n" - " operator: 3\n" - " operator { key: value }\n" - " >\n" - " >\n" - "};"); -} - -TEST_F(FormatTestProto, BreaksEntriesOfSubmessagesContainingSubmessages) { - FormatStyle Style = getGoogleStyle(FormatStyle::LK_TextProto); - Style.ColumnLimit = 60; - // The column limit allows for the keys submessage to be put on 1 line, but we - // break it since it contains a submessage an another entry. - verifyFormat("option (MyProto.options) = {\n" - " key: valueeeeeeee\n" - " keys: {\n" - " item: 'aaaaaaaaaaaaaaaa'\n" - " sub <>\n" - " }\n" - "}"); - verifyFormat("option (MyProto.options) = {\n" - " key: valueeeeeeee\n" - " keys: {\n" - " item: 'aaaaaaaaaaaaaaaa'\n" - " sub {}\n" - " }\n" - "}"); - verifyFormat("option (MyProto.options) = {\n" - " key: valueeeeeeee\n" - " keys: {\n" - " sub {}\n" - " sub: <>\n" - " sub: []\n" - " }\n" - "}"); - verifyFormat("option (MyProto.options) = {\n" - " key: valueeeeeeee\n" - " keys: {\n" - " item: 'aaaaaaaaaaa'\n" - " sub { msg: 1 }\n" - " }\n" - "}"); - verifyFormat("option (MyProto.options) = {\n" - " key: valueeeeeeee\n" - " keys: {\n" - " item: 'aaaaaaaaaaa'\n" - " sub: { msg: 1 }\n" - " }\n" - "}"); - verifyFormat("option (MyProto.options) = {\n" - " key: valueeeeeeee\n" - " keys: {\n" - " item: 'aaaaaaaaaaa'\n" - " sub < msg: 1 >\n" - " }\n" - "}"); - verifyFormat("option (MyProto.options) = {\n" - " key: valueeeeeeee\n" - " keys: {\n" - " item: 'aaaaaaaaaaa'\n" - " sub: [ msg: 1 ]\n" - " }\n" - "}"); - verifyFormat("option (MyProto.options) = {\n" - " key: valueeeeeeee\n" - " keys: <\n" - " item: 'aaaaaaaaaaa'\n" - " sub: [ 1, 2 ]\n" - " >\n" - "}"); - verifyFormat("option (MyProto.options) = {\n" - " key: valueeeeeeee\n" - " keys: {\n" - " sub {}\n" - " item: 'aaaaaaaaaaaaaaaa'\n" - " }\n" - "}"); - verifyFormat("option (MyProto.options) = {\n" - " key: valueeeeeeee\n" - " keys: {\n" - " sub: []\n" - " item: 'aaaaaaaaaaaaaaaa'\n" - " }\n" - "}"); - verifyFormat("option (MyProto.options) = {\n" - " key: valueeeeeeee\n" - " keys: {\n" - " sub <>\n" - " item: 'aaaaaaaaaaaaaaaa'\n" - " }\n" - "}"); - verifyFormat("option (MyProto.options) = {\n" - " key: valueeeeeeee\n" - " keys: {\n" - " sub { key: value }\n" - " item: 'aaaaaaaaaaaaaaaa'\n" - " }\n" - "}"); - verifyFormat("option (MyProto.options) = {\n" - " key: valueeeeeeee\n" - " keys: {\n" - " sub: [ 1, 2 ]\n" - " item: 'aaaaaaaaaaaaaaaa'\n" - " }\n" - "}"); - verifyFormat("option (MyProto.options) = {\n" - " key: valueeeeeeee\n" - " keys: {\n" - " sub < sub_2: {} >\n" - " item: 'aaaaaaaaaaaaaaaa'\n" - " }\n" - "}"); - verifyFormat("option (MyProto.options) = {\n" - " key: valueeeeeeee\n" - " keys: {\n" - " item: data\n" - " sub: [ 1, 2 ]\n" - " item: 'aaaaaaaaaaaaaaaa'\n" - " }\n" - "}"); - verifyFormat("option (MyProto.options) = {\n" - " key: valueeeeeeee\n" - " keys: {\n" - " item: data\n" - " sub < sub_2: {} >\n" - " item: 'aaaaaaaaaaaaaaaa'\n" - " }\n" - "}"); - verifyFormat("option (MyProto.options) = {\n" - " sub: {\n" - " key: valueeeeeeee\n" - " keys: {\n" - " sub: [ 1, 2 ]\n" - " item: 'aaaaaaaaaaaaaaaa'\n" - " }\n" - " }\n" - "}"); -} - -TEST_F(FormatTestProto, PreventBreaksBetweenKeyAndSubmessages) { - verifyFormat("option (MyProto.options) = {\n" - " submessage: {\n" - " key: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'\n" - " }\n" - "}"); - verifyFormat("option (MyProto.options) = {\n" - " submessage {\n" - " key: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'\n" - " }\n" - "}"); - verifyFormat("option (MyProto.options) = {\n" - " submessage: <\n" - " key: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'\n" - " >\n" - "}"); - verifyFormat("option (MyProto.options) = {\n" - " submessage <\n" - " key: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'\n" - " >\n" - "}"); - verifyFormat("option (MyProto.options) = {\n" - " repeatedd: [\n" - " 'eyaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'\n" - " ]\n" - "}"); -} - - -} // end namespace tooling -} // end namespace clang |
