SDK rotation changes (#9942) (#10025)

Co-authored-by: kpcraig <3031348+kpcraig@users.noreply.github.com>
This commit is contained in:
Vault Automation 2025-10-10 12:23:51 -04:00 committed by GitHub
parent 93312c8c2d
commit 68d559dd6e
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
3 changed files with 55 additions and 0 deletions

3
changelog/_9942.txt Normal file
View file

@ -0,0 +1,3 @@
```release-note:bug
core: interpret all new rotation manager rotation_schedules as UTC to avoid inadvertent use of tz-local
```

View file

@ -52,6 +52,10 @@ func (d *DefaultSchedule) Parse(rotationSchedule string) (*cron.SpecSchedule, er
if !ok {
return nil, fmt.Errorf("invalid rotation schedule")
}
// override the timezone in all cases, even if was set otherwise
sched.Location = time.UTC
return sched, nil
}

View file

@ -0,0 +1,48 @@
// Copyright (c) HashiCorp, Inc.
// SPDX-License-Identifier: MPL-2.0
package rotation
import (
"testing"
"time"
)
func TestParseSchedule(t *testing.T) {
// Actual schedule-parsing tests are the responsibility of the library,
// (currently robfig/cron), but here are some cases for our specific functionality
cases := []struct {
name string
in string
shouldErr bool
location *time.Location
}{
{"force local to utc", "* * * * *", false, time.UTC},
{"seconds are invalid", "* * * * * *", true, nil},
// Specifically override this usage
{"custom timezone", "CRON_TZ=Asia/Tokyo * * * * *", false, time.UTC},
}
for _, c := range cases {
t.Run(c.name, func(t *testing.T) {
sched, err := DefaultScheduler.Parse(c.in)
if c.shouldErr { // should-err tests end here no matter what
if err == nil {
t.Error("should have errored, but didn't")
} else {
return
}
}
if err != nil {
t.Errorf("got unexpected error: %v", err)
}
// check the tz
if sched.Location.String() != c.location.String() {
t.Errorf("wrong tz, expected %s, got %s", c.location.String(), sched.Location.String())
}
})
}
}