mirror of
https://github.com/minio/minio.git
synced 2025-01-23 04:33:15 -05:00
Merge pull request #87 from fkautz/pr_out_adding_more_unit_tests_to_strbyteconv_fixes_69
Adding more unit tests to strbyteconv. Fixes #69.
This commit is contained in:
commit
d34d86c050
@ -59,14 +59,20 @@ func BytesToString(bytes uint64) string {
|
||||
|
||||
func StringToBytes(s string) (uint64, error) {
|
||||
var bytes uint64
|
||||
var err error
|
||||
|
||||
StringPattern, err := regexp.Compile(`(?i)^(-?\d+)([KMGT])B?$`)
|
||||
bytes, err = strconv.ParseUint(s, 10, 64)
|
||||
if err == nil {
|
||||
return bytes, nil
|
||||
}
|
||||
|
||||
stringPattern, err := regexp.Compile(`(?i)^(-?\d+)([BKMGT])B?$`)
|
||||
if err != nil {
|
||||
return 0, err
|
||||
}
|
||||
|
||||
parts := StringPattern.FindStringSubmatch(strings.TrimSpace(s))
|
||||
if len(parts) < 3 {
|
||||
parts := stringPattern.FindStringSubmatch(strings.TrimSpace(s))
|
||||
if len(parts) < 2 {
|
||||
return 0, errors.New("Incorrect string format must be K,KB,M,MB,G,GB")
|
||||
}
|
||||
|
||||
@ -87,6 +93,8 @@ func StringToBytes(s string) (uint64, error) {
|
||||
bytes = value * UNIT_KILOBYTE
|
||||
case "B":
|
||||
bytes = value * UNIT_BYTE
|
||||
default:
|
||||
return 0, errors.New("Incorrect string format must be K,KB,M,MB,G,GB")
|
||||
}
|
||||
|
||||
return bytes, nil
|
||||
|
@ -17,8 +17,10 @@
|
||||
package strbyteconv
|
||||
|
||||
import (
|
||||
. "gopkg.in/check.v1"
|
||||
"log"
|
||||
"testing"
|
||||
|
||||
. "gopkg.in/check.v1"
|
||||
)
|
||||
|
||||
type MySuite struct{}
|
||||
@ -43,7 +45,20 @@ func (s *MySuite) Test(c *C) {
|
||||
value = BytesToString(100 * UNIT_TERABYTE)
|
||||
c.Assert(value, Equals, "100TB")
|
||||
|
||||
bytes, err := StringToBytes("100KB")
|
||||
bytes, err := StringToBytes("100B")
|
||||
log.Println(err)
|
||||
c.Assert(err, IsNil)
|
||||
c.Assert(bytes, Equals, uint64(100))
|
||||
|
||||
bytes, err = StringToBytes("100")
|
||||
c.Assert(err, IsNil)
|
||||
c.Assert(bytes, Equals, uint64(100))
|
||||
|
||||
bytes, err = StringToBytes("100KB")
|
||||
c.Assert(err, IsNil)
|
||||
c.Assert(bytes, Equals, uint64(100*UNIT_KILOBYTE))
|
||||
|
||||
bytes, err = StringToBytes("100K")
|
||||
c.Assert(err, IsNil)
|
||||
c.Assert(bytes, Equals, uint64(100*UNIT_KILOBYTE))
|
||||
|
||||
@ -51,12 +66,49 @@ func (s *MySuite) Test(c *C) {
|
||||
c.Assert(err, IsNil)
|
||||
c.Assert(bytes, Equals, uint64(100*UNIT_MEGABYTE))
|
||||
|
||||
bytes, err = StringToBytes("100M")
|
||||
c.Assert(err, IsNil)
|
||||
c.Assert(bytes, Equals, uint64(100*UNIT_MEGABYTE))
|
||||
|
||||
bytes, err = StringToBytes("100GB")
|
||||
c.Assert(err, IsNil)
|
||||
c.Assert(bytes, Equals, uint64(100*UNIT_GIGABYTE))
|
||||
|
||||
bytes, err = StringToBytes("100G")
|
||||
c.Assert(err, IsNil)
|
||||
c.Assert(bytes, Equals, uint64(100*UNIT_GIGABYTE))
|
||||
|
||||
bytes, err = StringToBytes("100TB")
|
||||
c.Assert(err, IsNil)
|
||||
c.Assert(bytes, Equals, uint64(100*UNIT_TERABYTE))
|
||||
|
||||
bytes, err = StringToBytes("100T")
|
||||
c.Assert(err, IsNil)
|
||||
c.Assert(bytes, Equals, uint64(100*UNIT_TERABYTE))
|
||||
|
||||
bytes, err = StringToBytes("0")
|
||||
c.Assert(err, IsNil)
|
||||
c.Assert(bytes, Equals, uint64(0))
|
||||
|
||||
bytes, err = StringToBytes("23")
|
||||
c.Assert(err, IsNil)
|
||||
c.Assert(bytes, Equals, uint64(23))
|
||||
|
||||
bytes, err = StringToBytes("0TB")
|
||||
c.Assert(err, IsNil)
|
||||
c.Assert(bytes, Equals, uint64(0))
|
||||
}
|
||||
|
||||
func (s *MySuite) TestBadInput(c *C) {
|
||||
_, err := StringToBytes("")
|
||||
c.Assert(err, Not(IsNil))
|
||||
|
||||
_, err = StringToBytes("HELLO")
|
||||
c.Assert(err, Not(IsNil))
|
||||
|
||||
_, err = StringToBytes("-20B")
|
||||
c.Assert(err, Not(IsNil))
|
||||
|
||||
_, err = StringToBytes("-20MB")
|
||||
c.Assert(err, Not(IsNil))
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user