From 6eb81ae5a91bd987c3afb1b58136bcc2ce03bfd2 Mon Sep 17 00:00:00 2001 From: boocmp Date: Mon, 16 Dec 2024 14:20:43 +0700 Subject: [PATCH] Await for element in list. --- .../ad_block_custom_resources_browsertest.cc | 41 +++++++++++++------ .../brave_adblock_scriptlet_list.ts | 16 ++++---- 2 files changed, 37 insertions(+), 20 deletions(-) diff --git a/browser/brave_shields/ad_block_custom_resources_browsertest.cc b/browser/brave_shields/ad_block_custom_resources_browsertest.cc index 43bce15ff82a..9c1530eabe61 100644 --- a/browser/brave_shields/ad_block_custom_resources_browsertest.cc +++ b/browser/brave_shields/ad_block_custom_resources_browsertest.cc @@ -24,18 +24,23 @@ namespace { void AwaitElement(content::WebContents* web_contents, const std::string& root, - const std::string& id) { + const std::string& id, + bool disappear = false) { constexpr const char kScript[] = R"js( (async () => { - while (!window.testing[$1].getElementById($2)) { + let waiter = () => { return !window.testing[$1].getElementById($2); }; + if ($3) { + waiter = () => { return window.testing[$1].getElementById($2); }; + } + while (waiter()) { await new Promise(r => setTimeout(r, 10)); } return true; })(); )js"; - EXPECT_TRUE( - content::EvalJs(web_contents, content::JsReplace(kScript, root, id)) - .ExtractBool()); + EXPECT_TRUE(content::EvalJs(web_contents, + content::JsReplace(kScript, root, id, disappear)) + .ExtractBool()); } bool ClickAddCustomScriptlet(content::WebContents* web_contents) { @@ -90,12 +95,21 @@ std::string GetCustomScriptletContent(content::WebContents* web_contents) { return GetCustomScriptletValue(web_contents, "scriptlet-content"); } -bool ClickSaveCustomScriptlet(content::WebContents* web_contents) { +bool ClickSaveCustomScriptlet(content::WebContents* web_contents, + const std ::string& name) { AwaitElement(web_contents, "adblockScriptletEditor", "save"); - return EvalJs(web_contents, - "window.testing.adblockScriptletEditor.getElementById('save')." - "click()") - .value.is_none(); + if (!EvalJs(web_contents, + "window.testing.adblockScriptletEditor.getElementById('save')." + "click()") + .value.is_none()) { + return false; + } + std::string id = name.starts_with("user-") ? name : "user-" + name; + if (!id.ends_with(".js")) { + id += ".js"; + } + AwaitElement(web_contents, "adblockScriptletList", id); + return true; } bool ClickCustomScriplet(content::WebContents* web_contents, @@ -133,7 +147,7 @@ class AdblockCustomResourcesTest : public AdBlockServiceTest { ASSERT_TRUE(SetCustomScriptletContent(web_contents(), value)); ASSERT_TRUE(SetCustomScriptletName(web_contents(), name)); - ASSERT_TRUE(ClickSaveCustomScriptlet(web_contents())); + ASSERT_TRUE(ClickSaveCustomScriptlet(web_contents(), name)); } void CheckCustomScriptlet(const base::Value& custom_scriptlet, @@ -165,8 +179,7 @@ class AdblockCustomResourcesTest : public AdBlockServiceTest { base::test::ScopedFeatureList feature_list_; }; -IN_PROC_BROWSER_TEST_F(AdblockCustomResourcesTest, - DISABLED_AddEditRemoveScriptlet) { +IN_PROC_BROWSER_TEST_F(AdblockCustomResourcesTest, AddEditRemoveScriptlet) { EnableDeveloperMode(true); NavigateToURL(GURL("brave://settings/shields/filters")); @@ -202,6 +215,8 @@ IN_PROC_BROWSER_TEST_F(AdblockCustomResourcesTest, ASSERT_TRUE(ClickCustomScriplet(web_contents(), "user-custom-script-edited.js", "delete")); + AwaitElement(web_contents(), "adblockScriptletList", + "user-custom-script-edited.js", true); { const auto& custom_resources = GetCustomResources(); ASSERT_TRUE(custom_resources.is_list()); diff --git a/browser/resources/settings/default_brave_shields_page/components/brave_adblock_scriptlet_list.ts b/browser/resources/settings/default_brave_shields_page/components/brave_adblock_scriptlet_list.ts index 776088c5b691..a892da311e31 100644 --- a/browser/resources/settings/default_brave_shields_page/components/brave_adblock_scriptlet_list.ts +++ b/browser/resources/settings/default_brave_shields_page/components/brave_adblock_scriptlet_list.ts @@ -18,7 +18,8 @@ import { loadTimeData } from '../../i18n_setup.js' import { Scriptlet, - BraveAdblockBrowserProxyImpl + BraveAdblockBrowserProxyImpl, + ErrorCode } from '../brave_adblock_browser_proxy.js' import './brave_adblock_scriptlet_editor.js' @@ -100,12 +101,13 @@ class AdblockScriptletList extends AdblockScriptletListBase { } } - this.browserProxy_.removeCustomScriptlet( - this.customScriptletsList_[e.model.index].name - ) - this.browserProxy_.getCustomScriptlets().then((scriptlets) => { - this.customScriptletsList_ = scriptlets - }) + this.browserProxy_ + .removeCustomScriptlet(this.customScriptletsList_[e.model.index].name) + .then((_: ErrorCode) => + this.browserProxy_.getCustomScriptlets().then((scriptlets) => { + this.customScriptletsList_ = scriptlets + }) + ) } scriptletEditorClosed_(_: any) {