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

Unified Diff: courgette/adjustment_method_unittest.cc

Issue 1629703002: [Courgette] Refactor: Manage AssemblyProgram and EncodedProgram with scoped_ptr. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix courgette_fuzzer in libfuzzer. Created 4 years, 11 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « courgette/BUILD.gn ('k') | courgette/assembly_program.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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
« no previous file with comments | « courgette/BUILD.gn ('k') | courgette/assembly_program.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698