use the correct error code when checking for encryption level boundaries

This commit is contained in:
Marten Seemann 2019-11-23 12:05:18 +07:00
parent 92b898e811
commit aefd4f83ea
2 changed files with 3 additions and 2 deletions

View file

@ -6,6 +6,7 @@ import (
"io" "io"
"github.com/lucas-clemente/quic-go/internal/protocol" "github.com/lucas-clemente/quic-go/internal/protocol"
"github.com/lucas-clemente/quic-go/internal/qerr"
"github.com/lucas-clemente/quic-go/internal/utils" "github.com/lucas-clemente/quic-go/internal/utils"
"github.com/lucas-clemente/quic-go/internal/wire" "github.com/lucas-clemente/quic-go/internal/wire"
) )
@ -73,7 +74,7 @@ func (s *cryptoStreamImpl) HandleCryptoFrame(f *wire.CryptoFrame) error {
if s.finished { if s.finished {
if highestOffset > s.highestOffset { if highestOffset > s.highestOffset {
// reject crypto data received after this stream was already finished // reject crypto data received after this stream was already finished
return errors.New("received crypto data after change of encryption level") return qerr.Error(qerr.ProtocolViolation, "received crypto data after change of encryption level")
} }
// ignore data with a smaller offset than the highest received // ignore data with a smaller offset than the highest received
// could e.g. be a retransmission // could e.g. be a retransmission

View file

@ -119,7 +119,7 @@ var _ = Describe("Crypto Stream", func() {
err := str.HandleCryptoFrame(&wire.CryptoFrame{ err := str.HandleCryptoFrame(&wire.CryptoFrame{
Data: createHandshakeMessage(5), Data: createHandshakeMessage(5),
}) })
Expect(err).To(MatchError("received crypto data after change of encryption level")) Expect(err).To(MatchError("PROTOCOL_VIOLATION: received crypto data after change of encryption level"))
}) })
It("ignores crypto data below the maximum offset received before finishing", func() { It("ignores crypto data below the maximum offset received before finishing", func() {