mirror of
https://github.com/fluencelabs/tendermint
synced 2025-06-24 18:21:38 +00:00
changelog and PR changes
This commit is contained in:
@ -1,5 +1,12 @@
|
|||||||
# Changelog
|
# Changelog
|
||||||
|
|
||||||
|
|
||||||
|
## Develop-Branch changes (unreleased)
|
||||||
|
|
||||||
|
FEATURES:
|
||||||
|
|
||||||
|
- [common] Date range parsing from string (ex. "2015-12-31:2017-12-31")
|
||||||
|
|
||||||
## 0.2.1 (June 2, 2017)
|
## 0.2.1 (June 2, 2017)
|
||||||
|
|
||||||
FEATURES:
|
FEATURES:
|
||||||
|
@ -7,37 +7,37 @@ import (
|
|||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
)
|
)
|
||||||
|
|
||||||
// ParseDate parses a date string of the format YYYY-MM-DD
|
// TimeLayout helps to parse a date string of the format YYYY-MM-DD
|
||||||
func ParseDate(date string) (t time.Time, err error) {
|
// Intended to be used with the following function:
|
||||||
layout := "2006-01-02" //this represents YYYY-MM-DD
|
// time.Parse(TimeLayout, date)
|
||||||
return time.Parse(layout, date)
|
var TimeLayout = "2006-01-02" //this represents YYYY-MM-DD
|
||||||
}
|
|
||||||
|
|
||||||
// ParseDateRange parses a date range string of the format start:end
|
// ParseDateRange parses a date range string of the format start:end
|
||||||
// where the start and end date are of the format YYYY-MM-DD.
|
// where the start and end date are of the format YYYY-MM-DD.
|
||||||
// The parsed dates are *time.Time and will return nil pointers for
|
// The parsed dates are time.Time and will return the zero time for
|
||||||
// unbounded dates, ex:
|
// unbounded dates, ex:
|
||||||
// unbounded start: :2000-12-31
|
// unbounded start: :2000-12-31
|
||||||
// unbounded end: 2000-12-31:
|
// unbounded end: 2000-12-31:
|
||||||
func ParseDateRange(dateRange string) (startDate, endDate *time.Time, err error) {
|
func ParseDateRange(dateRange string) (startDate, endDate time.Time, err error) {
|
||||||
dates := strings.Split(dateRange, ":")
|
dates := strings.Split(dateRange, ":")
|
||||||
if len(dates) != 2 {
|
if len(dates) != 2 {
|
||||||
return nil, nil, errors.New("bad date range, must be in format date:date")
|
err = errors.New("bad date range, must be in format date:date")
|
||||||
|
return
|
||||||
}
|
}
|
||||||
parseDate := func(date string) (*time.Time, error) {
|
parseDate := func(date string) (out time.Time, err error) {
|
||||||
if len(date) == 0 {
|
if len(date) == 0 {
|
||||||
return nil, nil
|
return
|
||||||
}
|
}
|
||||||
d, err := ParseDate(date)
|
out, err = time.Parse(TimeLayout, date)
|
||||||
return &d, err
|
return
|
||||||
}
|
}
|
||||||
startDate, err = parseDate(dates[0])
|
startDate, err = parseDate(dates[0])
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, nil, err
|
return
|
||||||
}
|
}
|
||||||
endDate, err = parseDate(dates[1])
|
endDate, err = parseDate(dates[1])
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, nil, err
|
return
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
@ -10,66 +10,36 @@ import (
|
|||||||
var (
|
var (
|
||||||
date = time.Date(2015, time.Month(12), 31, 0, 0, 0, 0, time.UTC)
|
date = time.Date(2015, time.Month(12), 31, 0, 0, 0, 0, time.UTC)
|
||||||
date2 = time.Date(2016, time.Month(12), 31, 0, 0, 0, 0, time.UTC)
|
date2 = time.Date(2016, time.Month(12), 31, 0, 0, 0, 0, time.UTC)
|
||||||
|
zero time.Time
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestParseDate(t *testing.T) {
|
|
||||||
assert := assert.New(t)
|
|
||||||
|
|
||||||
var testDates = []struct {
|
|
||||||
dateStr string
|
|
||||||
date time.Time
|
|
||||||
errNil bool
|
|
||||||
}{
|
|
||||||
{"2015-12-31", date, true},
|
|
||||||
{"2015-31-12", date, false},
|
|
||||||
{"12-31-2015", date, false},
|
|
||||||
{"31-12-2015", date, false},
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, test := range testDates {
|
|
||||||
parsed, err := ParseDate(test.dateStr)
|
|
||||||
switch test.errNil {
|
|
||||||
case true:
|
|
||||||
assert.Nil(err)
|
|
||||||
assert.True(parsed.Equal(test.date), "parsed: %v, want %v", parsed, test.date)
|
|
||||||
case false:
|
|
||||||
assert.NotNil(err, "parsed %v, expected err %v", parsed, err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestParseDateRange(t *testing.T) {
|
func TestParseDateRange(t *testing.T) {
|
||||||
assert := assert.New(t)
|
assert := assert.New(t)
|
||||||
|
|
||||||
var testDates = []struct {
|
var testDates = []struct {
|
||||||
dateStr string
|
dateStr string
|
||||||
start *time.Time
|
start time.Time
|
||||||
end *time.Time
|
end time.Time
|
||||||
errNil bool
|
errNil bool
|
||||||
}{
|
}{
|
||||||
{"2015-12-31:2016-12-31", &date, &date2, true},
|
{"2015-12-31:2016-12-31", date, date2, true},
|
||||||
{"2015-12-31:", &date, nil, true},
|
{"2015-12-31:", date, zero, true},
|
||||||
{":2016-12-31", nil, &date2, true},
|
{":2016-12-31", zero, date2, true},
|
||||||
{"2016-12-31", nil, nil, false},
|
{"2016-12-31", zero, zero, false},
|
||||||
{"2016-31-12:", nil, nil, false},
|
{"2016-31-12:", zero, zero, false},
|
||||||
{":2016-31-12", nil, nil, false},
|
{":2016-31-12", zero, zero, false},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, test := range testDates {
|
for _, test := range testDates {
|
||||||
start, end, err := ParseDateRange(test.dateStr)
|
start, end, err := ParseDateRange(test.dateStr)
|
||||||
switch test.errNil {
|
if test.errNil {
|
||||||
case true:
|
|
||||||
assert.Nil(err)
|
assert.Nil(err)
|
||||||
testPtr := func(want, have *time.Time) {
|
testPtr := func(want, have time.Time) {
|
||||||
if want == nil {
|
assert.True(have.Equal(want))
|
||||||
assert.Nil(have)
|
|
||||||
} else {
|
|
||||||
assert.True((*have).Equal(*want))
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
testPtr(test.start, start)
|
testPtr(test.start, start)
|
||||||
testPtr(test.end, end)
|
testPtr(test.end, end)
|
||||||
case false:
|
} else {
|
||||||
assert.NotNil(err)
|
assert.NotNil(err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user