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

Unified Diff: chrome/browser/ui/webui/print_preview_handler_unittest.cc

Issue 8351048: Print Preview: Making margin selection sticky (part 2/2) (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Adding test for verifying that sticky settings are stored. Created 9 years, 1 month 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 | « chrome/browser/ui/webui/print_preview_handler.cc ('k') | chrome/browser/ui/webui/print_preview_ui.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/ui/webui/print_preview_handler_unittest.cc
diff --git a/chrome/browser/ui/webui/print_preview_handler_unittest.cc b/chrome/browser/ui/webui/print_preview_handler_unittest.cc
new file mode 100644
index 0000000000000000000000000000000000000000..c556703bb2e19857073cbb8aa629b3df34a10d67
--- /dev/null
+++ b/chrome/browser/ui/webui/print_preview_handler_unittest.cc
@@ -0,0 +1,100 @@
+// 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 "base/command_line.h"
+#include "base/json/json_writer.h"
+#include "base/values.h"
+#include "chrome/browser/browser_process.h"
+#include "chrome/browser/printing/background_printing_manager.h"
+#include "chrome/browser/printing/print_preview_tab_controller.h"
+#include "chrome/browser/ui/browser_list.h"
+#include "chrome/browser/ui/tab_contents/tab_contents_wrapper.h"
+#include "chrome/browser/ui/webui/print_preview_handler.h"
+#include "chrome/browser/ui/webui/print_preview_ui.h"
+#include "chrome/common/chrome_switches.h"
+#include "chrome/test/base/browser_with_test_window_test.h"
+#include "printing/page_size_margins.h"
+#include "printing/print_job_constants.h"
+
+typedef BrowserWithTestWindowTest PrintPreviewHandlerTest;
+
+// When users hit print in the print preview tab, the print preview tab hides
+// and the focus should return to the initiator tab.
+TEST_F(PrintPreviewHandlerTest, HandlePrintTest) {
kmadhusu 2011/11/11 23:39:40 Your test case is fine. But you can add more infor
dpapad 2011/11/14 16:31:55 Done.
+#if !defined(GOOGLE_CHROME_BUILD) || defined(OS_CHROMEOS)
+ CommandLine::ForCurrentProcess()->AppendSwitch(switches::kEnablePrintPreview);
+#endif
+ ASSERT_TRUE(browser());
+ BrowserList::SetLastActive(browser());
+ ASSERT_TRUE(BrowserList::GetLastActive());
+
+ browser()->NewTab();
+ EXPECT_EQ(1, browser()->tab_count());
+ TabContentsWrapper* initiator_tab =
+ browser()->GetSelectedTabContentsWrapper();
+ ASSERT_TRUE(initiator_tab);
+
+ scoped_refptr<printing::PrintPreviewTabController>
+ controller(new printing::PrintPreviewTabController());
+ ASSERT_TRUE(controller.get());
+
+ TabContentsWrapper* preview_tab =
+ controller->GetOrCreatePreviewTab(initiator_tab);
+ ASSERT_TRUE(preview_tab);
+ EXPECT_EQ(2, browser()->tab_count());
+
+ PrintPreviewUI* preview_ui =
+ static_cast<PrintPreviewUI*>(preview_tab->web_ui());
+ ASSERT_TRUE(preview_ui);
+
+ // Set the minimal dummy settings to make the HandlePrint() code happy.
+ DictionaryValue settings;
+ settings.SetBoolean(printing::kSettingPreviewModifiable, true);
+ settings.SetInteger(printing::kSettingColor, printing::COLOR);
+ settings.SetBoolean(printing::kSettingPrintToPDF, false);
+ settings.SetInteger(printing::kSettingMarginsType, printing::CUSTOM_MARGINS);
+
+ // Creating custom margins dictionary and nesting it in |settings|.
+ std::string custom_margins_root(printing::kSettingMarginsCustom);
+ custom_margins_root.append(".");
+ std::stringstream ss;
kmadhusu 2011/11/11 23:39:40 Any special reason to use the stringstream? You c
dpapad 2011/11/14 16:31:55 Done. I was following the instructions on the top
+ ss << custom_margins_root << printing::kSettingMarginTop;
+ settings.SetDouble(ss.str(), 25.5);
Lei Zhang 2011/11/11 22:56:30 make the values constants?
dpapad 2011/11/14 16:31:55 Done.
+ ss.str(std::string());
+ ss << custom_margins_root << printing::kSettingMarginRight;
+ settings.SetDouble(ss.str(), 26.5);
+ ss.str(std::string());
+ ss << custom_margins_root << printing::kSettingMarginBottom;
+ settings.SetDouble(ss.str(), 27.5);
+ ss.str(std::string());
+ ss << custom_margins_root << printing::kSettingMarginLeft;
+ settings.SetDouble(ss.str(), 28.5);
+
+ // Put |settings| in to |args| as a JSON string.
+ std::string json_string;
+ base::JSONWriter::Write(&settings, false, &json_string);
+ ListValue args;
+ args.Append(new base::StringValue(json_string)); // |args| takes ownership.
Lei Zhang 2011/11/11 22:56:30 nit: 2 spaces
dpapad 2011/11/14 16:31:55 Done.
+ preview_ui->handler_->HandlePrint(&args);
+ EXPECT_EQ(1, browser()->tab_count());
+
+ // Checking that sticky settings were saved correctly.
+ EXPECT_EQ(PrintPreviewHandler::last_used_color_model_, printing::COLOR);
+ EXPECT_EQ(PrintPreviewHandler::last_used_margins_type_,
+ printing::CUSTOM_MARGINS);
+ EXPECT_EQ(PrintPreviewHandler::last_used_page_size_margins_->margin_top,
+ 25.5);
+ EXPECT_EQ(PrintPreviewHandler::last_used_page_size_margins_->margin_right,
+ 26.5);
+ EXPECT_EQ(PrintPreviewHandler::last_used_page_size_margins_->margin_bottom,
+ 27.5);
+ EXPECT_EQ(PrintPreviewHandler::last_used_page_size_margins_->margin_left,
+ 28.5);
+
+ printing::BackgroundPrintingManager* bg_printing_manager =
Lei Zhang 2011/11/11 22:56:30 Might want a comment to explain why this is here a
dpapad 2011/11/14 16:31:55 Done.
+ g_browser_process->background_printing_manager();
+ ASSERT_TRUE(bg_printing_manager->HasPrintPreviewTab(preview_tab));
+
+ delete preview_tab;
+}
« no previous file with comments | « chrome/browser/ui/webui/print_preview_handler.cc ('k') | chrome/browser/ui/webui/print_preview_ui.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698