1 /*
2  * Copyright (C) 2008 The Guava Authors
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 package com.google.common.base;
18 
19 import static java.util.concurrent.TimeUnit.MICROSECONDS;
20 import static java.util.concurrent.TimeUnit.MILLISECONDS;
21 import static java.util.concurrent.TimeUnit.NANOSECONDS;
22 
23 import com.google.common.annotations.GwtCompatible;
24 import com.google.common.annotations.GwtIncompatible;
25 import com.google.common.testing.FakeTicker;
26 
27 import junit.framework.TestCase;
28 
29 /**
30  * Unit test for {@link Stopwatch}.
31  *
32  * @author Kevin Bourrillion
33  */
34 @GwtCompatible(emulated = true)
35 public class StopwatchTest extends TestCase {
36 
37   private final FakeTicker ticker = new FakeTicker();
38   private final Stopwatch stopwatch = new Stopwatch(ticker);
39 
testCreateStarted()40   public void testCreateStarted() {
41     Stopwatch startedStopwatch = Stopwatch.createStarted();
42     assertTrue(startedStopwatch.isRunning());
43   }
44 
testCreateUnstarted()45   public void testCreateUnstarted() {
46     Stopwatch unstartedStopwatch = Stopwatch.createUnstarted();
47     assertFalse(unstartedStopwatch.isRunning());
48     assertEquals(0, unstartedStopwatch.elapsed(NANOSECONDS));
49   }
50 
testInitialState()51   public void testInitialState() {
52     assertFalse(stopwatch.isRunning());
53     assertEquals(0, stopwatch.elapsed(NANOSECONDS));
54   }
55 
testStart()56   public void testStart() {
57     assertSame(stopwatch, stopwatch.start());
58     assertTrue(stopwatch.isRunning());
59   }
60 
testStart_whileRunning()61   public void testStart_whileRunning() {
62     stopwatch.start();
63     try {
64       stopwatch.start();
65       fail();
66     } catch (IllegalStateException expected) {
67     }
68     assertTrue(stopwatch.isRunning());
69   }
70 
testStop()71   public void testStop() {
72     stopwatch.start();
73     assertSame(stopwatch, stopwatch.stop());
74     assertFalse(stopwatch.isRunning());
75   }
76 
testStop_new()77   public void testStop_new() {
78     try {
79       stopwatch.stop();
80       fail();
81     } catch (IllegalStateException expected) {
82     }
83     assertFalse(stopwatch.isRunning());
84   }
85 
testStop_alreadyStopped()86   public void testStop_alreadyStopped() {
87     stopwatch.start();
88     stopwatch.stop();
89     try {
90       stopwatch.stop();
91       fail();
92     } catch (IllegalStateException expected) {
93     }
94     assertFalse(stopwatch.isRunning());
95   }
96 
testReset_new()97   public void testReset_new() {
98     ticker.advance(1);
99     stopwatch.reset();
100     assertFalse(stopwatch.isRunning());
101     ticker.advance(2);
102     assertEquals(0, stopwatch.elapsed(NANOSECONDS));
103     stopwatch.start();
104     ticker.advance(3);
105     assertEquals(3, stopwatch.elapsed(NANOSECONDS));
106   }
107 
testReset_whileRunning()108   public void testReset_whileRunning() {
109     ticker.advance(1);
110     stopwatch.start();
111     assertEquals(0, stopwatch.elapsed(NANOSECONDS));
112     ticker.advance(2);
113     assertEquals(2, stopwatch.elapsed(NANOSECONDS));
114     stopwatch.reset();
115     assertFalse(stopwatch.isRunning());
116     ticker.advance(3);
117     assertEquals(0, stopwatch.elapsed(NANOSECONDS));
118   }
119 
testElapsed_whileRunning()120   public void testElapsed_whileRunning() {
121     ticker.advance(78);
122     stopwatch.start();
123     assertEquals(0, stopwatch.elapsed(NANOSECONDS));
124 
125     ticker.advance(345);
126     assertEquals(345, stopwatch.elapsed(NANOSECONDS));
127   }
128 
testElapsed_notRunning()129   public void testElapsed_notRunning() {
130     ticker.advance(1);
131     stopwatch.start();
132     ticker.advance(4);
133     stopwatch.stop();
134     ticker.advance(9);
135     assertEquals(4, stopwatch.elapsed(NANOSECONDS));
136   }
137 
testElapsed_multipleSegments()138   public void testElapsed_multipleSegments() {
139     stopwatch.start();
140     ticker.advance(9);
141     stopwatch.stop();
142 
143     ticker.advance(16);
144 
145     stopwatch.start();
146     assertEquals(9, stopwatch.elapsed(NANOSECONDS));
147     ticker.advance(25);
148     assertEquals(34, stopwatch.elapsed(NANOSECONDS));
149 
150     stopwatch.stop();
151     ticker.advance(36);
152     assertEquals(34, stopwatch.elapsed(NANOSECONDS));
153   }
154 
testElapsed_micros()155   public void testElapsed_micros() {
156     stopwatch.start();
157     ticker.advance(999);
158     assertEquals(0, stopwatch.elapsed(MICROSECONDS));
159     ticker.advance(1);
160     assertEquals(1, stopwatch.elapsed(MICROSECONDS));
161   }
162 
testElapsed_millis()163   public void testElapsed_millis() {
164     stopwatch.start();
165     ticker.advance(999999);
166     assertEquals(0, stopwatch.elapsed(MILLISECONDS));
167     ticker.advance(1);
168     assertEquals(1, stopwatch.elapsed(MILLISECONDS));
169   }
170 
testElapsedMillis()171   public void testElapsedMillis() {
172     stopwatch.start();
173     ticker.advance(999999);
174     assertEquals(0, stopwatch.elapsed(MILLISECONDS));
175     ticker.advance(1);
176     assertEquals(1, stopwatch.elapsed(MILLISECONDS));
177   }
178 
testElapsedMillis_whileRunning()179   public void testElapsedMillis_whileRunning() {
180     ticker.advance(78000000);
181     stopwatch.start();
182     assertEquals(0, stopwatch.elapsed(MILLISECONDS));
183 
184     ticker.advance(345000000);
185     assertEquals(345, stopwatch.elapsed(MILLISECONDS));
186   }
187 
testElapsedMillis_notRunning()188   public void testElapsedMillis_notRunning() {
189     ticker.advance(1000000);
190     stopwatch.start();
191     ticker.advance(4000000);
192     stopwatch.stop();
193     ticker.advance(9000000);
194     assertEquals(4, stopwatch.elapsed(MILLISECONDS));
195   }
196 
testElapsedMillis_multipleSegments()197   public void testElapsedMillis_multipleSegments() {
198     stopwatch.start();
199     ticker.advance(9000000);
200     stopwatch.stop();
201 
202     ticker.advance(16000000);
203 
204     stopwatch.start();
205     assertEquals(9, stopwatch.elapsed(MILLISECONDS));
206     ticker.advance(25000000);
207     assertEquals(34, stopwatch.elapsed(MILLISECONDS));
208 
209     stopwatch.stop();
210     ticker.advance(36000000);
211     assertEquals(34, stopwatch.elapsed(MILLISECONDS));
212   }
213 
214   @GwtIncompatible("String.format()")
testToString()215   public void testToString() {
216     stopwatch.start();
217     assertEquals("0.000 ns", stopwatch.toString());
218     ticker.advance(1);
219     assertEquals("1.000 ns", stopwatch.toString());
220     ticker.advance(998);
221     assertEquals("999.0 ns", stopwatch.toString());
222     ticker.advance(1);
223     assertEquals("1.000 \u03bcs", stopwatch.toString());
224     ticker.advance(1);
225     assertEquals("1.001 \u03bcs", stopwatch.toString());
226     ticker.advance(8998);
227     assertEquals("9.999 \u03bcs", stopwatch.toString());
228     stopwatch.reset();
229     stopwatch.start();
230     ticker.advance(1234567);
231     assertEquals("1.235 ms", stopwatch.toString());
232     stopwatch.reset();
233     stopwatch.start();
234     ticker.advance(5000000000L);
235     assertEquals("5.000 s", stopwatch.toString());
236     stopwatch.reset();
237     stopwatch.start();
238     ticker.advance((long) (1.5 * 60 * 1000000000L));
239     assertEquals("1.500 min", stopwatch.toString());
240     stopwatch.reset();
241     stopwatch.start();
242     ticker.advance((long) (2.5 * 60 * 60 * 1000000000L));
243     assertEquals("2.500 h", stopwatch.toString());
244     stopwatch.reset();
245     stopwatch.start();
246     ticker.advance((long) (7.25 * 24 * 60 * 60 * 1000000000L));
247     assertEquals("7.250 d", stopwatch.toString());
248   }
249 
250 }
251