Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(5578)

Unified Diff: chrome/test/data/webui/md_bookmarks/test_timer_proxy.js

Issue 2926763005: [MD Bookmarks] Refactor window timer mocking. (Closed)
Patch Set: address comments Created 3 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/test/data/webui/md_bookmarks/test_timer_proxy.js
diff --git a/chrome/test/data/webui/md_bookmarks/test_timer_proxy.js b/chrome/test/data/webui/md_bookmarks/test_timer_proxy.js
new file mode 100644
index 0000000000000000000000000000000000000000..b165726002718a7479c53fa5e463b1321461146c
--- /dev/null
+++ b/chrome/test/data/webui/md_bookmarks/test_timer_proxy.js
@@ -0,0 +1,69 @@
+// 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.
+
+suiteSetup(function() {
+ cr.define('bookmarks', function() {
+ var TestTimerProxy = function(data) {
+ bookmarks.TimerProxy.call(this);
+
+ this.immediatelyResolveTimeouts = true;
+
+ /** @private */
+ this.timeoutIds_ = 0;
+
+ /** @private {!Map<number, !Function>} */
+ this.activeTimeouts_ = new Map();
+ };
+
+ TestTimerProxy.prototype = {
+ __proto__: bookmarks.TimerProxy.prototype,
+
+ /**
+ * @param {Function|string} fn
+ * @param {number=} delay
+ * @return {number}
+ * @override
+ */
+ setTimeout: function(fn, delay) {
+ if (this.immediatelyResolveTimeouts)
+ fn();
+ else
+ this.activeTimeouts_[this.timeoutIds_] = fn;
+
+ return this.timeoutIds_++;
+ },
+
+ /**
+ * @param {number|undefined?} id
+ * @override
+ */
+ clearTimeout: function(id) {
+ this.activeTimeouts_.delete(id);
+ },
+
+ /**
+ * Run the function associated with a timeout id and clear it from the
+ * active timeouts.
+ * @param {number} id
+ */
+ runTimeoutFn: function(id) {
+ this.activeTimeouts_[id]();
+ this.clearTimeout(id);
+ },
+
+ /**
+ * Returns true if a given timeout id has not been run or cleared.
+ * @param {number} id
+ * @return {boolean}
+ */
+ hasTimeout: function(id) {
+ return this.activeTimeouts_.has(id);
+ },
+ };
+
+ return {
+ TestTimerProxy: TestTimerProxy,
+ };
+ });
+});
« no previous file with comments | « chrome/test/data/webui/md_bookmarks/test_store.js ('k') | chrome/test/data/webui/md_bookmarks/toast_manager_test.js » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698