summaryrefslogtreecommitdiffstats
path: root/content/shell
diff options
context:
space:
mode:
authortfarina@chromium.org <tfarina@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2014-01-04 01:51:53 +0000
committertfarina@chromium.org <tfarina@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2014-01-04 01:51:53 +0000
commit3611020a689b02cef892f10b25dacd976c1f09e9 (patch)
tree09ff3abf7788a376889a597776b373fb0e9fedf1 /content/shell
parent9cd7164fb0ae1f6982749adb85449315e771a244 (diff)
downloadchromium_src-3611020a689b02cef892f10b25dacd976c1f09e9.zip
chromium_src-3611020a689b02cef892f10b25dacd976c1f09e9.tar.gz
chromium_src-3611020a689b02cef892f10b25dacd976c1f09e9.tar.bz2
content: Copy layout test helpers from Blink to Chromium.
It just copies the source files first, the gyp changes will come next. BUG=331304 TEST=None, no functional changes yet. R=jochen@chromium.org NOTRY=true Review URL: https://codereview.chromium.org/120773007 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@242982 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'content/shell')
-rw-r--r--content/shell/renderer/test_runner/helper/layout_test_helper_mac.mm263
-rw-r--r--content/shell/renderer/test_runner/helper/layout_test_helper_win.cc54
2 files changed, 317 insertions, 0 deletions
diff --git a/content/shell/renderer/test_runner/helper/layout_test_helper_mac.mm b/content/shell/renderer/test_runner/helper/layout_test_helper_mac.mm
new file mode 100644
index 0000000..31abe09
--- /dev/null
+++ b/content/shell/renderer/test_runner/helper/layout_test_helper_mac.mm
@@ -0,0 +1,263 @@
+// Copyright 2014 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.
+
+/*
+ * Copyright (C) 2010 Google Inc. All rights reserved.
+ * Copyright (C) 2012 Apple Inc.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ *
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following disclaimer
+ * in the documentation and/or other materials provided with the
+ * distribution.
+ * * Neither the name of Google Inc. nor the names of its
+ * contributors may be used to endorse or promote products derived from
+ * this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+ * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+ * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#import <AvailabilityMacros.h>
+#import <AppKit/AppKit.h>
+#include <signal.h>
+#include <stdio.h>
+#include <stdlib.h>
+
+// This is a simple helper app that changes the color sync profile to the
+// generic profile and back when done. This program is managed by the layout
+// test script, so it can do the job for multiple DumpRenderTree while they are
+// running layout tests.
+
+namespace {
+
+#if defined(MAC_OS_X_VERSION_10_7) && \
+ MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_7
+
+CFURLRef user_color_profile_url;
+
+void InstallLayoutTestColorProfile() {
+ // To make sure we get consistent colors (not dependent on the chosen color
+ // space of the main display), we force the generic RGB color profile.
+ // This causes a change the user can see.
+
+ CFUUIDRef main_display_id =
+ CGDisplayCreateUUIDFromDisplayID(CGmain_display_id());
+
+ if (!user_color_profile_url) {
+ CFDictionaryRef device_info = ColorSyncDeviceCopyDeviceInfo(
+ kColorSyncDisplayDeviceClass, main_display_id);
+
+ if (!device_info) {
+ NSLog(@"No display attached to system; not setting main display's color "
+ "profile.");
+ CFRelease(main_display_id);
+ return;
+ }
+
+ CFDictionaryRef profile_info = (CFDictionaryRef)CFDictionaryGetValue(
+ device_info, kColorSyncCustomProfiles);
+ if (profile_info) {
+ user_color_profile_url =
+ (CFURLRef)CFDictionaryGetValue(profile_info, CFSTR("1"));
+ CFRetain(user_color_profile_url);
+ } else {
+ profile_info = (CFDictionaryRef)CFDictionaryGetValue(
+ device_info, kColorSyncFactoryProfiles);
+ CFDictionaryRef factory_profile =
+ (CFDictionaryRef)CFDictionaryGetValue(profile_info, CFSTR("1"));
+ user_color_profile_url = (CFURLRef)CFDictionaryGetValue(
+ factory_profile, kColorSyncDeviceProfileURL);
+ CFRetain(user_color_profile_url);
+ }
+
+ CFRelease(device_info);
+ }
+
+ ColorSyncProfileRef generic_rgb_profile =
+ ColorSyncProfileCreateWithName(kColorSyncGenericRGBProfile);
+ CFErrorRef error;
+ CFURLRef profile_url = ColorSyncProfileGetURL(generic_rgb_profile, &error);
+ if (!profile_url) {
+ NSLog(@"Failed to get URL of Generic RGB color profile! Many pixel tests "
+ "may fail as a result. Error: %@",
+ error);
+
+ if (user_color_profile_url) {
+ CFRelease(user_color_profile_url);
+ user_color_profile_url = 0;
+ }
+
+ CFRelease(generic_rgb_profile);
+ CFRelease(main_display_id);
+ return;
+ }
+
+ CFMutableDictionaryRef profile_info =
+ CFDictionaryCreateMutable(kCFAllocatorDefault,
+ 0,
+ &kCFTypeDictionaryKeyCallBacks,
+ &kCFTypeDictionaryValueCallBacks);
+ CFDictionarySetValue(
+ profile_info, kColorSyncDeviceDefaultProfileID, profile_url);
+
+ if (!ColorSyncDeviceSetCustomProfiles(
+ kColorSyncDisplayDeviceClass, main_display_id, profile_info)) {
+ NSLog(@"Failed to set color profile for main display! Many pixel tests may "
+ "fail as a result.");
+
+ if (user_color_profile_url) {
+ CFRelease(user_color_profile_url);
+ user_color_profile_url = 0;
+ }
+ }
+
+ CFRelease(profile_info);
+ CFRelease(generic_rgb_profile);
+ CFRelease(main_display_id);
+}
+
+void RestoreUserColorProfile() {
+ // This is used as a signal handler, and thus the calls into ColorSync are
+ // unsafe.
+ // But we might as well try to restore the user's color profile, we're going
+ // down anyway...
+
+ if (!user_color_profile_url)
+ return;
+
+ CFUUIDRef main_display_id =
+ CGDisplayCreateUUIDFromDisplayID(CGMainDisplayID());
+ CFMutableDictionaryRef profile_info =
+ CFDictionaryCreateMutable(kCFAllocatorDefault,
+ 0,
+ &kCFTypeDictionaryKeyCallBacks,
+ &kCFTypeDictionaryValueCallBacks);
+ CFDictionarySetValue(
+ profile_info, kColorSyncDeviceDefaultProfileID, user_color_profile_url);
+ ColorSyncDeviceSetCustomProfiles(
+ kColorSyncDisplayDeviceClass, main_display_id, profile_info);
+ CFRelease(main_display_id);
+ CFRelease(profile_info);
+}
+
+#else // For Snow Leopard and before, use older CM* API.
+
+const char color_profile_path[] =
+ "/System/Library/ColorSync/Profiles/Generic RGB Profile.icc";
+
+// The locType field is initialized to 0 which is the same as cmNoProfileBase.
+CMProfileLocation initial_color_profile_location;
+
+void InstallLayoutTestColorProfile() {
+ // To make sure we get consistent colors (not dependent on the Main display),
+ // we force the generic rgb color profile. This cases a change the user can
+ // see.
+ const CMDeviceScope scope = {kCFPreferencesCurrentUser,
+ kCFPreferencesCurrentHost};
+
+ CMProfileRef profile = 0;
+ int error =
+ CMGetProfileByAVID((CMDisplayIDType)kCGDirectMainDisplay, &profile);
+ if (!error) {
+ UInt32 size = sizeof(initial_color_profile_location);
+ error = NCMGetProfileLocation(profile, &initial_color_profile_location, &size);
+ CMCloseProfile(profile);
+ }
+ if (error) {
+ NSLog(@"failed to get the current color profile, pixmaps won't match. "
+ "Error: %d",
+ (int)error);
+ initial_color_profile_location.locType = cmNoProfileBase;
+ return;
+ }
+
+ CMProfileLocation location;
+ location.locType = cmPathBasedProfile;
+ strncpy(location.u.pathLoc.path,
+ color_profile_path,
+ sizeof(location.u.pathLoc.path));
+ error = CMSetDeviceProfile(cmDisplayDeviceClass,
+ (CMDeviceID)kCGDirectMainDisplay,
+ &scope,
+ cmDefaultProfileID,
+ &location);
+ if (error) {
+ NSLog(@"failed install the generic color profile, pixmaps won't match. "
+ "Error: %d",
+ (int)error);
+ initial_color_profile_location.locType = cmNoProfileBase;
+ }
+}
+
+void RestoreUserColorProfile() {
+ // This is used as a signal handler, and thus the calls into ColorSync are
+ // unsafe.
+ // But we might as well try to restore the user's color profile, we're going
+ // down anyway...
+ if (initial_color_profile_location.locType != cmNoProfileBase) {
+ const CMDeviceScope scope = {kCFPreferencesCurrentUser,
+ kCFPreferencesCurrentHost};
+ int error = CMSetDeviceProfile(cmDisplayDeviceClass,
+ (CMDeviceID)kCGDirectMainDisplay,
+ &scope,
+ cmDefaultProfileID,
+ &initial_color_profile_location);
+ if (error) {
+ NSLog(@"Failed to restore color profile, use System Preferences -> "
+ "Displays -> Color to reset. Error: %d",
+ (int)error);
+ }
+ initial_color_profile_location.locType = cmNoProfileBase;
+ }
+}
+
+#endif
+
+void SimpleSignalHandler(int sig) {
+ // Try to restore the color profile and try to go down cleanly.
+ RestoreUserColorProfile();
+ exit(128 + sig);
+}
+
+} // namespace
+
+int main(int argc, char* argv[]) {
+ NSAutoreleasePool* pool = [[NSAutoreleasePool alloc] init];
+
+ // Hooks the ways we might get told to clean up...
+ signal(SIGINT, SimpleSignalHandler);
+ signal(SIGHUP, SimpleSignalHandler);
+ signal(SIGTERM, SimpleSignalHandler);
+
+ // Save off the current profile, and then install the layout test profile.
+ InstallLayoutTestColorProfile();
+
+ // Let the script know we're ready.
+ printf("ready\n");
+ fflush(stdout);
+
+ // Wait for any key (or signal).
+ getchar();
+
+ // Restore the profile.
+ RestoreUserColorProfile();
+
+ [pool release];
+ return 0;
+}
diff --git a/content/shell/renderer/test_runner/helper/layout_test_helper_win.cc b/content/shell/renderer/test_runner/helper/layout_test_helper_win.cc
new file mode 100644
index 0000000..9ec99890
--- /dev/null
+++ b/content/shell/renderer/test_runner/helper/layout_test_helper_win.cc
@@ -0,0 +1,54 @@
+// Copyright 2014 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 <signal.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <windows.h>
+
+static BOOL font_smoothing_enabled = FALSE;
+
+static void SaveInitialSettings() {
+ ::SystemParametersInfo(SPI_GETFONTSMOOTHING, 0, &font_smoothing_enabled, 0);
+}
+
+// Technically, all we need to do is disable ClearType. However,
+// for some reason, the call to SPI_SETFONTSMOOTHINGTYPE doesn't
+// seem to work, so we just disable font smoothing all together
+// (which works reliably).
+static void InstallLayoutTestSettings() {
+ ::SystemParametersInfo(SPI_SETFONTSMOOTHING, FALSE, 0, 0);
+}
+
+static void RestoreInitialSettings() {
+ ::SystemParametersInfo(
+ SPI_SETFONTSMOOTHING, static_cast<UINT>(font_smoothing_enabled), 0, 0);
+}
+
+static void SimpleSignalHandler(int signalNumber) {
+ // Try to restore the settings and then go down cleanly.
+ RestoreInitialSettings();
+ exit(128 + signalNumber);
+}
+
+int main(int, char**) {
+ // Hooks the ways we might get told to clean up...
+ signal(SIGINT, SimpleSignalHandler);
+ signal(SIGTERM, SimpleSignalHandler);
+
+ SaveInitialSettings();
+
+ InstallLayoutTestSettings();
+
+ // Let the script know we're ready.
+ printf("ready\n");
+ fflush(stdout);
+
+ // Wait for any key (or signal).
+ getchar();
+
+ RestoreInitialSettings();
+
+ return EXIT_SUCCESS;
+}