-
Notifications
You must be signed in to change notification settings - Fork 68
/
Copy pathtimeout.cc
48 lines (38 loc) · 1.43 KB
/
timeout.cc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
// Copyright 2016 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "chrome/test/chromedriver/net/timeout.h"
#include <algorithm>
#include "base/logging.h"
#include "base/notreached.h"
Timeout::Timeout() : start_(base::TimeTicks::Now()) {
}
Timeout::Timeout(const base::TimeDelta& duration) : Timeout() {
SetDuration(duration);
}
Timeout::Timeout(const base::TimeDelta& duration, const Timeout* outer)
: Timeout(duration) {
if (outer && !outer->deadline_.is_null())
deadline_ = std::min(outer->deadline_, deadline_);
}
void Timeout::SetDuration(const base::TimeDelta& duration) {
DCHECK(!start_.is_null());
if (deadline_.is_null()) {
deadline_ = start_ + duration;
} else if (deadline_ - start_ != duration) {
NOTREACHED() << "Timeout::SetDuration was called with a duration different"
" from what was already set: "
<< duration << " vs. " << deadline_ - start_ << " (original).";
}
}
bool Timeout::IsExpired() const {
return GetRemainingTime() <= base::TimeDelta();
}
base::TimeDelta Timeout::GetDuration() const {
return !deadline_.is_null() ? deadline_ - start_
: base::TimeDelta::Max();
}
base::TimeDelta Timeout::GetRemainingTime() const {
return !deadline_.is_null() ? deadline_ - base::TimeTicks::Now()
: base::TimeDelta::Max();
}