| Index: courgette/adjustment_method_unittest.cc
|
| diff --git a/courgette/adjustment_method_unittest.cc b/courgette/adjustment_method_unittest.cc
|
| index 5b213dc4d95805f7373b7b6aecf2ba0f7ef6fc8b..e25a8e7271f2eeeb8f7a52914912121e4ea02256 100644
|
| --- a/courgette/adjustment_method_unittest.cc
|
| +++ b/courgette/adjustment_method_unittest.cc
|
| @@ -3,11 +3,13 @@
|
| // found in the LICENSE file.
|
|
|
| #include <string>
|
| +#include <utility>
|
|
|
| +#include "base/memory/scoped_ptr.h"
|
| #include "base/strings/string_util.h"
|
| -
|
| #include "courgette/assembly_program.h"
|
| #include "courgette/courgette.h"
|
| +#include "courgette/encoded_program.h"
|
| #include "courgette/streams.h"
|
|
|
| #include "testing/gtest/include/gtest/gtest.h"
|
| @@ -23,11 +25,11 @@ class AdjustmentMethodTest : public testing::Test {
|
| void TearDown() {
|
| }
|
|
|
| - // Returns one of two similar a simple programs. They differ only in the
|
| - // label assignment, so that it is possible to make them look identical.
|
| - courgette::AssemblyProgram* MakeProgram(int kind) const {
|
| - courgette::AssemblyProgram* prog =
|
| - new courgette::AssemblyProgram(courgette::EXE_WIN_32_X86);
|
| + // Returns one of two similar simple programs. These differ only in Label
|
| + // assignment, so it is possible to make them look identical.
|
| + scoped_ptr<courgette::AssemblyProgram> MakeProgram(int kind) const {
|
| + scoped_ptr<courgette::AssemblyProgram> prog(
|
| + new courgette::AssemblyProgram(courgette::EXE_WIN_32_X86));
|
| prog->set_image_base(0x00400000);
|
|
|
| courgette::Label* labelA = prog->FindOrMakeAbs32Label(0x00410000);
|
| @@ -52,24 +54,29 @@ class AdjustmentMethodTest : public testing::Test {
|
| return prog;
|
| }
|
|
|
| - courgette::AssemblyProgram* MakeProgramA() const { return MakeProgram(0); }
|
| - courgette::AssemblyProgram* MakeProgramB() const { return MakeProgram(1); }
|
| + scoped_ptr<courgette::AssemblyProgram> MakeProgramA() const {
|
| + return MakeProgram(0);
|
| + }
|
| + scoped_ptr<courgette::AssemblyProgram> MakeProgramB() const {
|
| + return MakeProgram(1);
|
| + }
|
|
|
| // Returns a string that is the serialized version of |program|.
|
| // Deletes |program|.
|
| - std::string Serialize(courgette::AssemblyProgram *program) const {
|
| - courgette::EncodedProgram* encoded = NULL;
|
| + std::string Serialize(scoped_ptr<courgette::AssemblyProgram> program) const {
|
| + scoped_ptr<courgette::EncodedProgram> encoded;
|
|
|
| - const courgette::Status encode_status = Encode(program, &encoded);
|
| + const courgette::Status encode_status = Encode(*program, &encoded);
|
| EXPECT_EQ(courgette::C_OK, encode_status);
|
|
|
| - DeleteAssemblyProgram(program);
|
| + program.reset();
|
|
|
| courgette::SinkStreamSet sinks;
|
| - const courgette::Status write_status = WriteEncodedProgram(encoded, &sinks);
|
| + const courgette::Status write_status =
|
| + WriteEncodedProgram(encoded.get(), &sinks);
|
| EXPECT_EQ(courgette::C_OK, write_status);
|
|
|
| - DeleteEncodedProgram(encoded);
|
| + encoded.reset();
|
|
|
| courgette::SinkStream sink;
|
| bool can_collect = sinks.CopyTo(&sink);
|
| @@ -82,20 +89,20 @@ class AdjustmentMethodTest : public testing::Test {
|
|
|
|
|
| void AdjustmentMethodTest::Test1() const {
|
| - courgette::AssemblyProgram* prog1 = MakeProgramA();
|
| - courgette::AssemblyProgram* prog2 = MakeProgramB();
|
| - std::string s1 = Serialize(prog1);
|
| - std::string s2 = Serialize(prog2);
|
| + scoped_ptr<courgette::AssemblyProgram> prog1 = MakeProgramA();
|
| + scoped_ptr<courgette::AssemblyProgram> prog2 = MakeProgramB();
|
| + std::string s1 = Serialize(std::move(prog1));
|
| + std::string s2 = Serialize(std::move(prog2));
|
|
|
| // Don't use EXPECT_EQ because strings are unprintable.
|
| EXPECT_FALSE(s1 == s2); // Unadjusted A and B differ.
|
|
|
| - courgette::AssemblyProgram* prog5 = MakeProgramA();
|
| - courgette::AssemblyProgram* prog6 = MakeProgramB();
|
| - courgette::Status can_adjust = Adjust(*prog5, prog6);
|
| + scoped_ptr<courgette::AssemblyProgram> prog5 = MakeProgramA();
|
| + scoped_ptr<courgette::AssemblyProgram> prog6 = MakeProgramB();
|
| + courgette::Status can_adjust = Adjust(*prog5, prog6.get());
|
| EXPECT_EQ(courgette::C_OK, can_adjust);
|
| - std::string s5 = Serialize(prog5);
|
| - std::string s6 = Serialize(prog6);
|
| + std::string s5 = Serialize(std::move(prog5));
|
| + std::string s6 = Serialize(std::move(prog6));
|
|
|
| EXPECT_TRUE(s1 == s5); // Adjustment did not change A (prog5)
|
| EXPECT_TRUE(s5 == s6); // Adjustment did change B into A
|
|
|