Chromium Code Reviews| Index: ios/web/shell/test/web_shell_navigation_egtest.mm |
| diff --git a/ios/web/shell/test/web_shell_navigation_egtest.mm b/ios/web/shell/test/web_shell_navigation_egtest.mm |
| index 38936aecbe8e41e3afd7e501e2542f321e2b89c4..283d212d66c4c3a39df40a97b0e38d090ac7c492 100644 |
| --- a/ios/web/shell/test/web_shell_navigation_egtest.mm |
| +++ b/ios/web/shell/test/web_shell_navigation_egtest.mm |
| @@ -4,9 +4,13 @@ |
| #import <UIKit/UIKit.h> |
| #import <XCTest/XCTest.h> |
| +#import <WebKit/WebKit.h> |
|
Eugene But (OOO till 7-30)
2016/04/16 00:38:40
Please sort includes alphabetically
baxley
2016/04/21 16:09:18
Done.
|
| #import <EarlGrey/EarlGrey.h> |
| +#include "base/strings/sys_string_conversions.h" |
| +#include "ios/web/public/test/http_server_util.h" |
| +#import "ios/web/shell/test/utils/web_view_egutil.h" |
| #import "ios/web/shell/view_controller.h" |
| @interface CRWWebShellNavigationTest : XCTestCase |
| @@ -15,51 +19,92 @@ |
| @implementation CRWWebShellNavigationTest |
| -// Sample test to load a live URL, go back and then forward. |
| -- (void)testExternalURLBackAndForward { |
| +// Set up called once for the class. |
| ++ (void)setUp { |
| + [super setUp]; |
| + web::test::HttpServer& server = web::test::HttpServer::GetSharedInstance(); |
| + server.StartOrDie(); |
| + DCHECK(server.IsRunning()); |
| +} |
| + |
| +// Tear down called once for the class. |
| ++ (void)tearDown { |
| + [super tearDown]; |
| + web::test::HttpServer& server = web::test::HttpServer::GetSharedInstance(); |
| + server.Stop(); |
| + DCHECK(!server.IsRunning()); |
| +} |
| + |
| +// Tear down called after each test. |
| +- (void)tearDown { |
| + [super tearDown]; |
| + web::test::HttpServer& server = web::test::HttpServer::GetSharedInstance(); |
| + server.RemoveAllResponseProviders(); |
| +} |
| + |
| +// Tests the back and forward button after entering two URLs. |
| +- (void)testWebScenarioBrowsingBackAndForward { |
| + // Create map of canned responses and set up the test HTML server. |
| + std::map<GURL, std::string> responses; |
| + const GURL firstGURL = web::test::HttpServer::MakeUrl("http://firstURL"); |
| + NSString* firstURL = base::SysUTF8ToNSString(firstGURL.spec().c_str()); |
| + NSString* firstResponse = @"Test Page 1"; |
| + responses[firstGURL] = base::SysNSStringToUTF8(firstResponse); |
| + |
| + const GURL secondGURL = web::test::HttpServer::MakeUrl("http://secondURL"); |
|
Eugene But (OOO till 7-30)
2016/04/16 00:38:40
Optional NIT: s/secondGURL/secondURL
baxley
2016/04/21 16:09:18
Done.
|
| + NSString* secondURL = base::SysUTF8ToNSString(secondGURL.spec().c_str()); |
|
Eugene But (OOO till 7-30)
2016/04/16 00:38:40
Optional NIT: s/secondURL/secondURLSpec
Eugene But (OOO till 7-30)
2016/04/16 00:38:41
Drop |.c_str()|. SysUTF8ToNSString takes std::stri
baxley
2016/04/21 16:09:18
Acknowledged.
baxley
2016/04/21 16:09:18
Acknowledged.
|
| + NSString* secondResponse = @"Test Page 2"; |
| + responses[secondGURL] = base::SysNSStringToUTF8(secondResponse); |
| + |
| + web::test::http_server_util::SetUpSimpleHttpServer(responses); |
| + |
| [[EarlGrey |
|
Eugene But (OOO till 7-30)
2016/04/16 00:38:40
Can we group these methods into a single "enter UR
baxley
2016/04/21 16:09:18
I think that's a reasonable approach, but isn't ne
|
| selectElementWithMatcher:grey_accessibilityLabel( |
|
Eugene But (OOO till 7-30)
2016/04/16 00:38:40
NIT: Can you move matcher to a separate variable t
baxley
2016/04/21 16:09:18
n/a
|
| kWebShellAddressFieldAccessibilityLabel)] |
| performAction:grey_tap()]; |
| [[EarlGrey selectElementWithMatcher:grey_accessibilityLabel(@"Clear text")] |
|
Eugene But (OOO till 7-30)
2016/04/16 00:38:41
Please make constant for "Clear Text"
baxley
2016/04/21 16:09:18
n/a
|
| performAction:grey_tap()]; |
| - [[EarlGrey |
| + [[[EarlGrey |
| selectElementWithMatcher:grey_accessibilityLabel( |
|
Eugene But (OOO till 7-30)
2016/04/16 00:38:40
NIT: Separate variable for matcher?
baxley
2016/04/21 16:09:18
n/a for this CL, but good idea for the future.
|
| kWebShellAddressFieldAccessibilityLabel)] |
| - performAction:grey_typeText(@"http://browsingtest.appspot.com\n")]; |
| - [[EarlGrey |
| - selectElementWithMatcher:grey_accessibilityLabel( |
| - kWebShellBackButtonAccessibilityLabel)] |
| - performAction:grey_tap()]; |
| + performAction:grey_typeText(firstURL)] |
| + performAction:grey_typeText(@"\n")]; |
| + |
| [[EarlGrey |
| - selectElementWithMatcher:grey_accessibilityLabel( |
| - kWebShellForwardButtonAccessibilityLabel)] |
| - performAction:grey_tap()]; |
| -} |
| + selectElementWithMatcher:shell_webViewContainingText(firstResponse)] |
| + assertWithMatcher:grey_notNil()]; |
| -// Sample test to load a live URL, go back, forward, and then back again. |
| -- (void)testExternalURLBackAndForwardAndBack { |
| [[EarlGrey |
| selectElementWithMatcher:grey_accessibilityLabel( |
| kWebShellAddressFieldAccessibilityLabel)] |
| performAction:grey_tap()]; |
| [[EarlGrey selectElementWithMatcher:grey_accessibilityLabel(@"Clear text")] |
| performAction:grey_tap()]; |
| - [[EarlGrey |
| + [[[EarlGrey |
| selectElementWithMatcher:grey_accessibilityLabel( |
| kWebShellAddressFieldAccessibilityLabel)] |
| - performAction:grey_typeText(@"http://browsingtest.appspot.com\n")]; |
| + performAction:grey_typeText(secondURL)] |
| + performAction:grey_typeText(@"\n")]; |
| + |
| + [[EarlGrey |
| + selectElementWithMatcher:shell_webViewContainingText(secondResponse)] |
| + assertWithMatcher:grey_notNil()]; |
| + |
| [[EarlGrey |
| selectElementWithMatcher:grey_accessibilityLabel( |
| kWebShellBackButtonAccessibilityLabel)] |
| performAction:grey_tap()]; |
| [[EarlGrey |
| + selectElementWithMatcher:shell_webViewContainingText(firstResponse)] |
| + assertWithMatcher:grey_notNil()]; |
| + [[EarlGrey |
| selectElementWithMatcher:grey_accessibilityLabel( |
| kWebShellForwardButtonAccessibilityLabel)] |
| performAction:grey_tap()]; |
| + |
| [[EarlGrey |
| - selectElementWithMatcher:grey_accessibilityLabel( |
| - kWebShellBackButtonAccessibilityLabel)] |
| - performAction:grey_tap()]; |
| + selectElementWithMatcher:shell_webViewContainingText(secondResponse)] |
| + assertWithMatcher:grey_notNil()]; |
| } |
| + |
| @end |