xref: /aosp_15_r20/build/soong/ui/metrics/event_test.go (revision 333d2b3687b3a337dbcca9d65000bca186795e39)
1*333d2b36SAndroid Build Coastguard Worker// Copyright 2020 Google Inc. All Rights Reserved.
2*333d2b36SAndroid Build Coastguard Worker//
3*333d2b36SAndroid Build Coastguard Worker// Licensed under the Apache License, Version 2.0 (the "License");
4*333d2b36SAndroid Build Coastguard Worker// you may not use this file except in compliance with the License.
5*333d2b36SAndroid Build Coastguard Worker// You may obtain a copy of the License at
6*333d2b36SAndroid Build Coastguard Worker//
7*333d2b36SAndroid Build Coastguard Worker//   http://www.apache.org/licenses/LICENSE-2.0
8*333d2b36SAndroid Build Coastguard Worker//
9*333d2b36SAndroid Build Coastguard Worker// Unless required by applicable law or agreed to in writing, software
10*333d2b36SAndroid Build Coastguard Worker// distributed under the License is distributed on an "AS IS" BASIS,
11*333d2b36SAndroid Build Coastguard Worker// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*333d2b36SAndroid Build Coastguard Worker// See the License for the specific language governing permissions and
13*333d2b36SAndroid Build Coastguard Worker// limitations under the License.
14*333d2b36SAndroid Build Coastguard Worker
15*333d2b36SAndroid Build Coastguard Workerpackage metrics
16*333d2b36SAndroid Build Coastguard Worker
17*333d2b36SAndroid Build Coastguard Workerimport (
18*333d2b36SAndroid Build Coastguard Worker	"testing"
19*333d2b36SAndroid Build Coastguard Worker	"time"
20*333d2b36SAndroid Build Coastguard Worker)
21*333d2b36SAndroid Build Coastguard Worker
22*333d2b36SAndroid Build Coastguard Workerfunc TestEnd(t *testing.T) {
23*333d2b36SAndroid Build Coastguard Worker	startTime := time.Date(2020, time.July, 13, 13, 0, 0, 0, time.UTC)
24*333d2b36SAndroid Build Coastguard Worker	dur := time.Nanosecond * 10
25*333d2b36SAndroid Build Coastguard Worker	initialNow := _now
26*333d2b36SAndroid Build Coastguard Worker	_now = func() time.Time { return startTime.Add(dur) }
27*333d2b36SAndroid Build Coastguard Worker	defer func() { _now = initialNow }()
28*333d2b36SAndroid Build Coastguard Worker
29*333d2b36SAndroid Build Coastguard Worker	et := &EventTracer{}
30*333d2b36SAndroid Build Coastguard Worker	et.push(&event{
31*333d2b36SAndroid Build Coastguard Worker		desc:  "test",
32*333d2b36SAndroid Build Coastguard Worker		name:  "test",
33*333d2b36SAndroid Build Coastguard Worker		start: startTime,
34*333d2b36SAndroid Build Coastguard Worker	})
35*333d2b36SAndroid Build Coastguard Worker
36*333d2b36SAndroid Build Coastguard Worker	perf := et.End()
37*333d2b36SAndroid Build Coastguard Worker	if perf.GetRealTime() != uint64(dur.Nanoseconds()) {
38*333d2b36SAndroid Build Coastguard Worker		t.Errorf("got %d, want %d nanoseconds for event duration", perf.GetRealTime(), dur.Nanoseconds())
39*333d2b36SAndroid Build Coastguard Worker	}
40*333d2b36SAndroid Build Coastguard Worker}
41*333d2b36SAndroid Build Coastguard Worker
42*333d2b36SAndroid Build Coastguard Workerfunc TestEndWithError(t *testing.T) {
43*333d2b36SAndroid Build Coastguard Worker	startTime := time.Date(2020, time.July, 13, 13, 0, 0, 0, time.UTC)
44*333d2b36SAndroid Build Coastguard Worker	dur := time.Nanosecond * 10
45*333d2b36SAndroid Build Coastguard Worker	initialNow := _now
46*333d2b36SAndroid Build Coastguard Worker	_now = func() time.Time { return startTime.Add(dur) }
47*333d2b36SAndroid Build Coastguard Worker	defer func() { _now = initialNow }()
48*333d2b36SAndroid Build Coastguard Worker
49*333d2b36SAndroid Build Coastguard Worker	err := "foobar"
50*333d2b36SAndroid Build Coastguard Worker	et := &EventTracer{}
51*333d2b36SAndroid Build Coastguard Worker	et.push(&event{
52*333d2b36SAndroid Build Coastguard Worker		desc:            "test",
53*333d2b36SAndroid Build Coastguard Worker		name:            "test",
54*333d2b36SAndroid Build Coastguard Worker		start:           startTime,
55*333d2b36SAndroid Build Coastguard Worker		nonZeroExitCode: true,
56*333d2b36SAndroid Build Coastguard Worker		errorMsg:        &err,
57*333d2b36SAndroid Build Coastguard Worker	})
58*333d2b36SAndroid Build Coastguard Worker
59*333d2b36SAndroid Build Coastguard Worker	perf := et.End()
60*333d2b36SAndroid Build Coastguard Worker	if msg := perf.GetErrorMessage(); msg != err {
61*333d2b36SAndroid Build Coastguard Worker		t.Errorf("got %q, want %q for even error message", msg, err)
62*333d2b36SAndroid Build Coastguard Worker	}
63*333d2b36SAndroid Build Coastguard Worker}
64