Browse Source
Merge pull request #836 from bingoohuang/master
Merge pull request #836 from bingoohuang/master
fix needle Append return offset to avoid uint32 overflowpull/842/head
Chris Lu
6 years ago
committed by
GitHub
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 261 additions and 138 deletions
-
4unmaintained/fix_dat/fix_dat.go
-
32unmaintained/see_dat/see_dat.go
-
105weed/command/export.go
-
48weed/command/fix.go
-
9weed/storage/needle_read_write.go
-
62weed/storage/needle_read_write_test.go
-
24weed/storage/volume_read_write.go
-
115weed/storage/volume_vacuum.go
@ -0,0 +1,62 @@ |
|||
package storage |
|||
|
|||
import ( |
|||
"crypto/rand" |
|||
"github.com/chrislusf/seaweedfs/weed/storage/types" |
|||
"io" |
|||
"io/ioutil" |
|||
"os" |
|||
"testing" |
|||
) |
|||
|
|||
func TestAppend(t *testing.T) { |
|||
n := &Needle{ |
|||
|
|||
Cookie: types.Cookie(123), // Cookie Cookie `comment:"random number to mitigate brute force lookups"`
|
|||
Id: types.NeedleId(123), // Id NeedleId `comment:"needle id"`
|
|||
Size: 8, // Size uint32 `comment:"sum of DataSize,Data,NameSize,Name,MimeSize,Mime"`
|
|||
DataSize: 4, // DataSize uint32 `comment:"Data size"` //version2
|
|||
Data: []byte("abcd"), // Data []byte `comment:"The actual file data"`
|
|||
Flags: 0, // Flags byte `comment:"boolean flags"` //version2
|
|||
NameSize: 0, // NameSize uint8 //version2
|
|||
Name: nil, // Name []byte `comment:"maximum 256 characters"` //version2
|
|||
MimeSize: 0, // MimeSize uint8 //version2
|
|||
Mime: nil, // Mime []byte `comment:"maximum 256 characters"` //version2
|
|||
PairsSize: 0, // PairsSize uint16 //version2
|
|||
Pairs: nil, // Pairs []byte `comment:"additional name value pairs, json format, maximum 6
|
|||
LastModified: 123, // LastModified uint64 //only store LastModifiedBytesLength bytes, which is 5 bytes
|
|||
Ttl: nil, // Ttl *TTL
|
|||
Checksum: 123, // Checksum CRC `comment:"CRC32 to check integrity"`
|
|||
AppendAtNs: 123, // AppendAtNs uint64 `comment:"append timestamp in nano seconds"` //version3
|
|||
Padding: nil, // Padding []byte `comment:"Aligned to 8 bytes"`
|
|||
} |
|||
|
|||
tempFile, err := ioutil.TempFile("", ".dat") |
|||
if err != nil { |
|||
t.Errorf("Fail TempFile. %v", err) |
|||
return |
|||
} |
|||
|
|||
/* |
|||
uint8 : 0 to 255 |
|||
uint16 : 0 to 65535 |
|||
uint32 : 0 to 4294967295 |
|||
uint64 : 0 to 18446744073709551615 |
|||
int8 : -128 to 127 |
|||
int16 : -32768 to 32767 |
|||
int32 : -2147483648 to 2147483647 |
|||
int64 : -9223372036854775808 to 9223372036854775807 |
|||
*/ |
|||
|
|||
fileSize := int64(4294967295) + 10000 |
|||
io.CopyN(tempFile, rand.Reader, fileSize) |
|||
defer func() { |
|||
tempFile.Close() |
|||
os.Remove(tempFile.Name()) |
|||
}() |
|||
|
|||
offset, _, _, _ := n.Append(tempFile, CurrentVersion) |
|||
if offset != uint64(fileSize) { |
|||
t.Errorf("Fail to Append Needle.") |
|||
} |
|||
} |
Write
Preview
Loading…
Cancel
Save
Reference in new issue