| Index: ios/web/navigation/navigation_manager_util_unittest.mm
|
| diff --git a/ios/web/navigation/navigation_manager_util_unittest.mm b/ios/web/navigation/navigation_manager_util_unittest.mm
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..da2297af2fcbf3ede86da7ea59eb4959d42229f7
|
| --- /dev/null
|
| +++ b/ios/web/navigation/navigation_manager_util_unittest.mm
|
| @@ -0,0 +1,61 @@
|
| +// Copyright 2017 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 "ios/web/navigation/navigation_manager_util.h"
|
| +
|
| +#include "base/memory/ptr_util.h"
|
| +#import "ios/web/navigation/crw_session_controller+private_constructors.h"
|
| +#import "ios/web/navigation/crw_session_controller.h"
|
| +#import "ios/web/navigation/navigation_manager_impl.h"
|
| +#import "ios/web/public/navigation_item.h"
|
| +#include "ios/web/public/test/fakes/test_browser_state.h"
|
| +#include "testing/platform_test.h"
|
| +
|
| +#if !defined(__has_feature) || !__has_feature(objc_arc)
|
| +#error "This file requires ARC support."
|
| +#endif
|
| +
|
| +namespace web {
|
| +
|
| +// Test fixture testing navigation_manager_util.h functions.
|
| +class NavigationManagerUtilTest : public PlatformTest {
|
| + protected:
|
| + NavigationManagerUtilTest()
|
| + : controller_([[CRWSessionController alloc]
|
| + initWithBrowserState:&browser_state_]) {
|
| + manager_.SetSessionController(controller_);
|
| + }
|
| +
|
| + NavigationManagerImpl manager_;
|
| + CRWSessionController* controller_;
|
| +
|
| + private:
|
| + TestBrowserState browser_state_;
|
| +};
|
| +
|
| +// Tests GetCommittedItemWithUniqueID and GetCommittedItemIndexWithUniqueID
|
| +// functions.
|
| +TEST_F(NavigationManagerUtilTest, GetCommittedItemWithUniqueID) {
|
| + // Start with NavigationManager that only has a pending item.
|
| + manager_.AddPendingItem(
|
| + GURL("http://chromium.org"), Referrer(), ui::PAGE_TRANSITION_TYPED,
|
| + web::NavigationInitiationType::USER_INITIATED,
|
| + web::NavigationManager::UserAgentOverrideOption::INHERIT);
|
| + NavigationItem* item = manager_.GetPendingItem();
|
| + int unique_id = item->GetUniqueID();
|
| + EXPECT_FALSE(GetCommittedItemWithUniqueID(&manager_, unique_id));
|
| + EXPECT_EQ(-1, GetCommittedItemIndexWithUniqueID(&manager_, unique_id));
|
| +
|
| + // Commit that pending item.
|
| + [controller_ commitPendingItem];
|
| + EXPECT_EQ(item, GetCommittedItemWithUniqueID(&manager_, unique_id));
|
| + EXPECT_EQ(0, GetCommittedItemIndexWithUniqueID(&manager_, unique_id));
|
| +
|
| + // Remove committed item.
|
| + manager_.RemoveItemAtIndex(0);
|
| + EXPECT_FALSE(GetCommittedItemWithUniqueID(&manager_, unique_id));
|
| + EXPECT_EQ(-1, GetCommittedItemIndexWithUniqueID(&manager_, unique_id));
|
| +}
|
| +
|
| +} // namespace web
|
|
|