summaryrefslogtreecommitdiff
path: root/testing/embedder_test_timer_handling_delegate.h
diff options
context:
space:
mode:
authortsepez <tsepez@chromium.org>2017-01-12 11:21:12 -0800
committerCommit bot <commit-bot@chromium.org>2017-01-12 11:21:12 -0800
commit6cf5ecae75a5cd6fea9ae7f4e28cc28abb3e69c6 (patch)
tree07f913aa6847952a32ed787f2861a5099d81cf69 /testing/embedder_test_timer_handling_delegate.h
parent192497124e7cde747ade7bf89028586eea293be5 (diff)
downloadpdfium-6cf5ecae75a5cd6fea9ae7f4e28cc28abb3e69c6.tar.xz
Don't put timers with ID == 0 into the global timer map.
A return of ID == 0 from the embedder means the timer was not created (see public/fpdf_formfill.h), although few embedders actually conform to this convention. Firing a timer with ID == 0 will thus do nothing since there can't be such a timer in the map. BUG=679649 Review-Url: https://codereview.chromium.org/2626863003
Diffstat (limited to 'testing/embedder_test_timer_handling_delegate.h')
-rw-r--r--testing/embedder_test_timer_handling_delegate.h11
1 files changed, 8 insertions, 3 deletions
diff --git a/testing/embedder_test_timer_handling_delegate.h b/testing/embedder_test_timer_handling_delegate.h
index 709dd22c17..31966159eb 100644
--- a/testing/embedder_test_timer_handling_delegate.h
+++ b/testing/embedder_test_timer_handling_delegate.h
@@ -38,9 +38,11 @@ class EmbedderTestTimerHandlingDelegate : public EmbedderTest::Delegate {
}
int SetTimer(int msecs, TimerCallback fn) override {
- expiry_to_timer_map_.insert(std::pair<int, Timer>(
- msecs + fake_elapsed_msecs_, {++next_timer_id_, msecs, fn}));
- return next_timer_id_;
+ int id = fail_next_timer_ ? 0 : ++next_timer_id_;
+ expiry_to_timer_map_.insert(
+ std::pair<int, Timer>(msecs + fake_elapsed_msecs_, {id, msecs, fn}));
+ fail_next_timer_ = false;
+ return id;
}
void KillTimer(int id) override {
@@ -73,8 +75,11 @@ class EmbedderTestTimerHandlingDelegate : public EmbedderTest::Delegate {
const std::vector<AlertRecord>& GetAlerts() const { return alerts_; }
+ void SetFailNextTimer() { fail_next_timer_ = true; }
+
protected:
std::multimap<int, Timer> expiry_to_timer_map_; // Keyed by timeout.
+ bool fail_next_timer_ = false;
int next_timer_id_ = 0;
int fake_elapsed_msecs_ = 0;
std::vector<AlertRecord> alerts_;