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

Unified Diff: tools/gn/ninja_action_target_writer_unittest.cc

Issue 440333002: Support more configurability in GN toolchains (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: unsigned check Created 6 years, 4 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 | « tools/gn/ninja_action_target_writer.cc ('k') | tools/gn/ninja_binary_target_writer.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tools/gn/ninja_action_target_writer_unittest.cc
diff --git a/tools/gn/ninja_action_target_writer_unittest.cc b/tools/gn/ninja_action_target_writer_unittest.cc
index b2b7f7f43d8a4979a1d527eb74f1340ab50d0ad6..b0161d665037dec0b17112fdc656f2c2e624b7f4 100644
--- a/tools/gn/ninja_action_target_writer_unittest.cc
+++ b/tools/gn/ninja_action_target_writer_unittest.cc
@@ -8,18 +8,24 @@
#include "testing/gtest/include/gtest/gtest.h"
#include "tools/gn/ninja_action_target_writer.h"
#include "tools/gn/substitution_list.h"
+#include "tools/gn/target.h"
#include "tools/gn/test_with_scope.h"
TEST(NinjaActionTargetWriter, WriteOutputFilesForBuildLine) {
TestWithScope setup;
setup.build_settings()->SetBuildDir(SourceDir("//out/Debug/"));
+
Target target(setup.settings(), Label(SourceDir("//foo/"), "bar"));
+ target.set_output_type(Target::ACTION_FOREACH);
target.action_values().outputs() = SubstitutionList::MakeForTest(
"//out/Debug/gen/a b{{source_name_part}}.h",
"//out/Debug/gen/{{source_name_part}}.cc");
+ target.SetToolchain(setup.toolchain());
+ target.OnResolved();
+
std::ostringstream out;
- NinjaActionTargetWriter writer(&target, setup.toolchain(), out);
+ NinjaActionTargetWriter writer(&target, out);
SourceFile source("//foo/bar.in");
std::vector<OutputFile> output_files;
@@ -41,12 +47,15 @@ TEST(NinjaActionTargetWriter, ActionNoSources) {
target.action_values().outputs() =
SubstitutionList::MakeForTest("//out/Debug/foo.out");
+ target.SetToolchain(setup.toolchain());
+ target.OnResolved();
+
setup.settings()->set_target_os(Settings::LINUX);
setup.build_settings()->set_python_path(base::FilePath(FILE_PATH_LITERAL(
"/usr/bin/python")));
std::ostringstream out;
- NinjaActionTargetWriter writer(&target, setup.toolchain(), out);
+ NinjaActionTargetWriter writer(&target, out);
writer.Run();
const char expected[] =
@@ -79,6 +88,9 @@ TEST(NinjaActionTargetWriter, ActionWithSources) {
target.action_values().outputs() =
SubstitutionList::MakeForTest("//out/Debug/foo.out");
+ target.SetToolchain(setup.toolchain());
+ target.OnResolved();
+
// Posix.
{
setup.settings()->set_target_os(Settings::LINUX);
@@ -86,7 +98,7 @@ TEST(NinjaActionTargetWriter, ActionWithSources) {
"/usr/bin/python")));
std::ostringstream out;
- NinjaActionTargetWriter writer(&target, setup.toolchain(), out);
+ NinjaActionTargetWriter writer(&target, out);
writer.Run();
const char expected_linux[] =
@@ -112,7 +124,7 @@ TEST(NinjaActionTargetWriter, ActionWithSources) {
setup.settings()->set_target_os(Settings::WIN);
std::ostringstream out;
- NinjaActionTargetWriter writer(&target, setup.toolchain(), out);
+ NinjaActionTargetWriter writer(&target, out);
writer.Run();
const char expected_win[] =
@@ -142,8 +154,13 @@ TEST(NinjaActionTargetWriter, ForEach) {
// binaries).
Target dep(setup.settings(), Label(SourceDir("//foo/"), "dep"));
dep.set_output_type(Target::ACTION);
+ dep.SetToolchain(setup.toolchain());
+ dep.OnResolved();
+
Target datadep(setup.settings(), Label(SourceDir("//foo/"), "datadep"));
datadep.set_output_type(Target::ACTION);
+ datadep.SetToolchain(setup.toolchain());
+ datadep.OnResolved();
Target target(setup.settings(), Label(SourceDir("//foo/"), "bar"));
target.set_output_type(Target::ACTION_FOREACH);
@@ -164,6 +181,9 @@ TEST(NinjaActionTargetWriter, ForEach) {
target.inputs().push_back(SourceFile("//foo/included.txt"));
+ target.SetToolchain(setup.toolchain());
+ target.OnResolved();
+
// Posix.
{
setup.settings()->set_target_os(Settings::LINUX);
@@ -171,7 +191,7 @@ TEST(NinjaActionTargetWriter, ForEach) {
"/usr/bin/python")));
std::ostringstream out;
- NinjaActionTargetWriter writer(&target, setup.toolchain(), out);
+ NinjaActionTargetWriter writer(&target, out);
writer.Run();
const char expected_linux[] =
@@ -196,7 +216,7 @@ TEST(NinjaActionTargetWriter, ForEach) {
" source_name_part = input2\n"
"\n"
"build obj/foo/bar.stamp: "
- "stamp input1.out input2.out obj/foo/datadep.stamp\n";
+ "stamp input1.out input2.out || obj/foo/datadep.stamp\n";
std::string out_str = out.str();
#if defined(OS_WIN)
@@ -212,7 +232,7 @@ TEST(NinjaActionTargetWriter, ForEach) {
setup.settings()->set_target_os(Settings::WIN);
std::ostringstream out;
- NinjaActionTargetWriter writer(&target, setup.toolchain(), out);
+ NinjaActionTargetWriter writer(&target, out);
writer.Run();
const char expected_win[] =
@@ -241,7 +261,7 @@ TEST(NinjaActionTargetWriter, ForEach) {
" source_name_part = input2\n"
"\n"
"build obj/foo/bar.stamp: "
- "stamp input1.out input2.out obj/foo/datadep.stamp\n";
+ "stamp input1.out input2.out || obj/foo/datadep.stamp\n";
EXPECT_EQ(expected_win, out.str());
}
}
@@ -257,6 +277,9 @@ TEST(NinjaActionTargetWriter, ForEachWithDepfile) {
target.action_values().set_script(SourceFile("//foo/script.py"));
+ target.SetToolchain(setup.toolchain());
+ target.OnResolved();
+
SubstitutionPattern depfile;
Err err;
ASSERT_TRUE(
@@ -279,7 +302,7 @@ TEST(NinjaActionTargetWriter, ForEachWithDepfile) {
"/usr/bin/python")));
std::ostringstream out;
- NinjaActionTargetWriter writer(&target, setup.toolchain(), out);
+ NinjaActionTargetWriter writer(&target, out);
writer.Run();
const char expected_linux[] =
@@ -315,7 +338,7 @@ TEST(NinjaActionTargetWriter, ForEachWithDepfile) {
setup.settings()->set_target_os(Settings::WIN);
std::ostringstream out;
- NinjaActionTargetWriter writer(&target, setup.toolchain(), out);
+ NinjaActionTargetWriter writer(&target, out);
writer.Run();
const char expected_win[] =
« no previous file with comments | « tools/gn/ninja_action_target_writer.cc ('k') | tools/gn/ninja_binary_target_writer.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698