mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-03 20:27:35 +03:00
record InSlowStart and InRecovery
This commit is contained in:
parent
73f83ca4bb
commit
fcb0d6cfdc
5 changed files with 41 additions and 5 deletions
|
@ -694,5 +694,7 @@ func (h *sentPacketHandler) GetStats() *quictrace.TransportState {
|
|||
LatestRTT: h.rttStats.LatestRTT(),
|
||||
BytesInFlight: h.bytesInFlight,
|
||||
CongestionWindow: h.congestion.GetCongestionWindow(),
|
||||
InSlowStart: h.congestion.InSlowStart(),
|
||||
InRecovery: h.congestion.InRecovery(),
|
||||
}
|
||||
}
|
||||
|
|
|
@ -20,5 +20,7 @@ type SendAlgorithm interface {
|
|||
// A SendAlgorithmWithDebugInfos is a SendAlgorithm that exposes some debug infos
|
||||
type SendAlgorithmWithDebugInfos interface {
|
||||
SendAlgorithm
|
||||
InSlowStart() bool
|
||||
InRecovery() bool
|
||||
GetCongestionWindow() protocol.ByteCount
|
||||
}
|
||||
|
|
|
@ -63,6 +63,34 @@ func (mr *MockSendAlgorithmWithDebugInfosMockRecorder) GetCongestionWindow() *go
|
|||
return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "GetCongestionWindow", reflect.TypeOf((*MockSendAlgorithmWithDebugInfos)(nil).GetCongestionWindow))
|
||||
}
|
||||
|
||||
// InRecovery mocks base method
|
||||
func (m *MockSendAlgorithmWithDebugInfos) InRecovery() bool {
|
||||
m.ctrl.T.Helper()
|
||||
ret := m.ctrl.Call(m, "InRecovery")
|
||||
ret0, _ := ret[0].(bool)
|
||||
return ret0
|
||||
}
|
||||
|
||||
// InRecovery indicates an expected call of InRecovery
|
||||
func (mr *MockSendAlgorithmWithDebugInfosMockRecorder) InRecovery() *gomock.Call {
|
||||
mr.mock.ctrl.T.Helper()
|
||||
return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "InRecovery", reflect.TypeOf((*MockSendAlgorithmWithDebugInfos)(nil).InRecovery))
|
||||
}
|
||||
|
||||
// InSlowStart mocks base method
|
||||
func (m *MockSendAlgorithmWithDebugInfos) InSlowStart() bool {
|
||||
m.ctrl.T.Helper()
|
||||
ret := m.ctrl.Call(m, "InSlowStart")
|
||||
ret0, _ := ret[0].(bool)
|
||||
return ret0
|
||||
}
|
||||
|
||||
// InSlowStart indicates an expected call of InSlowStart
|
||||
func (mr *MockSendAlgorithmWithDebugInfosMockRecorder) InSlowStart() *gomock.Call {
|
||||
mr.mock.ctrl.T.Helper()
|
||||
return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "InSlowStart", reflect.TypeOf((*MockSendAlgorithmWithDebugInfos)(nil).InSlowStart))
|
||||
}
|
||||
|
||||
// MaybeExitSlowStart mocks base method
|
||||
func (m *MockSendAlgorithmWithDebugInfos) MaybeExitSlowStart() {
|
||||
m.ctrl.T.Helper()
|
||||
|
|
|
@ -45,4 +45,6 @@ type TransportState struct {
|
|||
|
||||
BytesInFlight protocol.ByteCount
|
||||
CongestionWindow protocol.ByteCount
|
||||
InSlowStart bool
|
||||
InRecovery bool
|
||||
}
|
||||
|
|
|
@ -173,12 +173,14 @@ func getFrames(wframes []wire.Frame) []*pb.Frame {
|
|||
func getTransportState(state *TransportState) *pb.TransportState {
|
||||
bytesInFlight := uint64(state.BytesInFlight)
|
||||
congestionWindow := uint64(state.CongestionWindow)
|
||||
ccs := fmt.Sprintf("InSlowStart: %t, InRecovery: %t", state.InSlowStart, state.InRecovery)
|
||||
return &pb.TransportState{
|
||||
MinRttUs: durationToUs(state.MinRTT),
|
||||
SmoothedRttUs: durationToUs(state.SmoothedRTT),
|
||||
LastRttUs: durationToUs(state.LatestRTT),
|
||||
InFlightBytes: &bytesInFlight,
|
||||
CwndBytes: &congestionWindow,
|
||||
MinRttUs: durationToUs(state.MinRTT),
|
||||
SmoothedRttUs: durationToUs(state.SmoothedRTT),
|
||||
LastRttUs: durationToUs(state.LatestRTT),
|
||||
InFlightBytes: &bytesInFlight,
|
||||
CwndBytes: &congestionWindow,
|
||||
CongestionControlState: &ccs,
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue