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

Side by Side Diff: third_party/WebKit/Source/core/editing/spellcheck/IdleSpellCheckCallbackTest.cpp

Issue 2744603004: Correct the activation of idle time spell checker on document attach (Closed)
Patch Set: Created 3 years, 9 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 unified diff | Download patch
OLDNEW
1 // Copyright 2017 The Chromium Authors. All rights reserved. 1 // Copyright 2017 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "core/editing/spellcheck/IdleSpellCheckCallback.h" 5 #include "core/editing/spellcheck/IdleSpellCheckCallback.h"
6 6
7 #include "core/editing/spellcheck/SpellCheckTestBase.h" 7 #include "core/editing/spellcheck/SpellCheckTestBase.h"
8 #include "core/editing/spellcheck/SpellChecker.h" 8 #include "core/editing/spellcheck/SpellChecker.h"
9 #include "core/frame/LocalFrame.h" 9 #include "core/frame/LocalFrame.h"
10 #include "platform/RuntimeEnabledFeatures.h" 10 #include "platform/RuntimeEnabledFeatures.h"
11 11
12 namespace blink { 12 namespace blink {
13 13
14 using State = IdleSpellCheckCallback::State; 14 using State = IdleSpellCheckCallback::State;
15 15
16 class IdleSpellCheckCallbackTest : public SpellCheckTestBase { 16 class IdleSpellCheckCallbackTest : public SpellCheckTestBase {
17 protected: 17 protected:
18 IdleSpellCheckCallback& idleChecker() { 18 IdleSpellCheckCallback& idleChecker() {
19 return frame().spellChecker().idleSpellCheckCallback(); 19 return frame().spellChecker().idleSpellCheckCallback();
20 } 20 }
21 21
22 void SetUp() override {
23 SpellCheckTestBase::SetUp();
24 if (!RuntimeEnabledFeatures::idleTimeSpellCheckingEnabled())
25 idleChecker().documentAttached(frame().document());
26 }
27
28 void transitTo(State state) { 22 void transitTo(State state) {
29 switch (state) { 23 switch (state) {
30 case State::kInactive: 24 case State::kInactive:
31 idleChecker().deactivate(); 25 idleChecker().deactivate();
32 break; 26 break;
33 case State::kHotModeRequested: 27 case State::kHotModeRequested:
34 idleChecker().setNeedsInvocation(); 28 idleChecker().setNeedsInvocation();
35 break; 29 break;
36 case State::kColdModeTimerStarted: 30 case State::kColdModeTimerStarted:
37 break; 31 break;
38 case State::kColdModeRequested: 32 case State::kColdModeRequested:
39 idleChecker().skipColdModeTimerForTesting(); 33 idleChecker().skipColdModeTimerForTesting();
40 break; 34 break;
41 case State::kInHotModeInvocation: 35 case State::kInHotModeInvocation:
42 case State::kInColdModeInvocation: 36 case State::kInColdModeInvocation:
43 NOTREACHED(); 37 NOTREACHED();
44 } 38 }
45 } 39 }
46 }; 40 };
47 41
48 // Test cases for lifecycle state transitions. 42 // Test cases for lifecycle state transitions.
49 43
50 TEST_F(IdleSpellCheckCallbackTest, Initialization) { 44 TEST_F(IdleSpellCheckCallbackTest, Initialization) {
45 if (!RuntimeEnabledFeatures::idleTimeSpellCheckingEnabled())
46 return;
47
51 EXPECT_EQ(State::kColdModeTimerStarted, idleChecker().state()); 48 EXPECT_EQ(State::kColdModeTimerStarted, idleChecker().state());
52 } 49 }
53 50
54 TEST_F(IdleSpellCheckCallbackTest, RequestWhenInactive) { 51 TEST_F(IdleSpellCheckCallbackTest, RequestWhenInactive) {
52 if (!RuntimeEnabledFeatures::idleTimeSpellCheckingEnabled())
53 return;
54
55 transitTo(State::kInactive); 55 transitTo(State::kInactive);
56 idleChecker().setNeedsInvocation(); 56 idleChecker().setNeedsInvocation();
57 EXPECT_EQ(State::kHotModeRequested, idleChecker().state()); 57 EXPECT_EQ(State::kHotModeRequested, idleChecker().state());
58 EXPECT_NE(-1, idleChecker().idleCallbackHandle()); 58 EXPECT_NE(-1, idleChecker().idleCallbackHandle());
59 } 59 }
60 60
61 TEST_F(IdleSpellCheckCallbackTest, RequestWhenHotModeRequested) { 61 TEST_F(IdleSpellCheckCallbackTest, RequestWhenHotModeRequested) {
62 if (!RuntimeEnabledFeatures::idleTimeSpellCheckingEnabled())
63 return;
64
62 transitTo(State::kHotModeRequested); 65 transitTo(State::kHotModeRequested);
63 int handle = idleChecker().idleCallbackHandle(); 66 int handle = idleChecker().idleCallbackHandle();
64 idleChecker().setNeedsInvocation(); 67 idleChecker().setNeedsInvocation();
65 EXPECT_EQ(State::kHotModeRequested, idleChecker().state()); 68 EXPECT_EQ(State::kHotModeRequested, idleChecker().state());
66 EXPECT_EQ(handle, idleChecker().idleCallbackHandle()); 69 EXPECT_EQ(handle, idleChecker().idleCallbackHandle());
67 EXPECT_NE(-1, idleChecker().idleCallbackHandle()); 70 EXPECT_NE(-1, idleChecker().idleCallbackHandle());
68 } 71 }
69 72
70 TEST_F(IdleSpellCheckCallbackTest, RequestWhenColdModeTimerStarted) { 73 TEST_F(IdleSpellCheckCallbackTest, RequestWhenColdModeTimerStarted) {
74 if (!RuntimeEnabledFeatures::idleTimeSpellCheckingEnabled())
75 return;
76
71 transitTo(State::kColdModeTimerStarted); 77 transitTo(State::kColdModeTimerStarted);
72 idleChecker().setNeedsInvocation(); 78 idleChecker().setNeedsInvocation();
73 EXPECT_EQ(State::kHotModeRequested, idleChecker().state()); 79 EXPECT_EQ(State::kHotModeRequested, idleChecker().state());
74 EXPECT_NE(-1, idleChecker().idleCallbackHandle()); 80 EXPECT_NE(-1, idleChecker().idleCallbackHandle());
75 } 81 }
76 82
77 TEST_F(IdleSpellCheckCallbackTest, RequestWhenColdModeRequested) { 83 TEST_F(IdleSpellCheckCallbackTest, RequestWhenColdModeRequested) {
84 if (!RuntimeEnabledFeatures::idleTimeSpellCheckingEnabled())
85 return;
86
78 transitTo(State::kColdModeRequested); 87 transitTo(State::kColdModeRequested);
79 int handle = idleChecker().idleCallbackHandle(); 88 int handle = idleChecker().idleCallbackHandle();
80 idleChecker().setNeedsInvocation(); 89 idleChecker().setNeedsInvocation();
81 EXPECT_EQ(State::kHotModeRequested, idleChecker().state()); 90 EXPECT_EQ(State::kHotModeRequested, idleChecker().state());
82 EXPECT_NE(handle, idleChecker().idleCallbackHandle()); 91 EXPECT_NE(handle, idleChecker().idleCallbackHandle());
83 EXPECT_NE(-1, idleChecker().idleCallbackHandle()); 92 EXPECT_NE(-1, idleChecker().idleCallbackHandle());
84 } 93 }
85 94
86 TEST_F(IdleSpellCheckCallbackTest, HotModeTransitToColdMode) { 95 TEST_F(IdleSpellCheckCallbackTest, HotModeTransitToColdMode) {
96 if (!RuntimeEnabledFeatures::idleTimeSpellCheckingEnabled())
97 return;
98
87 transitTo(State::kHotModeRequested); 99 transitTo(State::kHotModeRequested);
88 idleChecker().forceInvocationForTesting(); 100 idleChecker().forceInvocationForTesting();
89 EXPECT_EQ(State::kColdModeTimerStarted, idleChecker().state()); 101 EXPECT_EQ(State::kColdModeTimerStarted, idleChecker().state());
90 } 102 }
91 103
92 TEST_F(IdleSpellCheckCallbackTest, ColdModeTimerStartedToRequested) { 104 TEST_F(IdleSpellCheckCallbackTest, ColdModeTimerStartedToRequested) {
105 if (!RuntimeEnabledFeatures::idleTimeSpellCheckingEnabled())
106 return;
107
93 transitTo(State::kColdModeTimerStarted); 108 transitTo(State::kColdModeTimerStarted);
94 idleChecker().skipColdModeTimerForTesting(); 109 idleChecker().skipColdModeTimerForTesting();
95 EXPECT_EQ(State::kColdModeRequested, idleChecker().state()); 110 EXPECT_EQ(State::kColdModeRequested, idleChecker().state());
96 EXPECT_NE(-1, idleChecker().idleCallbackHandle()); 111 EXPECT_NE(-1, idleChecker().idleCallbackHandle());
97 } 112 }
98 113
99 TEST_F(IdleSpellCheckCallbackTest, ColdModeStayAtColdMode) { 114 TEST_F(IdleSpellCheckCallbackTest, ColdModeStayAtColdMode) {
115 if (!RuntimeEnabledFeatures::idleTimeSpellCheckingEnabled())
116 return;
117
100 transitTo(State::kColdModeRequested); 118 transitTo(State::kColdModeRequested);
101 idleChecker().setNeedsMoreColdModeInvocationForTesting(); 119 idleChecker().setNeedsMoreColdModeInvocationForTesting();
102 idleChecker().forceInvocationForTesting(); 120 idleChecker().forceInvocationForTesting();
103 EXPECT_EQ(State::kColdModeTimerStarted, idleChecker().state()); 121 EXPECT_EQ(State::kColdModeTimerStarted, idleChecker().state());
104 } 122 }
105 123
106 TEST_F(IdleSpellCheckCallbackTest, ColdModeToInactive) { 124 TEST_F(IdleSpellCheckCallbackTest, ColdModeToInactive) {
125 if (!RuntimeEnabledFeatures::idleTimeSpellCheckingEnabled())
126 return;
127
107 transitTo(State::kColdModeRequested); 128 transitTo(State::kColdModeRequested);
108 idleChecker().forceInvocationForTesting(); 129 idleChecker().forceInvocationForTesting();
109 EXPECT_EQ(State::kInactive, idleChecker().state()); 130 EXPECT_EQ(State::kInactive, idleChecker().state());
110 } 131 }
111 132
112 TEST_F(IdleSpellCheckCallbackTest, DetachWhenInactive) { 133 TEST_F(IdleSpellCheckCallbackTest, DetachWhenInactive) {
134 if (!RuntimeEnabledFeatures::idleTimeSpellCheckingEnabled())
135 return;
136
113 transitTo(State::kInactive); 137 transitTo(State::kInactive);
114 document().shutdown(); 138 document().shutdown();
115 EXPECT_EQ(State::kInactive, idleChecker().state()); 139 EXPECT_EQ(State::kInactive, idleChecker().state());
116 } 140 }
117 141
118 TEST_F(IdleSpellCheckCallbackTest, DetachWhenHotModeRequested) { 142 TEST_F(IdleSpellCheckCallbackTest, DetachWhenHotModeRequested) {
143 if (!RuntimeEnabledFeatures::idleTimeSpellCheckingEnabled())
144 return;
145
119 transitTo(State::kHotModeRequested); 146 transitTo(State::kHotModeRequested);
120 document().shutdown(); 147 document().shutdown();
121 EXPECT_EQ(State::kInactive, idleChecker().state()); 148 EXPECT_EQ(State::kInactive, idleChecker().state());
122 } 149 }
123 150
124 TEST_F(IdleSpellCheckCallbackTest, DetachWhenColdModeTimerStarted) { 151 TEST_F(IdleSpellCheckCallbackTest, DetachWhenColdModeTimerStarted) {
152 if (!RuntimeEnabledFeatures::idleTimeSpellCheckingEnabled())
153 return;
154
125 transitTo(State::kColdModeTimerStarted); 155 transitTo(State::kColdModeTimerStarted);
126 document().shutdown(); 156 document().shutdown();
127 EXPECT_EQ(State::kInactive, idleChecker().state()); 157 EXPECT_EQ(State::kInactive, idleChecker().state());
128 } 158 }
129 159
130 TEST_F(IdleSpellCheckCallbackTest, DetachWhenColdModeRequested) { 160 TEST_F(IdleSpellCheckCallbackTest, DetachWhenColdModeRequested) {
161 if (!RuntimeEnabledFeatures::idleTimeSpellCheckingEnabled())
162 return;
163
131 transitTo(State::kColdModeRequested); 164 transitTo(State::kColdModeRequested);
132 document().shutdown(); 165 document().shutdown();
133 EXPECT_EQ(State::kInactive, idleChecker().state()); 166 EXPECT_EQ(State::kInactive, idleChecker().state());
134 } 167 }
135 168
136 } // namespace blink 169 } // namespace blink
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698