mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-03 04:07:35 +03:00
introduce a logging.CloseReason for version negotiation errors
This commit is contained in:
parent
3bce408c8d
commit
5208845191
5 changed files with 55 additions and 6 deletions
|
@ -13,6 +13,7 @@ type CloseReason struct {
|
|||
|
||||
timeout *TimeoutReason
|
||||
statelessResetToken *StatelessResetToken
|
||||
versions []VersionNumber
|
||||
}
|
||||
|
||||
// NewApplicationCloseReason creates a new CloseReason for an application error.
|
||||
|
@ -35,6 +36,11 @@ func NewStatelessResetCloseReason(token StatelessResetToken) CloseReason {
|
|||
return CloseReason{statelessResetToken: &token}
|
||||
}
|
||||
|
||||
// NewVersionNegotiationError creates a new CloseReason for a version negotiation error.
|
||||
func NewVersionNegotiationError(versions []VersionNumber) CloseReason {
|
||||
return CloseReason{versions: versions}
|
||||
}
|
||||
|
||||
// ApplicationError gets the application error.
|
||||
func (r *CloseReason) ApplicationError() (errorCode ApplicationError, remote bool, ok bool) {
|
||||
if r.applicationError == nil {
|
||||
|
@ -66,3 +72,7 @@ func (r *CloseReason) StatelessReset() (token StatelessResetToken, ok bool) {
|
|||
}
|
||||
return *r.statelessResetToken, true
|
||||
}
|
||||
|
||||
func (r *CloseReason) VersionNegotiation() (versions []VersionNumber, ok bool) {
|
||||
return r.versions, len(r.versions) > 0
|
||||
}
|
||||
|
|
|
@ -26,6 +26,11 @@ var _ = Describe("Close Reason", func() {
|
|||
ExpectWithOffset(1, ok).To(BeFalse())
|
||||
}
|
||||
|
||||
checkNotVN := func(r CloseReason) {
|
||||
_, ok := r.VersionNegotiation()
|
||||
ExpectWithOffset(1, ok).To(BeFalse())
|
||||
}
|
||||
|
||||
It("application errors", func() {
|
||||
r := NewApplicationCloseReason(1337, true)
|
||||
errorCode, remote, ok := r.ApplicationError()
|
||||
|
@ -35,6 +40,7 @@ var _ = Describe("Close Reason", func() {
|
|||
checkNotTransportError(r)
|
||||
checkNotStatelessReset(r)
|
||||
checkNotTimeout(r)
|
||||
checkNotVN(r)
|
||||
})
|
||||
|
||||
It("transport errors", func() {
|
||||
|
@ -46,6 +52,7 @@ var _ = Describe("Close Reason", func() {
|
|||
checkNotApplicationError(r)
|
||||
checkNotStatelessReset(r)
|
||||
checkNotTimeout(r)
|
||||
checkNotVN(r)
|
||||
})
|
||||
|
||||
It("transport errors", func() {
|
||||
|
@ -55,7 +62,7 @@ var _ = Describe("Close Reason", func() {
|
|||
Expect(timeout).To(Equal(TimeoutReasonIdle))
|
||||
checkNotApplicationError(r)
|
||||
checkNotTransportError(r)
|
||||
checkNotStatelessReset(r)
|
||||
checkNotVN(r)
|
||||
})
|
||||
|
||||
It("stateless resets", func() {
|
||||
|
@ -66,5 +73,17 @@ var _ = Describe("Close Reason", func() {
|
|||
checkNotApplicationError(r)
|
||||
checkNotTransportError(r)
|
||||
checkNotTimeout(r)
|
||||
checkNotVN(r)
|
||||
})
|
||||
|
||||
It("version negotiation errors", func() {
|
||||
r := NewVersionNegotiationError([]VersionNumber{1, 2, 3})
|
||||
vn, ok := r.VersionNegotiation()
|
||||
Expect(ok).To(BeTrue())
|
||||
Expect(vn).To(Equal([]VersionNumber{1, 2, 3}))
|
||||
checkNotApplicationError(r)
|
||||
checkNotTransportError(r)
|
||||
checkNotTimeout(r)
|
||||
checkNotStatelessReset(r)
|
||||
})
|
||||
})
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue