Skip to content

Commit

Permalink
types: fix STR_TO_DATE handling for %h, %r (pingcap#18171) (pingcap#1…
Browse files Browse the repository at this point in the history
…8428) (pingcap#18726)

Signed-off-by: ti-srebot <[email protected]>
  • Loading branch information
ti-srebot authored Jul 28, 2020
1 parent 4a2ed89 commit 90120cb
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 7 deletions.
13 changes: 7 additions & 6 deletions types/format_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -89,9 +89,11 @@ func (s *testTimeSuite) TestStrToDate(c *C) {
{`a09:30:17`, `a%h:%i:%s`, types.FromDate(0, 0, 0, 9, 30, 17, 0)},
{`09:30:17a`, `%h:%i:%s`, types.FromDate(0, 0, 0, 9, 30, 17, 0)},
{`abc`, `abc`, types.ZeroTime},
{`12:43:24`, `%h:%i:%s`, types.FromDate(0, 0, 0, 0, 43, 24, 0)},
{`09`, `%m`, types.FromDate(0, 9, 0, 0, 0, 0, 0)},
{`09`, `%s`, types.FromDate(0, 0, 0, 0, 0, 9, 0)},
{`12:43:24 AM`, `%r`, types.FromDate(0, 0, 0, 12, 43, 24, 0)},
{`12:43:24 AM`, `%r`, types.FromDate(0, 0, 0, 0, 43, 24, 0)},
{`12:43:24 PM`, `%r`, types.FromDate(0, 0, 0, 12, 43, 24, 0)},
{`11:43:24 PM`, `%r`, types.FromDate(0, 0, 0, 23, 43, 24, 0)},
{`00:12:13`, `%T`, types.FromDate(0, 0, 0, 0, 12, 13, 0)},
{`23:59:59`, `%T`, types.FromDate(0, 0, 0, 23, 59, 59, 0)},
Expand Down Expand Up @@ -127,15 +129,14 @@ func (s *testTimeSuite) TestStrToDate(c *C) {
}{
{`04/31/2004`, `%m/%d/%Y`},
{`a09:30:17`, `%h:%i:%s`}, // format mismatch
{`12:43:24 PM`, `%r`},
{`12:43:24`, `%r`}, // no PM or AM followed
{`23:60:12`, `%T`}, // invalid minute
{`12:43:24`, `%r`}, // no PM or AM followed
{`23:60:12`, `%T`}, // invalid minute
{`18`, `%l`},
{`00:21:22 AM`, `%h:%i:%s %p`},
{`100/10/22`, `%y/%m/%d`},
}
for _, tt := range errTests {
for i, tt := range errTests {
var t types.Time
c.Assert(t.StrToDate(sc, tt.input, tt.format), IsFalse)
c.Assert(t.StrToDate(sc, tt.input, tt.format), IsFalse, Commentf("no.%d failed", i))
}
}
11 changes: 10 additions & 1 deletion types/time.go
Original file line number Diff line number Diff line change
Expand Up @@ -2173,6 +2173,10 @@ func mysqlTimeFix(t *MysqlTime, ctx map[string]int) error {
if valueAMorPm == constForPM {
t.hour += 12
}
} else {
if _, ok := ctx["%h"]; ok && t.Hour() == 12 {
t.hour = 0
}
}
return nil
}
Expand Down Expand Up @@ -2271,7 +2275,7 @@ var dateFormatParserTable = map[string]dateFormatParser{
"%d": dayOfMonthNumeric, // Day of the month, numeric (0..31)
"%e": dayOfMonthNumeric, // Day of the month, numeric (0..31)
"%f": microSeconds, // Microseconds (000000..999999)
"%h": hour24TwoDigits, // Hour (01..12)
"%h": hour12Numeric, // Hour (01..12)
"%H": hour24Numeric, // Hour (00..23)
"%I": hour12Numeric, // Hour (01..12)
"%i": minutesNumeric, // Minutes, numeric (00..59)
Expand Down Expand Up @@ -2397,6 +2401,10 @@ func time12Hour(t *MysqlTime, input string, ctx map[string]int) (string, bool) {
if !succ || hour > 12 || hour == 0 || input[2] != ':' {
return input, false
}
// 12:34:56 AM -> 00:34:56
if hour == 12 {
hour = 0
}

minute, succ := parseDigits(input[3:], 2)
if !succ || minute > 59 || input[5] != ':' {
Expand Down Expand Up @@ -2542,6 +2550,7 @@ func hour12Numeric(t *MysqlTime, input string, ctx map[string]int) (string, bool
return input, false
}
t.hour = v
ctx["%h"] = v
return input[length:], true
}

Expand Down

0 comments on commit 90120cb

Please sign in to comment.