add the stylecheck linter

This commit is contained in:
Marten Seemann 2019-09-13 13:53:21 +07:00
parent ab2b26a5cb
commit 6b22f36d82
19 changed files with 30 additions and 20 deletions

View file

@ -19,6 +19,7 @@ linters:
- prealloc - prealloc
- scopelint - scopelint
- staticcheck - staticcheck
- stylecheck
- structcheck - structcheck
- unconvert - unconvert
- unparam - unparam

View file

@ -341,6 +341,7 @@ func (c *client) handleVersionNegotiationPacket(p *receivedPacket) {
c.logger.Infof("Received a Version Negotiation packet. Supported Versions: %s", hdr.SupportedVersions) c.logger.Infof("Received a Version Negotiation packet. Supported Versions: %s", hdr.SupportedVersions)
newVersion, ok := protocol.ChooseSupportedVersion(c.config.Versions, hdr.SupportedVersions) newVersion, ok := protocol.ChooseSupportedVersion(c.config.Versions, hdr.SupportedVersions)
if !ok { if !ok {
//nolint:stylecheck
c.session.destroy(fmt.Errorf("No compatible QUIC version found. We support %s, server offered %s", c.config.Versions, hdr.SupportedVersions)) c.session.destroy(fmt.Errorf("No compatible QUIC version found. We support %s, server offered %s", c.config.Versions, hdr.SupportedVersions))
c.logger.Debugf("No compatible QUIC version found.") c.logger.Debugf("No compatible QUIC version found.")
return return

View file

@ -18,7 +18,7 @@ type frameSorter struct {
gaps *utils.ByteIntervalList gaps *utils.ByteIntervalList
} }
var errDuplicateStreamData = errors.New("Duplicate Stream Data") var errDuplicateStreamData = errors.New("duplicate stream data")
func newFrameSorter() *frameSorter { func newFrameSorter() *frameSorter {
s := frameSorter{ s := frameSorter{
@ -146,7 +146,7 @@ func (s *frameSorter) push(data []byte, offset protocol.ByteCount, doneCb func()
} }
if s.gaps.Len() > protocol.MaxStreamFrameSorterGaps { if s.gaps.Len() > protocol.MaxStreamFrameSorterGaps {
return errors.New("Too many gaps in received data") return errors.New("too many gaps in received data")
} }
if wasCut && len(data) < protocol.MinStreamFrameBufferSize { if wasCut && len(data) < protocol.MinStreamFrameBufferSize {

View file

@ -555,7 +555,7 @@ var _ = Describe("frame sorter", func() {
} }
Expect(s.gaps.Len()).To(Equal(protocol.MaxStreamFrameSorterGaps)) Expect(s.gaps.Len()).To(Equal(protocol.MaxStreamFrameSorterGaps))
err := s.Push([]byte("foobar"), protocol.ByteCount(protocol.MaxStreamFrameSorterGaps*7)+100, nil) err := s.Push([]byte("foobar"), protocol.ByteCount(protocol.MaxStreamFrameSorterGaps*7)+100, nil)
Expect(err).To(MatchError("Too many gaps in received data")) Expect(err).To(MatchError("too many gaps in received data"))
}) })
}) })
}) })

View file

@ -44,7 +44,7 @@ var _ = Describe("Stream Cancelations", func() {
str, err := sess.OpenUniStreamSync(context.Background()) str, err := sess.OpenUniStreamSync(context.Background())
Expect(err).ToNot(HaveOccurred()) Expect(err).ToNot(HaveOccurred())
if _, err = str.Write(testserver.PRData); err != nil { if _, err = str.Write(testserver.PRData); err != nil {
Expect(err).To(MatchError(fmt.Sprintf("Stream %d was reset with error code %d", str.StreamID(), str.StreamID()))) Expect(err).To(MatchError(fmt.Sprintf("stream %d was reset with error code %d", str.StreamID(), str.StreamID())))
atomic.AddInt32(&canceledCounter, 1) atomic.AddInt32(&canceledCounter, 1)
return return
} }
@ -174,7 +174,7 @@ var _ = Describe("Stream Cancelations", func() {
data, err := ioutil.ReadAll(str) data, err := ioutil.ReadAll(str)
if err != nil { if err != nil {
atomic.AddInt32(&counter, 1) atomic.AddInt32(&counter, 1)
Expect(err).To(MatchError(fmt.Sprintf("Stream %d was reset with error code %d", str.StreamID(), str.StreamID()))) Expect(err).To(MatchError(fmt.Sprintf("stream %d was reset with error code %d", str.StreamID(), str.StreamID())))
return return
} }
Expect(data).To(Equal(testserver.PRData)) Expect(data).To(Equal(testserver.PRData))
@ -281,7 +281,7 @@ var _ = Describe("Stream Cancelations", func() {
return return
} }
if _, err = str.Write(testserver.PRData); err != nil { if _, err = str.Write(testserver.PRData); err != nil {
Expect(err).To(MatchError(fmt.Sprintf("Stream %d was reset with error code %d", str.StreamID(), str.StreamID()))) Expect(err).To(MatchError(fmt.Sprintf("stream %d was reset with error code %d", str.StreamID(), str.StreamID())))
return return
} }
Expect(str.Close()).To(Succeed()) Expect(str.Close()).To(Succeed())
@ -314,7 +314,7 @@ var _ = Describe("Stream Cancelations", func() {
} }
data, err := ioutil.ReadAll(str) data, err := ioutil.ReadAll(str)
if err != nil { if err != nil {
Expect(err).To(MatchError(fmt.Sprintf("Stream %d was reset with error code %d", str.StreamID(), str.StreamID()))) Expect(err).To(MatchError(fmt.Sprintf("stream %d was reset with error code %d", str.StreamID(), str.StreamID())))
return return
} }
atomic.AddInt32(&counter, 1) atomic.AddInt32(&counter, 1)
@ -355,7 +355,7 @@ var _ = Describe("Stream Cancelations", func() {
length = int(rand.Int31n(int32(len(testserver.PRData) - 1))) length = int(rand.Int31n(int32(len(testserver.PRData) - 1)))
} }
if _, err = str.Write(testserver.PRData[:length]); err != nil { if _, err = str.Write(testserver.PRData[:length]); err != nil {
Expect(err).To(MatchError(fmt.Sprintf("Stream %d was reset with error code %d", str.StreamID(), str.StreamID()))) Expect(err).To(MatchError(fmt.Sprintf("stream %d was reset with error code %d", str.StreamID(), str.StreamID())))
return return
} }
if length < len(testserver.PRData) { if length < len(testserver.PRData) {
@ -396,7 +396,7 @@ var _ = Describe("Stream Cancelations", func() {
} }
data, err := ioutil.ReadAll(r) data, err := ioutil.ReadAll(r)
if err != nil { if err != nil {
Expect(err).To(MatchError(fmt.Sprintf("Stream %d was reset with error code %d", str.StreamID(), str.StreamID()))) Expect(err).To(MatchError(fmt.Sprintf("stream %d was reset with error code %d", str.StreamID(), str.StreamID())))
return return
} }
Expect(data).To(Equal(testserver.PRData[:length])) Expect(data).To(Equal(testserver.PRData[:length]))

View file

@ -9,7 +9,9 @@ import (
"github.com/lucas-clemente/quic-go/internal/utils" "github.com/lucas-clemente/quic-go/internal/utils"
//nolint:stylecheck
. "github.com/onsi/ginkgo" . "github.com/onsi/ginkgo"
//nolint:stylecheck
. "github.com/onsi/gomega" . "github.com/onsi/gomega"
) )

View file

@ -12,7 +12,9 @@ import (
"github.com/lucas-clemente/quic-go/internal/protocol" "github.com/lucas-clemente/quic-go/internal/protocol"
"github.com/lucas-clemente/quic-go/internal/testdata" "github.com/lucas-clemente/quic-go/internal/testdata"
//nolint:stylecheck
. "github.com/onsi/ginkgo" . "github.com/onsi/ginkgo"
//nolint:stylecheck
. "github.com/onsi/gomega" . "github.com/onsi/gomega"
) )

View file

@ -54,7 +54,7 @@ func (s *tokenProtectorImpl) NewToken(data []byte) ([]byte, error) {
// DecodeToken decodes a token. // DecodeToken decodes a token.
func (s *tokenProtectorImpl) DecodeToken(p []byte) ([]byte, error) { func (s *tokenProtectorImpl) DecodeToken(p []byte) ([]byte, error) {
if len(p) < tokenNonceSize { if len(p) < tokenNonceSize {
return nil, fmt.Errorf("Token too short: %d", len(p)) return nil, fmt.Errorf("token too short: %d", len(p))
} }
nonce := p[:tokenNonceSize] nonce := p[:tokenNonceSize]
aead, aeadNonce, err := s.createAEAD(nonce) aead, aeadNonce, err := s.createAEAD(nonce)

View file

@ -34,6 +34,6 @@ var _ = Describe("Token Protector", func() {
It("errors when decoding too short tokens", func() { It("errors when decoding too short tokens", func() {
_, err := tp.DecodeToken([]byte("foobar")) _, err := tp.DecodeToken([]byte("foobar"))
Expect(err).To(MatchError("Token too short: 6")) Expect(err).To(MatchError("token too short: 6"))
}) })
}) })

View file

@ -215,9 +215,11 @@ func (h *Header) parseLongHeader(b *bytes.Reader) error {
func (h *Header) parseVersionNegotiationPacket(b *bytes.Reader) error { func (h *Header) parseVersionNegotiationPacket(b *bytes.Reader) error {
if b.Len() == 0 { if b.Len() == 0 {
//nolint:stylecheck
return errors.New("Version Negotiation packet has empty version list") return errors.New("Version Negotiation packet has empty version list")
} }
if b.Len()%4 != 0 { if b.Len()%4 != 0 {
//nolint:stylecheck
return errors.New("Version Negotiation packet has a version list with an invalid length") return errors.New("Version Negotiation packet has a version list with an invalid length")
} }
h.SupportedVersions = make([]protocol.VersionNumber, b.Len()/4) h.SupportedVersions = make([]protocol.VersionNumber, b.Len()/4)

View file

@ -32,6 +32,7 @@ func parseNewConnectionIDFrame(r *bytes.Reader, _ protocol.VersionNumber) (*NewC
return nil, err return nil, err
} }
if ret > seq { if ret > seq {
//nolint:stylecheck
return nil, fmt.Errorf("Retire Prior To value (%d) larger than Sequence Number (%d)", ret, seq) return nil, fmt.Errorf("Retire Prior To value (%d) larger than Sequence Number (%d)", ret, seq)
} }
connIDLen, err := r.ReadByte() connIDLen, err := r.ReadByte()

View file

@ -26,7 +26,7 @@ func parseNewTokenFrame(r *bytes.Reader, _ protocol.VersionNumber) (*NewTokenFra
return nil, io.EOF return nil, io.EOF
} }
if tokenLen == 0 { if tokenLen == 0 {
return nil, errors.New("Token must not be empty.") return nil, errors.New("token must not be empty")
} }
token := make([]byte, int(tokenLen)) token := make([]byte, int(tokenLen))
if _, err := io.ReadFull(r, token); err != nil { if _, err := io.ReadFull(r, token); err != nil {

View file

@ -29,7 +29,7 @@ var _ = Describe("NEW_TOKEN frame", func() {
data = append(data, encodeVarInt(uint64(0))...) data = append(data, encodeVarInt(uint64(0))...)
b := bytes.NewReader(data) b := bytes.NewReader(data)
_, err := parseNewTokenFrame(b, protocol.VersionWhatever) _, err := parseNewTokenFrame(b, protocol.VersionWhatever)
Expect(err).To(MatchError("Token must not be empty.")) Expect(err).To(MatchError("token must not be empty"))
}) })
It("errors on EOFs", func() { It("errors on EOFs", func() {

View file

@ -139,6 +139,7 @@ func (u *packetUnpacker) unpack(hd headerDecryptor, hdr *wire.Header, data []byt
hdrLen := int(hdr.ParsedLen()) hdrLen := int(hdr.ParsedLen())
if len(data) < hdrLen+4+16 { if len(data) < hdrLen+4+16 {
//nolint:stylecheck
return nil, fmt.Errorf("Packet too small. Expected at least 20 bytes after the header, got %d", len(data)-hdrLen) return nil, fmt.Errorf("Packet too small. Expected at least 20 bytes after the header, got %d", len(data)-hdrLen)
} }
// The packet number can be up to 4 bytes long, but we won't know the length until we decrypt it. // The packet number can be up to 4 bytes long, but we won't know the length until we decrypt it.

View file

@ -70,7 +70,7 @@ func (t *tracer) Emit(connID protocol.ConnectionID) ([]byte, error) {
func (t *tracer) emitByConnIDAsString(connID string) ([]byte, error) { func (t *tracer) emitByConnIDAsString(connID string) ([]byte, error) {
events, ok := t.events[connID] events, ok := t.events[connID]
if !ok { if !ok {
return nil, fmt.Errorf("No trace found for connection ID %s", connID) return nil, fmt.Errorf("no trace found for connection ID %s", connID)
} }
trace := &pb.Trace{ trace := &pb.Trace{
DestinationConnectionId: []byte{1, 2, 3, 4, 5, 6, 7, 8}, DestinationConnectionId: []byte{1, 2, 3, 4, 5, 6, 7, 8},

View file

@ -276,7 +276,7 @@ func (s *receiveStream) handleResetStreamFrameImpl(frame *wire.ResetStreamFrame)
s.resetRemotely = true s.resetRemotely = true
s.resetRemotelyErr = streamCanceledError{ s.resetRemotelyErr = streamCanceledError{
errorCode: frame.ErrorCode, errorCode: frame.ErrorCode,
error: fmt.Errorf("Stream %d was reset with error code %d", s.streamID, frame.ErrorCode), error: fmt.Errorf("stream %d was reset with error code %d", s.streamID, frame.ErrorCode),
} }
s.signalRead() s.signalRead()
return true, nil return true, nil

View file

@ -552,7 +552,7 @@ var _ = Describe("Receive Stream", func() {
go func() { go func() {
defer GinkgoRecover() defer GinkgoRecover()
_, err := strWithTimeout.Read([]byte{0}) _, err := strWithTimeout.Read([]byte{0})
Expect(err).To(MatchError("Stream 1337 was reset with error code 1234")) Expect(err).To(MatchError("stream 1337 was reset with error code 1234"))
Expect(err).To(BeAssignableToTypeOf(streamCanceledError{})) Expect(err).To(BeAssignableToTypeOf(streamCanceledError{}))
Expect(err.(streamCanceledError).Canceled()).To(BeTrue()) Expect(err.(streamCanceledError).Canceled()).To(BeTrue())
Expect(err.(streamCanceledError).ErrorCode()).To(Equal(protocol.ApplicationErrorCode(1234))) Expect(err.(streamCanceledError).ErrorCode()).To(Equal(protocol.ApplicationErrorCode(1234)))
@ -576,7 +576,7 @@ var _ = Describe("Receive Stream", func() {
) )
Expect(str.handleResetStreamFrame(rst)).To(Succeed()) Expect(str.handleResetStreamFrame(rst)).To(Succeed())
_, err := strWithTimeout.Read([]byte{0}) _, err := strWithTimeout.Read([]byte{0})
Expect(err).To(MatchError("Stream 1337 was reset with error code 1234")) Expect(err).To(MatchError("stream 1337 was reset with error code 1234"))
Expect(err).To(BeAssignableToTypeOf(streamCanceledError{})) Expect(err).To(BeAssignableToTypeOf(streamCanceledError{}))
Expect(err.(streamCanceledError).Canceled()).To(BeTrue()) Expect(err.(streamCanceledError).Canceled()).To(BeTrue())
Expect(err.(streamCanceledError).ErrorCode()).To(Equal(protocol.ApplicationErrorCode(1234))) Expect(err.(streamCanceledError).ErrorCode()).To(Equal(protocol.ApplicationErrorCode(1234)))

View file

@ -366,7 +366,7 @@ func (s *sendStream) handleMaxStreamDataFrame(frame *wire.MaxStreamDataFrame) {
func (s *sendStream) handleStopSendingFrame(frame *wire.StopSendingFrame) { func (s *sendStream) handleStopSendingFrame(frame *wire.StopSendingFrame) {
writeErr := streamCanceledError{ writeErr := streamCanceledError{
errorCode: frame.ErrorCode, errorCode: frame.ErrorCode,
error: fmt.Errorf("Stream %d was reset with error code %d", s.streamID, frame.ErrorCode), error: fmt.Errorf("stream %d was reset with error code %d", s.streamID, frame.ErrorCode),
} }
s.cancelWriteImpl(frame.ErrorCode, writeErr) s.cancelWriteImpl(frame.ErrorCode, writeErr)
} }

View file

@ -641,7 +641,7 @@ var _ = Describe("Send Stream", func() {
go func() { go func() {
defer GinkgoRecover() defer GinkgoRecover()
_, err := str.Write([]byte("foobar")) _, err := str.Write([]byte("foobar"))
Expect(err).To(MatchError("Stream 1337 was reset with error code 123")) Expect(err).To(MatchError("stream 1337 was reset with error code 123"))
Expect(err).To(BeAssignableToTypeOf(streamCanceledError{})) Expect(err).To(BeAssignableToTypeOf(streamCanceledError{}))
Expect(err.(streamCanceledError).Canceled()).To(BeTrue()) Expect(err.(streamCanceledError).Canceled()).To(BeTrue())
Expect(err.(streamCanceledError).ErrorCode()).To(Equal(protocol.ApplicationErrorCode(123))) Expect(err.(streamCanceledError).ErrorCode()).To(Equal(protocol.ApplicationErrorCode(123)))
@ -663,7 +663,7 @@ var _ = Describe("Send Stream", func() {
ErrorCode: 123, ErrorCode: 123,
}) })
_, err := str.Write([]byte("foobar")) _, err := str.Write([]byte("foobar"))
Expect(err).To(MatchError("Stream 1337 was reset with error code 123")) Expect(err).To(MatchError("stream 1337 was reset with error code 123"))
Expect(err).To(BeAssignableToTypeOf(streamCanceledError{})) Expect(err).To(BeAssignableToTypeOf(streamCanceledError{}))
Expect(err.(streamCanceledError).Canceled()).To(BeTrue()) Expect(err.(streamCanceledError).Canceled()).To(BeTrue())
Expect(err.(streamCanceledError).ErrorCode()).To(Equal(protocol.ApplicationErrorCode(123))) Expect(err.(streamCanceledError).ErrorCode()).To(Equal(protocol.ApplicationErrorCode(123)))