Merge pull request #645 from harshavardhana/pr_out_return_back_entity_too_large_for_objects_bigger_than_cache_size

Return back entity too large for objects bigger than cache size
This commit is contained in:
Harshavardhana 2015-06-08 17:12:22 -07:00
commit dcc1609d2e
2 changed files with 12 additions and 1 deletions

View File

@ -18,6 +18,7 @@ package main
import ( import (
"fmt" "fmt"
"net/http"
"os" "os"
"os/user" "os/user"
"runtime" "runtime"
@ -116,7 +117,7 @@ func getBuildDate() string {
if t.IsZero() { if t.IsZero() {
return "" return ""
} }
return t.Format(time.RFC1123) return t.Format(http.TimeFormat)
} }
// Tries to get os/arch/platform specific information // Tries to get os/arch/platform specific information

View File

@ -43,6 +43,7 @@ type memoryDriver struct {
lock *sync.RWMutex lock *sync.RWMutex
objects *trove.Cache objects *trove.Cache
multiPartObjects *trove.Cache multiPartObjects *trove.Cache
maxSize uint64
} }
type storedBucket struct { type storedBucket struct {
@ -71,6 +72,7 @@ func Start(maxSize uint64, expiration time.Duration) (chan<- string, <-chan erro
memory = new(memoryDriver) memory = new(memoryDriver)
memory.storedBuckets = make(map[string]storedBucket) memory.storedBuckets = make(map[string]storedBucket)
memory.objects = trove.NewCache(maxSize, expiration) memory.objects = trove.NewCache(maxSize, expiration)
memory.maxSize = maxSize
memory.multiPartObjects = trove.NewCache(0, time.Duration(0)) memory.multiPartObjects = trove.NewCache(0, time.Duration(0))
memory.lock = new(sync.RWMutex) memory.lock = new(sync.RWMutex)
@ -204,6 +206,14 @@ func isMD5SumEqual(expectedMD5Sum, actualMD5Sum string) error {
} }
func (memory *memoryDriver) CreateObject(bucket, key, contentType, expectedMD5Sum string, size int64, data io.Reader) (string, error) { func (memory *memoryDriver) CreateObject(bucket, key, contentType, expectedMD5Sum string, size int64, data io.Reader) (string, error) {
if size > int64(memory.maxSize) {
generic := drivers.GenericObjectError{Bucket: bucket, Object: key}
return "", iodine.New(drivers.EntityTooLarge{
GenericObjectError: generic,
Size: strconv.FormatInt(size, 10),
MaxSize: strconv.FormatUint(memory.maxSize, 10),
}, nil)
}
md5sum, err := memory.createObject(bucket, key, contentType, expectedMD5Sum, size, data) md5sum, err := memory.createObject(bucket, key, contentType, expectedMD5Sum, size, data)
// free // free
debug.FreeOSMemory() debug.FreeOSMemory()