Commit 19868d29 authored by dgarrett@chromium.org's avatar dgarrett@chromium.org

Revert 102428 - Add a backwards compatibility unittest.

This is a resubmit of CL 7915007.

BUG=None
TEST=New Unittest


Review URL: http://codereview.chromium.org/7976035

TBR=dgarrett@chromium.org
Review URL: http://codereview.chromium.org/7972027

git-svn-id: svn://svn.chromium.org/chrome/trunk/src@102434 0039d316-1c4b-4281-b951-d872f2087c98
parent a4c227c8
......@@ -167,4 +167,3 @@ v8.log
/webkit/data/xbm_decoder
/x86-generic_out/
/xcodebuild
courgette.log
# Copyright (c) 2011 The Chromium Authors. All rights reserved.
# Copyright (c) 2009 The Chromium Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
......@@ -92,7 +92,6 @@
'image_info_unittest.cc',
'run_all_unittests.cc',
'streams_unittest.cc',
'versioning_unittest.cc',
'third_party/paged_array_unittest.cc'
],
'dependencies': [
......
// Copyright (c) 2011 The Chromium 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 <string>
#include "base/path_service.h"
#include "base/file_util.h"
#include "base/string_util.h"
#include "courgette/courgette.h"
#include "courgette/streams.h"
#include "testing/gtest/include/gtest/gtest.h"
class VersioningTest : public testing::Test {
public:
void TestApplyingOldPatch(const char* src_file,
const char* patch_file,
const char* expected_file) const;
private:
void SetUp() {
PathService::Get(base::DIR_SOURCE_ROOT, &testdata_dir_);
testdata_dir_ = testdata_dir_.AppendASCII("courgette");
testdata_dir_ = testdata_dir_.AppendASCII("testdata");
}
void TearDown() { }
// Returns contents of |file_name| as uninterprested bytes stored in a string.
std::string FileContents(const char* file_name) const;
FilePath testdata_dir_; // Full path name of testdata directory
};
// Reads a test file into a string.
std::string VersioningTest::FileContents(const char* file_name) const {
FilePath file_path = testdata_dir_;
file_path = file_path.AppendASCII(file_name);
std::string file_contents;
EXPECT_TRUE(file_util::ReadFileToString(file_path, &file_contents));
return file_contents;
}
void VersioningTest::TestApplyingOldPatch(const char* src_file,
const char* patch_file,
const char* expected_file) const {
std::string old_buffer = FileContents(src_file);
std::string new_buffer = FileContents(patch_file);
std::string expected_buffer = FileContents(expected_file);
courgette::SourceStream old_stream;
courgette::SourceStream patch_stream;
old_stream.Init(old_buffer);
patch_stream.Init(new_buffer);
courgette::SinkStream generated_stream;
courgette::Status status =
courgette::ApplyEnsemblePatch(&old_stream,
&patch_stream,
&generated_stream);
EXPECT_EQ(status, courgette::C_OK);
size_t expected_length = expected_buffer.size();
size_t generated_length = generated_stream.Length();
EXPECT_EQ(generated_length, expected_length);
EXPECT_EQ(0, memcmp(generated_stream.Buffer(),
expected_buffer.c_str(),
expected_length));
}
TEST_F(VersioningTest, All) {
TestApplyingOldPatch("setup1.exe", "setup1-setup2.v1.patch", "setup2.exe");
// We also need a way to test that newly generated patches are appropriately
// applicable by older clients... not sure of the best way to do that.
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment