// Copyright 2017 The Chromium OS Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "bsdiff/brotli_compressor.h"
#include <gtest/gtest.h>
#include "bsdiff/brotli_decompressor.h"
namespace {
constexpr uint8_t kHelloWorld[] = {
0x48, 0x65, 0x6c, 0x6c, 0x6f, 0x20, 0x57, 0x6f, 0x72, 0x6c, 0x64, 0x0a,
};
} // namespace
namespace bsdiff {
TEST(BrotliCompressorTest, BrotliCompressorSmoke) {
BrotliCompressor brotli_compressor(11);
EXPECT_TRUE(brotli_compressor.Write(kHelloWorld, sizeof(kHelloWorld)));
EXPECT_TRUE(brotli_compressor.Finish());
std::vector<uint8_t> compressed_data = brotli_compressor.GetCompressedData();
EXPECT_GT(compressed_data.size(), static_cast<size_t>(0));
// Run decompressor and check we can get the exact same data as kHelloWorld.
std::vector<uint8_t> decompressed_data(sizeof(kHelloWorld));
BrotliDecompressor brotli_decompressor;
EXPECT_TRUE(brotli_decompressor.SetInputData(compressed_data.data(),
compressed_data.size()));
EXPECT_TRUE(
brotli_decompressor.Read(decompressed_data.data(), sizeof(kHelloWorld)));
EXPECT_TRUE(brotli_decompressor.Close());
EXPECT_EQ(
std::vector<uint8_t>(kHelloWorld, kHelloWorld + sizeof(kHelloWorld)),
decompressed_data);
}
TEST(BrotliCompressorTest, BrotliCompressorEmptyStream) {
uint8_t empty_buffer[] = {};
BrotliCompressor brotli_compressor(11);
EXPECT_TRUE(brotli_compressor.Write(empty_buffer, sizeof(empty_buffer)));
EXPECT_TRUE(brotli_compressor.Finish());
std::vector<uint8_t> compressed_data = brotli_compressor.GetCompressedData();
// Check that we can close the decompressor without errors.
BrotliDecompressor brotli_decompressor;
EXPECT_TRUE(brotli_decompressor.SetInputData(compressed_data.data(),
compressed_data.size()));
EXPECT_TRUE(brotli_decompressor.Close());
}
} // namespace bsdiff