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