Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1)

Side by Side Diff: src/platform/update_engine/bzip_extent_writer_unittest.cc

Issue 551132: AU: Extent writer utility classes (Closed)
Patch Set: fixes for review Created 10 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright (c) 2009 The Chromium OS Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include <sys/stat.h>
6 #include <sys/types.h>
7 #include <unistd.h>
8 #include <algorithm>
9 #include <string>
10 #include <vector>
11 #include <gtest/gtest.h>
12 #include "update_engine/bzip_extent_writer.h"
13 #include "update_engine/test_utils.h"
14 #include "update_engine/utils.h"
15
16 using std::min;
17 using std::string;
18 using std::vector;
19
20 namespace chromeos_update_engine {
21
22 namespace {
23 const char kPathTemplate[] = "./BzipExtentWriterTest-file.XXXXXX";
24 const uint32 kBlockSize = 4096;
25 }
26
27 class BzipExtentWriterTest : public ::testing::Test {
28 protected:
29 virtual void SetUp() {
30 memcpy(path_, kPathTemplate, sizeof(kPathTemplate));
31 fd_ = mkstemp(path_);
32 ASSERT_GE(fd_, 0);
33 }
34 virtual void TearDown() {
35 close(fd_);
36 LOG(INFO) << "unlink: " << path_;
37 unlink(path_);
38 }
39 int fd() { return fd_; }
40 const char* path() { return path_; }
41 void WriteAlignedExtents(size_t chunk_size, size_t first_chunk_size);
42 void TestZeroPad(bool aligned_size);
43 private:
44 int fd_;
45 char path_[sizeof(kPathTemplate)];
46 };
47
48 TEST_F(BzipExtentWriterTest, SimpleTest) {
49 vector<Extent> extents;
50 Extent extent;
51 extent.set_start_block(0);
52 extent.set_num_blocks(1);
53 extents.push_back(extent);
54
55 // 'echo test | bzip2 | hexdump' yields:
56 const char test_uncompressed[] = "test\n";
57 unsigned char test[] = {
58 0x42, 0x5a, 0x68, 0x39, 0x31, 0x41, 0x59, 0x26, 0x53, 0x59, 0xcc, 0xc3,
59 0x71, 0xd4, 0x00, 0x00, 0x02, 0x41, 0x80, 0x00, 0x10, 0x02, 0x00, 0x0c,
60 0x00, 0x20, 0x00, 0x21, 0x9a, 0x68, 0x33, 0x4d, 0x19, 0x97, 0x8b, 0xb9,
61 0x22, 0x9c, 0x28, 0x48, 0x66, 0x61, 0xb8, 0xea, 0x00,
62 };
63
64 DirectExtentWriter direct_writer;
65 BzipExtentWriter bzip_writer(&direct_writer);
66 EXPECT_TRUE(bzip_writer.Init(fd(), extents, kBlockSize));
67 EXPECT_TRUE(bzip_writer.Write(test, sizeof(test)));
68 EXPECT_TRUE(bzip_writer.End());
69
70 char buf[sizeof(test_uncompressed) + 1];
71 memset(buf, 0, sizeof(buf));
72 ssize_t rc = pread(fd(), buf, sizeof(buf) - 1, 0);
Daniel Erat 2010/02/03 02:12:24 rename 'rc' to something like 'bytes_read'
adlr 2010/02/04 22:25:37 Done.
73 EXPECT_EQ(strlen(test_uncompressed), rc);
74 EXPECT_EQ(string(buf), string(test_uncompressed));
75 }
76
77 TEST_F(BzipExtentWriterTest, ChunkedTest) {
78 const vector<char>::size_type kDecompressedLength = 2048 * 1024; // 2 MiB
79 const string kDecompressedPath = "BzipExtentWriterTest-file-decompressed";
80 const string kCompressedPath = "BzipExtentWriterTest-file-compressed";
81 const size_t kChunkSize = 3;
82
83 vector<Extent> extents;
84 Extent extent;
85 extent.set_start_block(0);
86 extent.set_num_blocks(kDecompressedLength / kBlockSize + 1);
87 extents.push_back(extent);
88
89 vector<char> decompressed_data(kDecompressedLength);
90 FillWithData(&decompressed_data);
91
92 EXPECT_TRUE(WriteFileVector(kDecompressedPath, decompressed_data));
93
94 EXPECT_EQ(0, System(string("cat ") + kDecompressedPath + "|bzip2>" +
95 kCompressedPath));
96
97 vector<char> compressed_data;
98 EXPECT_TRUE(utils::ReadFile(kCompressedPath, &compressed_data));
99
100 DirectExtentWriter direct_writer;
101 BzipExtentWriter bzip_writer(&direct_writer);
102 EXPECT_TRUE(bzip_writer.Init(fd(), extents, kBlockSize));
103
104 for (vector<char>::size_type i = 0; i < compressed_data.size();
105 i += kChunkSize) {
106 size_t this_chunk_size = min(kChunkSize, compressed_data.size() - i);
107 EXPECT_TRUE(bzip_writer.Write(&compressed_data[i], this_chunk_size));
108 }
109 EXPECT_TRUE(bzip_writer.End());
110
111 vector<char> output(kDecompressedLength + 1);
112 ssize_t rc = pread(fd(), &output[0], output.size(), 0);
113 EXPECT_EQ(kDecompressedLength, rc);
114 output.resize(kDecompressedLength);
115 ExpectVectorsEq(decompressed_data, output);
116
117 unlink(kDecompressedPath.c_str());
118 unlink(kCompressedPath.c_str());
119 }
120
121 } // namespace chromeos_update_engine
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698