forked from araddon/dateparse
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbench_test.go
111 lines (93 loc) · 2.56 KB
/
bench_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
package dateparse
import (
"fmt"
"testing"
"time"
"github.com/simplereach/timeutils"
)
/*
go test -bench Parse
BenchmarkShotgunParse 50000 37588 ns/op 13258 B/op 167 allocs/op
BenchmarkDateparseParseAny 500000 5752 ns/op 0 B/op 0 allocs/op
// Aarons Laptop Lenovo 900 Feb 2018
BenchmarkShotgunParse-4 50000 30045 ns/op 13136 B/op 169 allocs/op
BenchmarkParseAny-4 200000 8627 ns/op 144 B/op 3 allocs/op
// ifreddyrondon Laptop MacBook Pro (Retina, Mid 2012) March 2018
BenchmarkShotgunParse-8 50000 33940 ns/op 13136 B/op 169 allocs/op
BenchmarkParseAny-8 200000 10146 ns/op 912 B/op 29 allocs/op
BenchmarkParseDateString-8 10000 123077 ns/op 208 B/op 13 allocs/op
*/
func BenchmarkShotgunParse(b *testing.B) {
b.ReportAllocs()
for i := 0; i < b.N; i++ {
for _, dateStr := range testDates {
// This is the non dateparse traditional approach
parseShotgunStyle(dateStr)
}
}
}
func BenchmarkParseAny(b *testing.B) {
b.ReportAllocs()
for i := 0; i < b.N; i++ {
for _, dateStr := range testDates {
ParseAny(dateStr)
}
}
}
func BenchmarkParseDateString(b *testing.B) {
b.ReportAllocs()
for i := 0; i < b.N; i++ {
for _, dateStr := range testDates {
timeutils.ParseDateString(dateStr)
}
}
}
var (
testDates = []string{
"2012/03/19 10:11:59",
"2012/03/19 10:11:59.3186369",
"2009-08-12T22:15:09-07:00",
"2014-04-26 17:24:37.3186369",
"2012-08-03 18:31:59.257000000",
"2013-04-01 22:43:22",
"2014-04-26 17:24:37.123",
"2014-12-16 06:20:00 UTC",
"1384216367189",
"1332151919",
"2014-05-11 08:20:13,787",
"2014-04-26 05:24:37 PM",
"2014-04-26",
}
ErrDateFormat = fmt.Errorf("Invalid Date Format")
timeFormats = []string{
// ISO 8601ish formats
time.RFC3339Nano,
time.RFC3339,
// Unusual formats, prefer formats with timezones
time.RFC1123Z,
time.RFC1123,
time.RFC822Z,
time.RFC822,
time.UnixDate,
time.RubyDate,
time.ANSIC,
// Hilariously, Go doesn't have a const for it's own time layout.
// See: https://code.google.com/p/go/issues/detail?id=6587
"2006-01-02 15:04:05.999999999 -0700 MST",
// No timezone information
"2006-01-02T15:04:05.999999999",
"2006-01-02T15:04:05",
"2006-01-02 15:04:05.999999999",
"2006-01-02 15:04:05",
}
)
func parseShotgunStyle(raw string) (time.Time, error) {
for _, format := range timeFormats {
t, err := time.Parse(format, raw)
if err == nil {
// Parsed successfully
return t, nil
}
}
return time.Time{}, ErrDateFormat
}