From: Yedidya Feldblum Date: Sat, 20 May 2017 20:32:49 +0000 (-0700) Subject: Refactor folly/gen/test/StringTest.cpp X-Git-Tag: v2017.05.22.00^0 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=b3e1ea389e31e7c12d6ec38ed6c47ef4c1d1e70e;p=folly.git Refactor folly/gen/test/StringTest.cpp Summary: [Folly] Refactor `folly/gen/test/StringTest.cpp`. Prefer to compare whole values once per test case, rather than sequentially comparing each part in turn. Reviewed By: andrewjcg Differential Revision: D5101467 fbshipit-source-id: 3d19d32bc6a5ecc5863bea76c4292935c775fe75 --- diff --git a/folly/gen/test/StringTest.cpp b/folly/gen/test/StringTest.cpp index 42b166e9..b6b8713d 100644 --- a/folly/gen/test/StringTest.cpp +++ b/folly/gen/test/StringTest.cpp @@ -32,109 +32,117 @@ using std::tuple; using std::unique_ptr; using std::vector; +using vec = vector; + +static auto collect = eachTo() | as(); + TEST(StringGen, EmptySplit) { - auto collect = eachTo() | as(); { - auto pieces = split("", ',') | collect; - EXPECT_EQ(0, pieces.size()); + auto input = ""; + auto expected = vec{}; + EXPECT_EQ(expected, split("", ',') | collect); } // The last delimiter is eaten, just like std::getline { - auto pieces = split(",", ',') | collect; - EXPECT_EQ(1, pieces.size()); - EXPECT_EQ("", pieces[0]); + auto input = ","; + auto expected = vec{""}; + EXPECT_EQ(expected, split(input, ',') | collect); } { - auto pieces = split(",,", ',') | collect; - EXPECT_EQ(2, pieces.size()); - EXPECT_EQ("", pieces[0]); - EXPECT_EQ("", pieces[1]); + auto input = ",,"; + auto expected = vec{"", ""}; + EXPECT_EQ(expected, split(input, ',') | collect); } { - auto pieces = split(",,", ',') | take(1) | collect; - EXPECT_EQ(1, pieces.size()); - EXPECT_EQ("", pieces[0]); + auto input = ",,"; + auto expected = vec{""}; + EXPECT_EQ(expected, split(input, ',') | take(1) | collect); } } TEST(StringGen, Split) { - auto collect = eachTo() | as(); { - auto pieces = split("hello,, world, goodbye, meow", ',') | collect; - EXPECT_EQ(5, pieces.size()); - EXPECT_EQ("hello", pieces[0]); - EXPECT_EQ("", pieces[1]); - EXPECT_EQ(" world", pieces[2]); - EXPECT_EQ(" goodbye", pieces[3]); - EXPECT_EQ(" meow", pieces[4]); + auto input = "hello,, world, goodbye, meow"; + auto expected = vec{"hello", "", " world", " goodbye", " meow"}; + EXPECT_EQ(expected, split(input, ',') | collect); } { - auto pieces = split("hello,, world, goodbye, meow", ',') - | take(3) | collect; - EXPECT_EQ(3, pieces.size()); - EXPECT_EQ("hello", pieces[0]); - EXPECT_EQ("", pieces[1]); - EXPECT_EQ(" world", pieces[2]); + auto input = "hello,, world, goodbye, meow"; + auto expected = vec{"hello", "", " world"}; + EXPECT_EQ(expected, split(input, ',') | take(3) | collect); } { - auto pieces = split("hello,, world, goodbye, meow", ",") - | take(5) | collect; - EXPECT_EQ(5, pieces.size()); - EXPECT_EQ("hello", pieces[0]); - EXPECT_EQ("", pieces[1]); - EXPECT_EQ(" world", pieces[2]); + auto input = "hello,, world, goodbye, meow"; + auto expected = vec{"hello", "", " world", " goodbye", " meow"}; + EXPECT_EQ(expected, split(input, ",") | take(5) | collect); } { - auto pieces = split("hello,, world, goodbye, meow", ", ") - | collect; - EXPECT_EQ(4, pieces.size()); - EXPECT_EQ("hello,", pieces[0]); - EXPECT_EQ("world", pieces[1]); - EXPECT_EQ("goodbye", pieces[2]); - EXPECT_EQ("meow", pieces[3]); + auto input = "hello,, world, goodbye, meow"; + auto expected = vec{"hello,", "world", "goodbye", "meow"}; + EXPECT_EQ(expected, split(input, ", ") | collect); } } TEST(StringGen, SplitByNewLine) { - auto collect = eachTo() | as(); { - auto pieces = lines("hello\n\n world\r\n goodbye\r me\n\row") | collect; - EXPECT_EQ(7, pieces.size()); - EXPECT_EQ("hello", pieces[0]); - EXPECT_EQ("", pieces[1]); - EXPECT_EQ(" world", pieces[2]); - EXPECT_EQ(" goodbye", pieces[3]); - EXPECT_EQ(" me", pieces[4]); - EXPECT_EQ("", pieces[5]); - EXPECT_EQ("ow", pieces[6]); + auto input = "hello\n\n world\r\n goodbye\r me\n\row"; + auto expected = vec{"hello", "", " world", " goodbye", " me", "", "ow"}; + EXPECT_EQ(expected, lines(input) | collect); } } TEST(StringGen, EmptyResplit) { - auto collect = eachTo() | as(); { - auto pieces = from({""}) | resplit(',') | collect; - EXPECT_EQ(0, pieces.size()); + auto input = vec{""}; + auto expected = vec{}; + EXPECT_EQ(expected, from(input) | resplit(',') | collect); } // The last delimiter is eaten, just like std::getline { - auto pieces = from({","}) | resplit(',') | collect; - EXPECT_EQ(1, pieces.size()); - EXPECT_EQ("", pieces[0]); + auto input = vec{","}; + auto expected = vec{""}; + EXPECT_EQ(expected, from(input) | resplit(',') | collect); + } + + { + auto input = vec{",,"}; + auto expected = vec{"", ""}; + EXPECT_EQ(expected, from(input) | resplit(',') | collect); + } +} + +TEST(StringGen, Resplit) { + { + auto input = vec{"hello,, world, goodbye, meow"}; + auto expected = vec{"hello", "", " world", " goodbye", " meow"}; + EXPECT_EQ(expected, from(input) | resplit(',') | collect); + } + + { + auto input = vec{"hel", "lo,", ", world", ", goodbye, m", "eow"}; + auto expected = vec{"hello", "", " world", " goodbye", " meow"}; + EXPECT_EQ(expected, from(input) | resplit(',') | collect); + } +} + +TEST(StringGen, ResplitKeepDelimiter) { + { + auto input = vec{"hello,, world, goodbye, meow"}; + auto expected = vec{"hello,", ",", " world,", " goodbye,", " meow"}; + EXPECT_EQ(expected, from(input) | resplit(',', true) | collect); } { - auto pieces = from({",,"}) | resplit(',') | collect; - EXPECT_EQ(2, pieces.size()); - EXPECT_EQ("", pieces[0]); - EXPECT_EQ("", pieces[1]); + auto input = vec{"hel", "lo,", ", world", ", goodbye, m", "eow"}; + auto expected = vec{"hello,", ",", " world,", " goodbye,", " meow"}; + EXPECT_EQ(expected, from(input) | resplit(',', true) | collect); } } @@ -236,54 +244,6 @@ TEST(StringGen, EachToPair) { } } -TEST(StringGen, Resplit) { - auto collect = eachTo() | as(); - { - auto pieces = from({"hello,, world, goodbye, meow"}) | - resplit(',') | collect; - EXPECT_EQ(5, pieces.size()); - EXPECT_EQ("hello", pieces[0]); - EXPECT_EQ("", pieces[1]); - EXPECT_EQ(" world", pieces[2]); - EXPECT_EQ(" goodbye", pieces[3]); - EXPECT_EQ(" meow", pieces[4]); - } - { - auto pieces = from({"hel", "lo,", ", world", ", goodbye, m", "eow"}) | - resplit(',') | collect; - EXPECT_EQ(5, pieces.size()); - EXPECT_EQ("hello", pieces[0]); - EXPECT_EQ("", pieces[1]); - EXPECT_EQ(" world", pieces[2]); - EXPECT_EQ(" goodbye", pieces[3]); - EXPECT_EQ(" meow", pieces[4]); - } -} - -TEST(StringGen, ResplitKeepDelimiter) { - auto collect = eachTo() | as(); - { - auto pieces = - from({"hello,, world, goodbye, meow"}) | resplit(',', true) | collect; - ASSERT_EQ(5, pieces.size()); - EXPECT_EQ("hello,", pieces[0]); - EXPECT_EQ(",", pieces[1]); - EXPECT_EQ(" world,", pieces[2]); - EXPECT_EQ(" goodbye,", pieces[3]); - EXPECT_EQ(" meow", pieces[4]); - } - { - auto pieces = from({"hel", "lo,", ", world", ", goodbye, m", "eow"}) | - resplit(',', true) | collect; - ASSERT_EQ(5, pieces.size()); - EXPECT_EQ("hello,", pieces[0]); - EXPECT_EQ(",", pieces[1]); - EXPECT_EQ(" world,", pieces[2]); - EXPECT_EQ(" goodbye,", pieces[3]); - EXPECT_EQ(" meow", pieces[4]); - } -} - void checkResplitMaxLength(vector ins, char delim, uint64_t maxLength,