1*a3a45f30SXin Li // Copyright 2017 The Chromium OS Authors. All rights reserved.
2*a3a45f30SXin Li // Use of this source code is governed by a BSD-style license that can be
3*a3a45f30SXin Li // found in the LICENSE file.
4*a3a45f30SXin Li
5*a3a45f30SXin Li #include "bsdiff/bsdiff_arguments.h"
6*a3a45f30SXin Li
7*a3a45f30SXin Li #include <gtest/gtest.h>
8*a3a45f30SXin Li
9*a3a45f30SXin Li namespace bsdiff {
10*a3a45f30SXin Li
TEST(BsdiffArgumentsTest,ParseCompressorTypeTest)11*a3a45f30SXin Li TEST(BsdiffArgumentsTest, ParseCompressorTypeTest) {
12*a3a45f30SXin Li std::set<CompressorType> types;
13*a3a45f30SXin Li EXPECT_TRUE(BsdiffArguments::ParseCompressorTypes("Brotli", &types));
14*a3a45f30SXin Li EXPECT_EQ(1U, types.size());
15*a3a45f30SXin Li EXPECT_NE(types.end(), types.find(CompressorType::kBrotli));
16*a3a45f30SXin Li
17*a3a45f30SXin Li types.clear();
18*a3a45f30SXin Li
19*a3a45f30SXin Li EXPECT_TRUE(BsdiffArguments::ParseCompressorTypes("bz2", &types));
20*a3a45f30SXin Li EXPECT_EQ(1U, types.size());
21*a3a45f30SXin Li EXPECT_NE(types.end(), types.find(CompressorType::kBZ2));
22*a3a45f30SXin Li
23*a3a45f30SXin Li types.clear();
24*a3a45f30SXin Li
25*a3a45f30SXin Li EXPECT_FALSE(BsdiffArguments::ParseCompressorTypes("invalid", &types));
26*a3a45f30SXin Li }
27*a3a45f30SXin Li
TEST(BsdiffArgumentsTest,ParseMultipleCompressorTypeTest)28*a3a45f30SXin Li TEST(BsdiffArgumentsTest, ParseMultipleCompressorTypeTest) {
29*a3a45f30SXin Li std::set<CompressorType> types;
30*a3a45f30SXin Li EXPECT_TRUE(BsdiffArguments::ParseCompressorTypes("bz2:brotli:nocompression",
31*a3a45f30SXin Li &types));
32*a3a45f30SXin Li EXPECT_EQ(3U, types.size());
33*a3a45f30SXin Li EXPECT_NE(types.end(), types.find(CompressorType::kBrotli));
34*a3a45f30SXin Li EXPECT_NE(types.end(), types.find(CompressorType::kBZ2));
35*a3a45f30SXin Li EXPECT_NE(types.end(), types.find(CompressorType::kNoCompression));
36*a3a45f30SXin Li
37*a3a45f30SXin Li types.clear();
38*a3a45f30SXin Li
39*a3a45f30SXin Li // No space in the type string.
40*a3a45f30SXin Li EXPECT_FALSE(
41*a3a45f30SXin Li BsdiffArguments::ParseCompressorTypes("bz2 : nocompression", &types));
42*a3a45f30SXin Li }
43*a3a45f30SXin Li
TEST(BsdiffArgumentsTest,ParseBsdiffFormatTest)44*a3a45f30SXin Li TEST(BsdiffArgumentsTest, ParseBsdiffFormatTest) {
45*a3a45f30SXin Li BsdiffFormat format;
46*a3a45f30SXin Li EXPECT_TRUE(BsdiffArguments::ParseBsdiffFormat("bsdf2", &format));
47*a3a45f30SXin Li EXPECT_EQ(BsdiffFormat::kBsdf2, format);
48*a3a45f30SXin Li
49*a3a45f30SXin Li EXPECT_TRUE(BsdiffArguments::ParseBsdiffFormat("Legacy", &format));
50*a3a45f30SXin Li EXPECT_EQ(BsdiffFormat::kLegacy, format);
51*a3a45f30SXin Li
52*a3a45f30SXin Li EXPECT_TRUE(BsdiffArguments::ParseBsdiffFormat("bsdiff40", &format));
53*a3a45f30SXin Li EXPECT_EQ(BsdiffFormat::kLegacy, format);
54*a3a45f30SXin Li
55*a3a45f30SXin Li EXPECT_TRUE(BsdiffArguments::ParseBsdiffFormat("endsley", &format));
56*a3a45f30SXin Li EXPECT_EQ(BsdiffFormat::kEndsley, format);
57*a3a45f30SXin Li
58*a3a45f30SXin Li EXPECT_FALSE(BsdiffArguments::ParseBsdiffFormat("Other", &format));
59*a3a45f30SXin Li }
60*a3a45f30SXin Li
TEST(BsdiffArgumentsTest,ParseQualityTest)61*a3a45f30SXin Li TEST(BsdiffArgumentsTest, ParseQualityTest) {
62*a3a45f30SXin Li int quality;
63*a3a45f30SXin Li EXPECT_TRUE(BsdiffArguments::ParseQuality("9", &quality, 0, 11));
64*a3a45f30SXin Li EXPECT_EQ(9, quality);
65*a3a45f30SXin Li
66*a3a45f30SXin Li // Check the out of range quality values.
67*a3a45f30SXin Li EXPECT_FALSE(BsdiffArguments::ParseQuality("30", &quality, 0, 11));
68*a3a45f30SXin Li EXPECT_FALSE(BsdiffArguments::ParseQuality("1234567890", &quality, 0, 1000));
69*a3a45f30SXin Li EXPECT_FALSE(BsdiffArguments::ParseQuality("aabb", &quality, 0, 1000));
70*a3a45f30SXin Li }
71*a3a45f30SXin Li
TEST(BsdiffArgumentsTest,ParseMinLengthTest)72*a3a45f30SXin Li TEST(BsdiffArgumentsTest, ParseMinLengthTest) {
73*a3a45f30SXin Li size_t len;
74*a3a45f30SXin Li EXPECT_TRUE(BsdiffArguments::ParseMinLength("11", &len));
75*a3a45f30SXin Li EXPECT_EQ(11U, len);
76*a3a45f30SXin Li
77*a3a45f30SXin Li // Check the out of range quality values.
78*a3a45f30SXin Li EXPECT_FALSE(BsdiffArguments::ParseMinLength("-1", &len));
79*a3a45f30SXin Li EXPECT_FALSE(BsdiffArguments::ParseMinLength("aabb", &len));
80*a3a45f30SXin Li }
81*a3a45f30SXin Li
TEST(BsdiffArgumentsTest,ArgumentsValidTest)82*a3a45f30SXin Li TEST(BsdiffArgumentsTest, ArgumentsValidTest) {
83*a3a45f30SXin Li // Default arguments using BsdiffFormat::kLegacy and CompressorType::kBZ2
84*a3a45f30SXin Li // should be valid.
85*a3a45f30SXin Li EXPECT_TRUE(BsdiffArguments().IsValid());
86*a3a45f30SXin Li
87*a3a45f30SXin Li // brotli is not supported for BsdiffFormat::kLegacy.
88*a3a45f30SXin Li EXPECT_FALSE(
89*a3a45f30SXin Li BsdiffArguments(BsdiffFormat::kLegacy, {CompressorType::kBrotli}, -1)
90*a3a45f30SXin Li .IsValid());
91*a3a45f30SXin Li
92*a3a45f30SXin Li EXPECT_TRUE(
93*a3a45f30SXin Li BsdiffArguments(BsdiffFormat::kBsdf2, {CompressorType::kBrotli}, 9)
94*a3a45f30SXin Li .IsValid());
95*a3a45f30SXin Li
96*a3a45f30SXin Li // Compression quality out of range for brotli.
97*a3a45f30SXin Li EXPECT_FALSE(
98*a3a45f30SXin Li BsdiffArguments(BsdiffFormat::kBsdf2, {CompressorType::kBrotli}, 20)
99*a3a45f30SXin Li .IsValid());
100*a3a45f30SXin Li }
101*a3a45f30SXin Li
TEST(BsdiffArgumentsTest,ParseArgumentsSmokeTest)102*a3a45f30SXin Li TEST(BsdiffArgumentsTest, ParseArgumentsSmokeTest) {
103*a3a45f30SXin Li std::vector<const char*> args = {"bsdiff", "--format=bsdf2",
104*a3a45f30SXin Li "--type=brotli:bz2", "--brotli_quality=9",
105*a3a45f30SXin Li "--minlen=12"};
106*a3a45f30SXin Li
107*a3a45f30SXin Li BsdiffArguments arguments;
108*a3a45f30SXin Li EXPECT_TRUE(
109*a3a45f30SXin Li arguments.ParseCommandLine(args.size(), const_cast<char**>(args.data())));
110*a3a45f30SXin Li
111*a3a45f30SXin Li EXPECT_EQ(BsdiffFormat::kBsdf2, arguments.format());
112*a3a45f30SXin Li
113*a3a45f30SXin Li std::vector<CompressorType> types = {CompressorType::kBZ2,
114*a3a45f30SXin Li CompressorType::kBrotli};
115*a3a45f30SXin Li EXPECT_EQ(types, arguments.compressor_types());
116*a3a45f30SXin Li
117*a3a45f30SXin Li EXPECT_EQ(9, arguments.brotli_quality());
118*a3a45f30SXin Li EXPECT_EQ(12, arguments.min_length());
119*a3a45f30SXin Li }
120*a3a45f30SXin Li
121*a3a45f30SXin Li } // namespace bsdiff
122