Chromium Code Reviews| Index: fpdfsdk/fpdfformfill_embeddertest.cpp |
| diff --git a/fpdfsdk/fpdfformfill_embeddertest.cpp b/fpdfsdk/fpdfformfill_embeddertest.cpp |
| index c73dc008f7ba753d51d2b16375522f232c8dcd53..a827c11d57bb75487bd897b0e06fce55e48c7578 100644 |
| --- a/fpdfsdk/fpdfformfill_embeddertest.cpp |
| +++ b/fpdfsdk/fpdfformfill_embeddertest.cpp |
| @@ -66,22 +66,65 @@ TEST_F(FPDFFormFillEmbeddertest, BUG_514690) { |
| #ifdef PDF_ENABLE_V8 |
| TEST_F(FPDFFormFillEmbeddertest, BUG_551248) { |
| + // Test that timers fire once and intervals fire repeatedly. |
| EmbedderTestTimerHandlingDelegate delegate; |
| SetDelegate(&delegate); |
| EXPECT_TRUE(OpenDocument("bug_551248.pdf")); |
| FPDF_PAGE page = LoadPage(0); |
| - EXPECT_NE(nullptr, page); |
| + EXPECT_TRUE(page); |
| DoOpenActions(); |
| - delegate.AdvanceTime(5000); |
| - UnloadPage(page); |
| const auto& alerts = delegate.GetAlerts(); |
| - ASSERT_EQ(1U, alerts.size()); |
| + EXPECT_EQ(0U, alerts.size()); |
| + |
| + delegate.AdvanceTime(1000); |
| + EXPECT_EQ(0U, alerts.size()); // nothing fired. |
| + delegate.AdvanceTime(1000); |
| + EXPECT_EQ(1U, alerts.size()); // interval fired. |
| + delegate.AdvanceTime(1000); |
| + EXPECT_EQ(2U, alerts.size()); // timer fired. |
| + delegate.AdvanceTime(1000); |
| + EXPECT_EQ(3U, alerts.size()); // interval fired again. |
| + delegate.AdvanceTime(1000); |
| + UnloadPage(page); |
| + |
| + ASSERT_EQ(3U, alerts.size()); // nothing else fired. |
| - EXPECT_STREQ(L"hello world", alerts[0].message.c_str()); |
| + EXPECT_STREQ(L"interval fired", alerts[0].message.c_str()); |
| EXPECT_STREQ(L"Alert", alerts[0].title.c_str()); |
| EXPECT_EQ(0, alerts[0].type); |
| EXPECT_EQ(0, alerts[0].icon); |
| + |
| + EXPECT_STREQ(L"timer fired", alerts[1].message.c_str()); |
| + EXPECT_STREQ(L"Alert", alerts[1].title.c_str()); |
| + EXPECT_EQ(0, alerts[1].type); |
| + EXPECT_EQ(0, alerts[1].icon); |
| + |
| + EXPECT_STREQ(L"interval fired", alerts[2].message.c_str()); |
| + EXPECT_STREQ(L"Alert", alerts[2].title.c_str()); |
| + EXPECT_EQ(0, alerts[2].type); |
| + EXPECT_EQ(0, alerts[2].icon); |
| } |
| + |
| +TEST_F(FPDFFormFillEmbeddertest, BUG_620428) { |
| + // Test that timers and intervals are cancelable. |
| + EmbedderTestTimerHandlingDelegate delegate; |
| + SetDelegate(&delegate); |
| + |
| + EXPECT_TRUE(OpenDocument("bug_620428.pdf")); |
| + FPDF_PAGE page = LoadPage(0); |
| + EXPECT_NE(nullptr, page); |
|
Lei Zhang
2016/08/03 20:36:52
Do EXPECT_TRUE() like line 75?
Tom Sepez
2016/08/03 20:43:31
Done throughout.
|
| + DoOpenActions(); |
| + delegate.AdvanceTime(1000); |
|
Lei Zhang
2016/08/03 20:36:52
Does this behaves different vs delegate.AdvanceTim
Tom Sepez
2016/08/03 20:43:31
Kinda sorta. The clumsy test harness doesn't sche
|
| + delegate.AdvanceTime(1000); |
| + delegate.AdvanceTime(1000); |
| + delegate.AdvanceTime(1000); |
| + delegate.AdvanceTime(1000); |
| + UnloadPage(page); |
| + |
| + const auto& alerts = delegate.GetAlerts(); |
| + EXPECT_EQ(0U, alerts.size()); |
| +} |
| + |
| #endif // PDF_ENABLE_V8 |