| // 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_ |