// Copyright 2015 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.
#ifndef _BSDIFF_TEST_UTILS_H_
#define _BSDIFF_TEST_UTILS_H_
#include <gtest/gtest.h>
#include <string>
#include <vector>
#include "bsdiff/logging.h"
#define TEST_AND_RETURN_FALSE(_x) \
do { \
if (!static_cast<bool>(_x)) { \
LOG(ERROR) << #_x " failed."; \
return false; \
} \
} while (0)
namespace test_utils {
class BsdiffTestEnvironment : public ::testing::Environment {
public:
virtual void SetUp();
};
// Reads all the contents of the file |path| into |out|. Returns whether it
// read up to the end of file.
bool ReadFile(const std::string& path, std::vector<uint8_t>* out);
// Overrides the file |path| with the contents passed in |out|. Returns whether
// the operation succeeded.
bool WriteFile(const std::string& path, std::vector<uint8_t> contents);
// Utility class to create and delete a temp file.
class ScopedTempFile {
public:
// Creates a temp file with the passed |pattern|. The pattern should end with
// "XXXXXX", that will be replaced with a random string. The file will be
// removed when this instance is destroyed.
explicit ScopedTempFile(const std::string& pattern);
~ScopedTempFile();
std::string filename() const { return filename_; }
const char* c_str() const { return filename_.c_str(); }
// Releases the temporary file. It will not be deleted when this instance is
// destroyed.
void release() { filename_.clear(); }
private:
std::string filename_;
};
// This struct representes a parsed BSDIFF40 file.
struct BsdiffPatchFile {
static const size_t kHeaderSize = 32;
// Parses a BSDIFF40 file and stores the contents in the local methods.
bool LoadFromFile(const std::string& filename);
// Returns wheter the patch file is valid.
bool IsValid() const;
// The magic string in the header file. Normally "BSDIFF40".
std::string magic;
// The length of the first (ctrl) bzip2 stream. Negative values are invalid.
int64_t ctrl_len = -1;
// The length of the first (diff) bzip2 stream. Negative values are invalid.
int64_t diff_len = -1;
// The length of the first (diff) bzip2 stream. This value is not stored in
// the file, but generated based on the |file_size|.
uint64_t extra_len = 0;
// The length of the new file after applying the patch. Negative values are
// invalid.
int64_t new_file_len = -1;
// The three compressed streams.
std::vector<uint8_t> bz2_ctrl;
std::vector<uint8_t> bz2_diff;
std::vector<uint8_t> bz2_extra;
uint64_t file_size = 0;
};
} // namespace test_utils
#endif // _BSDIFF_TEST_UTILS_H_