summaryrefslogtreecommitdiffstats
path: root/printing/page_overlays_unittest.cc
diff options
context:
space:
mode:
authorsverrir@google.com <sverrir@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2009-07-07 21:31:39 +0000
committersverrir@google.com <sverrir@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2009-07-07 21:31:39 +0000
commit8ff1d42631e79e842669dc3051d91ed7db80f1dc (patch)
tree55c1987549e982bfbf60a33fad3b60b5113d7864 /printing/page_overlays_unittest.cc
parent395f9295b3e370746846dbe6073a0d43ab7e4af5 (diff)
downloadchromium_src-8ff1d42631e79e842669dc3051d91ed7db80f1dc.zip
chromium_src-8ff1d42631e79e842669dc3051d91ed7db80f1dc.tar.gz
chromium_src-8ff1d42631e79e842669dc3051d91ed7db80f1dc.tar.bz2
Move printing related stuff to the root printing project from the browser project. This simplifies further refactoring and eases understanding of the printing part of Chrome.
Also renamed win_printing_context to printing_context_win (correct naming convention) and added stub implementations for _linux and mac. Now all but one file is compiling on all platforms. TEST=none (no functional change). BUG=none Review URL: http://codereview.chromium.org/149212 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@20086 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'printing/page_overlays_unittest.cc')
-rw-r--r--printing/page_overlays_unittest.cc92
1 files changed, 92 insertions, 0 deletions
diff --git a/printing/page_overlays_unittest.cc b/printing/page_overlays_unittest.cc
new file mode 100644
index 0000000..2d1bdac
--- /dev/null
+++ b/printing/page_overlays_unittest.cc
@@ -0,0 +1,92 @@
+// Copyright (c) 2006-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.
+
+#include "base/at_exit.h"
+#include "base/message_loop.h"
+#include "base/string_util.h"
+#include "printing/page_overlays.h"
+#include "printing/print_settings.h"
+#include "printing/printed_document.h"
+#include "printing/printed_page.h"
+#include "printing/printed_pages_source.h"
+#include "testing/gtest/include/gtest/gtest.h"
+
+namespace {
+
+base::AtExitManager global_at_exit_manager;
+
+class PageOverlaysTest : public testing::Test {
+ private:
+ MessageLoop message_loop_;
+};
+
+struct Keys {
+ const wchar_t* key;
+ const wchar_t* expected;
+};
+
+const Keys kOverlayKeys[] = {
+ printing::PageOverlays::kTitle, L"Foobar Document",
+ printing::PageOverlays::kTime, L"",
+ printing::PageOverlays::kDate, L"",
+ printing::PageOverlays::kPage, L"1",
+ printing::PageOverlays::kPageCount, L"2",
+ printing::PageOverlays::kPageOnTotal, L"1/2",
+ printing::PageOverlays::kUrl, L"http://www.perdu.com/",
+};
+
+class PagesSource : public printing::PrintedPagesSource {
+ public:
+ virtual std::wstring RenderSourceName() {
+ return L"Foobar Document";
+ }
+
+ virtual GURL RenderSourceUrl() {
+ return GURL(L"http://www.perdu.com");
+ }
+};
+
+} // namespace
+
+
+TEST_F(PageOverlaysTest, StringConversion) {
+ printing::PageOverlays overlays;
+ overlays.GetOverlay(printing::PageOverlays::LEFT,
+ printing::PageOverlays::BOTTOM);
+ printing::PrintSettings settings;
+ PagesSource source;
+ int cookie = 1;
+ scoped_refptr<printing::PrintedDocument> doc(
+ new printing::PrintedDocument(settings, &source, cookie));
+ doc->set_page_count(2);
+ gfx::Size page_size(100, 100);
+ scoped_refptr<printing::PrintedPage> page(
+ new printing::PrintedPage(1, NULL, page_size));
+
+ std::wstring input;
+ std::wstring out;
+ for (int i = 0; i < arraysize(kOverlayKeys); ++i) {
+ input = StringPrintf(L"foo%lsbar", kOverlayKeys[i].key);
+ out = printing::PageOverlays::ReplaceVariables(input, *doc.get(),
+ *page.get());
+ EXPECT_FALSE(out.empty());
+ if (wcslen(kOverlayKeys[i].expected) == 0)
+ continue;
+ EXPECT_EQ(StringPrintf(L"foo%lsbar", kOverlayKeys[i].expected), out) <<
+ kOverlayKeys[i].key;
+ }
+
+ // Check if SetOverlay really sets the page overlay.
+ overlays.SetOverlay(printing::PageOverlays::LEFT,
+ printing::PageOverlays::TOP,
+ UTF16ToWide(L"Page {page}"));
+ input = overlays.GetOverlay(printing::PageOverlays::LEFT,
+ printing::PageOverlays::TOP);
+ EXPECT_EQ(input, L"Page {page}");
+
+ // Replace the variables to see if the page number is correct.
+ out = printing::PageOverlays::ReplaceVariables(input, *doc.get(),
+ *page.get());
+ EXPECT_EQ(out, L"Page 1");
+}