HistoryDelegate.mm 4.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. /*
  2. * Copyright (C) 2009 Apple Inc. All rights reserved.
  3. *
  4. * Redistribution and use in source and binary forms, with or without
  5. * modification, are permitted provided that the following conditions
  6. * are met:
  7. * 1. Redistributions of source code must retain the above copyright
  8. * notice, this list of conditions and the following disclaimer.
  9. * 2. Redistributions in binary form must reproduce the above copyright
  10. * notice, this list of conditions and the following disclaimer in the
  11. * documentation and/or other materials provided with the distribution.
  12. *
  13. * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
  14. * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  15. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
  16. * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR
  17. * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
  18. * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  19. * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
  20. * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
  21. * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  22. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  23. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  24. */
  25. #import "config.h"
  26. #import "HistoryDelegate.h"
  27. #import "DumpRenderTree.h"
  28. #import "TestRunner.h"
  29. #import <WebKit/WebNavigationData.h>
  30. #import <WebKit/WebView.h>
  31. @interface NSURL (DRTExtras)
  32. - (NSString *)_drt_descriptionSuitableForTestResult;
  33. @end
  34. @implementation HistoryDelegate
  35. - (void)webView:(WebView *)webView didNavigateWithNavigationData:(WebNavigationData *)navigationData inFrame:(WebFrame *)webFrame
  36. {
  37. NSURL *url = [navigationData url] ? [NSURL URLWithString:[navigationData url]] : nil;
  38. bool hasClientRedirect = [[navigationData clientRedirectSource] length];
  39. NSHTTPURLResponse *httpResponse = [[navigationData response] isKindOfClass:[NSHTTPURLResponse class]] ? (NSHTTPURLResponse *)[navigationData response] : nil;
  40. bool wasFailure = [navigationData hasSubstituteData] || (httpResponse && [httpResponse statusCode] >= 400);
  41. printf("WebView navigated to url \"%s\" with title \"%s\" with HTTP equivalent method \"%s\". The navigation was %s and was %s%s.\n",
  42. url ? [[url _drt_descriptionSuitableForTestResult] UTF8String] : "<none>",
  43. [navigationData title] ? [[navigationData title] UTF8String] : "",
  44. [navigationData originalRequest] ? [[[navigationData originalRequest] HTTPMethod] UTF8String] : "",
  45. wasFailure ? "a failure" : "successful",
  46. hasClientRedirect ? "a client redirect from " : "not a client redirect",
  47. hasClientRedirect ? [[navigationData clientRedirectSource] UTF8String] : "");
  48. }
  49. - (void)webView:(WebView *)webView didPerformClientRedirectFromURL:(NSString *)sourceURL toURL:(NSString *)destinationURL inFrame:(WebFrame *)webFrame
  50. {
  51. NSURL *source = [NSURL URLWithString:sourceURL];
  52. NSURL *dest = [NSURL URLWithString:destinationURL];
  53. printf("WebView performed a client redirect from \"%s\" to \"%s\".\n", [[source _drt_descriptionSuitableForTestResult] UTF8String], [[dest _drt_descriptionSuitableForTestResult] UTF8String]);
  54. }
  55. - (void)webView:(WebView *)webView didPerformServerRedirectFromURL:(NSString *)sourceURL toURL:(NSString *)destinationURL inFrame:(WebFrame *)webFrame
  56. {
  57. NSURL *source = [NSURL URLWithString:sourceURL];
  58. NSURL *dest = [NSURL URLWithString:destinationURL];
  59. printf("WebView performed a server redirect from \"%s\" to \"%s\".\n", [[source _drt_descriptionSuitableForTestResult] UTF8String], [[dest _drt_descriptionSuitableForTestResult] UTF8String]);
  60. }
  61. - (void)webView:(WebView *)webView updateHistoryTitle:(NSString *)title forURL:(NSString *)url
  62. {
  63. printf("WebView updated the title for history URL \"%s\" to \"%s\".\n", [[[NSURL URLWithString:url]_drt_descriptionSuitableForTestResult] UTF8String], [title UTF8String]);
  64. }
  65. - (void)populateVisitedLinksForWebView:(WebView *)webView
  66. {
  67. if (gTestRunner->dumpVisitedLinksCallback())
  68. printf("Asked to populate visited links for WebView \"%s\"\n", [[[NSURL URLWithString:[webView mainFrameURL]] _drt_descriptionSuitableForTestResult] UTF8String]);
  69. }
  70. @end