blob: 38b58f296c02ae7d82c89c963ebe2643ff79e50a [file] [log] [blame]
Jan Tattermuschd0c1bfa2015-10-22 19:14:57 -07001#region Copyright notice and license
2
Jan Tattermusch7897ae92017-06-07 22:57:36 +02003// Copyright 2015 gRPC authors.
Jan Tattermuschd0c1bfa2015-10-22 19:14:57 -07004//
Jan Tattermusch7897ae92017-06-07 22:57:36 +02005// Licensed under the Apache License, Version 2.0 (the "License");
6// you may not use this file except in compliance with the License.
7// You may obtain a copy of the License at
Jan Tattermuschd0c1bfa2015-10-22 19:14:57 -07008//
Jan Tattermusch7897ae92017-06-07 22:57:36 +02009// http://www.apache.org/licenses/LICENSE-2.0
Jan Tattermuschd0c1bfa2015-10-22 19:14:57 -070010//
Jan Tattermusch7897ae92017-06-07 22:57:36 +020011// Unless required by applicable law or agreed to in writing, software
12// distributed under the License is distributed on an "AS IS" BASIS,
13// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14// See the License for the specific language governing permissions and
15// limitations under the License.
Jan Tattermuschd0c1bfa2015-10-22 19:14:57 -070016
17#endregion
18
19using System;
20using System.Collections.Generic;
21using System.Diagnostics;
22using System.IO;
23using System.Linq;
24using System.Text.RegularExpressions;
25using System.Threading;
26using System.Threading.Tasks;
27using Google.Protobuf;
28using Grpc.Core;
29using Grpc.Core.Utils;
30using NUnit.Framework;
31using Grpc.Testing;
32
33namespace Grpc.IntegrationTesting
34{
35 /// <summary>
36 /// Snapshottable wall clock stopwatch.
37 /// </summary>
38 public class WallClockStopwatch
39 {
40 long startTicks;
41
42 public WallClockStopwatch()
43 {
44 this.startTicks = DateTime.UtcNow.Ticks;
45 }
46
47 public TimeSpan GetElapsedSnapshot(bool reset)
48 {
49 var utcNow = DateTime.UtcNow;
50
51 long oldStartTicks;
52 if (reset)
53 {
54 oldStartTicks = Interlocked.Exchange(ref this.startTicks, utcNow.Ticks);
55 }
56 else
57 {
58 oldStartTicks = this.startTicks;
59 }
60 return utcNow - new DateTime(oldStartTicks, DateTimeKind.Utc);
61 }
62 }
63}