diff options
author | yusukes@google.com <yusukes@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-06-06 10:04:15 +0000 |
---|---|---|
committer | yusukes@google.com <yusukes@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-06-06 10:04:15 +0000 |
commit | 6289beb1a1caa052d9379923e2a7a344edb74839 (patch) | |
tree | d86ead3d27e21eafe2490a9ddc0526cd5b57bf22 /app/animation_unittest.cc | |
parent | 8a17bd55d6f0336a3d8e3c66af61a0a3b074dfe9 (diff) | |
download | chromium_src-6289beb1a1caa052d9379923e2a7a344edb74839.zip chromium_src-6289beb1a1caa052d9379923e2a7a344edb74839.tar.gz chromium_src-6289beb1a1caa052d9379923e2a7a344edb74839.tar.bz2 |
Second (and hopefully the final) fix for the issue 805:
Killed (1) the "start download" (big arrow) animation and (2) fade and resize animation on NTP page, when the following conditions is met:
(XP) Chromium is used over RDP.
(Vista) "Turn off all unnecessary animations (when possible)" option in "Control Panel - Ease of Access Center - Make the computer easier to see" is checked. Note that the option automatically becomes checked when a user turns off the "Menu and window animation" option of a remote-desktop client.
Review: http://codereview.chromium.org/115304
BUG=805
TEST=For (1), download a file and verify the arrow doesn't appear over RDP. For (2), set NTP as your homepage, start chromium on RDP session, verify fade animations on thumbnails are killed, then resize browser window, verify resize animations on thumbnails are also killed. Do the same thing with --new-new-tab-page command line flag.
Review URL: http://codereview.chromium.org/118307
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@17827 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'app/animation_unittest.cc')
-rw-r--r-- | app/animation_unittest.cc | 25 |
1 files changed, 23 insertions, 2 deletions
diff --git a/app/animation_unittest.cc b/app/animation_unittest.cc index a7450e3..bc1ebe5 100644 --- a/app/animation_unittest.cc +++ b/app/animation_unittest.cc @@ -4,10 +4,11 @@ #include "app/animation.h" #include "base/message_loop.h" +#if defined(OS_WIN) +#include "base/win_util.h" +#endif #include "testing/gtest/include/gtest/gtest.h" -using namespace std; - class AnimationTest: public testing::Test { private: MessageLoopForUI message_loop_; @@ -100,3 +101,23 @@ TEST_F(AnimationTest, CancelCase) { EXPECT_TRUE(ad.finished()); EXPECT_TRUE(ad.canceled()); } + +TEST_F(AnimationTest, ShouldRenderRichAnimation) { +#if defined(OS_WIN) + if (win_util::GetWinVersion() >= win_util::WINVERSION_VISTA) { + BOOL result; + ASSERT_NE( + 0, ::SystemParametersInfo(SPI_GETCLIENTAREAANIMATION, 0, &result, 0)); + // ShouldRenderRichAnimation() should check the SPI_GETCLIENTAREAANIMATION + // value on Vista. + EXPECT_EQ(!!result, Animation::ShouldRenderRichAnimation()); + } else { + // On XP, the function should check the SM_REMOTESESSION value. + EXPECT_EQ(!::GetSystemMetrics(SM_REMOTESESSION), + Animation::ShouldRenderRichAnimation()); + } +#else + EXPECT_TRUE(Animation::ShouldRenderRichAnimation()); +#endif +} + |