diff options
author | sverrir@google.com <sverrir@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-07-07 21:31:39 +0000 |
---|---|---|
committer | sverrir@google.com <sverrir@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-07-07 21:31:39 +0000 |
commit | 8ff1d42631e79e842669dc3051d91ed7db80f1dc (patch) | |
tree | 55c1987549e982bfbf60a33fad3b60b5113d7864 /printing/page_overlays_unittest.cc | |
parent | 395f9295b3e370746846dbe6073a0d43ab7e4af5 (diff) | |
download | chromium_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.cc | 92 |
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"); +} |