Merge pull request #13131 from mmorel-35/patch-7

tsdb/tombstones: use Go standard errors package
This commit is contained in:
Julien Pivotto 2023-11-14 00:51:31 +01:00 committed by GitHub
commit f53af5c849
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -15,6 +15,7 @@ package tombstones
import (
"encoding/binary"
"errors"
"fmt"
"hash"
"hash/crc32"
@ -26,7 +27,6 @@ import (
"github.com/go-kit/log"
"github.com/go-kit/log/level"
"github.com/pkg/errors"
"github.com/prometheus/prometheus/storage"
"github.com/prometheus/prometheus/tsdb/encoding"
@ -109,17 +109,17 @@ func WriteFile(logger log.Logger, dir string, tr Reader) (int64, error) {
bytes, err := Encode(tr)
if err != nil {
return 0, errors.Wrap(err, "encoding tombstones")
return 0, fmt.Errorf("encoding tombstones: %w", err)
}
// Ignore first byte which is the format type. We do this for compatibility.
if _, err := hash.Write(bytes[tombstoneFormatVersionSize:]); err != nil {
return 0, errors.Wrap(err, "calculating hash for tombstones")
return 0, fmt.Errorf("calculating hash for tombstones: %w", err)
}
n, err = f.Write(bytes)
if err != nil {
return 0, errors.Wrap(err, "writing tombstones")
return 0, fmt.Errorf("writing tombstones: %w", err)
}
size += n
@ -161,7 +161,7 @@ func Encode(tr Reader) ([]byte, error) {
func Decode(b []byte) (Reader, error) {
d := &encoding.Decbuf{B: b}
if flag := d.Byte(); flag != tombstoneFormatV1 {
return nil, errors.Errorf("invalid tombstone format %x", flag)
return nil, fmt.Errorf("invalid tombstone format %x", flag)
}
if d.Err() != nil {
@ -199,7 +199,7 @@ func ReadTombstones(dir string) (Reader, int64, error) {
}
if len(b) < tombstonesHeaderSize {
return nil, 0, errors.Wrap(encoding.ErrInvalidSize, "tombstones header")
return nil, 0, fmt.Errorf("tombstones header: %w", encoding.ErrInvalidSize)
}
d := &encoding.Decbuf{B: b[:len(b)-tombstonesCRCSize]}
@ -211,7 +211,7 @@ func ReadTombstones(dir string) (Reader, int64, error) {
hash := newCRC32()
// Ignore first byte which is the format type.
if _, err := hash.Write(d.Get()[tombstoneFormatVersionSize:]); err != nil {
return nil, 0, errors.Wrap(err, "write to hash")
return nil, 0, fmt.Errorf("write to hash: %w", err)
}
if binary.BigEndian.Uint32(b[len(b)-tombstonesCRCSize:]) != hash.Sum32() {
return nil, 0, errors.New("checksum did not match")