Skip to content

Commit

Permalink
remove extra state.Locker assertions
Browse files Browse the repository at this point in the history
All states are lockers, so get rid of extra asertions.
  • Loading branch information
jbardin committed Apr 1, 2017
1 parent bf6384a commit 75458a1
Show file tree
Hide file tree
Showing 4 changed files with 7 additions and 34 deletions.
7 changes: 2 additions & 5 deletions backend/remote-state/consul/backend_state.go
Original file line number Diff line number Diff line change
Expand Up @@ -102,22 +102,19 @@ func (b *Backend) State(name string) (state.State, error) {
stateMgr = &state.LockDisabled{Inner: stateMgr}
}

// Get the locker, which we know always exists
stateMgrLocker := stateMgr.(state.Locker)

// Grab a lock, we use this to write an empty state if one doesn't
// exist already. We have to write an empty state as a sentinel value
// so States() knows it exists.
lockInfo := state.NewLockInfo()
lockInfo.Operation = "init"
lockId, err := stateMgrLocker.Lock(lockInfo)
lockId, err := stateMgr.Lock(lockInfo)
if err != nil {
return nil, fmt.Errorf("failed to lock state in Consul: %s", err)
}

// Local helper function so we can call it multiple places
lockUnlock := func(parent error) error {
if err := stateMgrLocker.Unlock(lockId); err != nil {
if err := stateMgr.Unlock(lockId); err != nil {
return fmt.Errorf(strings.TrimSpace(errStateUnlock), lockId, err)
}

Expand Down
14 changes: 2 additions & 12 deletions command/state/state.go
Original file line number Diff line number Diff line change
Expand Up @@ -50,15 +50,10 @@ that no one else is holding a lock.
// Lock locks the given state and outputs to the user if locking
// is taking longer than the threshold.
func Lock(s state.State, info *state.LockInfo, ui cli.Ui, color *colorstring.Colorize) (string, error) {
sl, ok := s.(state.Locker)
if !ok {
return "", nil
}

var lockID string

err := slowmessage.Do(LockThreshold, func() error {
id, err := sl.Lock(info)
id, err := s.Lock(info)
lockID = id
return err
}, func() {
Expand All @@ -77,13 +72,8 @@ func Lock(s state.State, info *state.LockInfo, ui cli.Ui, color *colorstring.Col
// Unlock unlocks the given state and outputs to the user if the
// unlock fails what can be done.
func Unlock(s state.State, id string, ui cli.Ui, color *colorstring.Colorize) error {
sl, ok := s.(state.Locker)
if !ok {
return nil
}

err := slowmessage.Do(LockThreshold, func() error {
return sl.Unlock(id)
return s.Unlock(id)
}, func() {
if ui != nil {
ui.Output(color.Color(UnlockMessage))
Expand Down
9 changes: 1 addition & 8 deletions command/unlock.go
Original file line number Diff line number Diff line change
Expand Up @@ -59,13 +59,6 @@ func (c *UnlockCommand) Run(args []string) int {
return 1
}

s, ok := st.(state.Locker)
if !ok {
c.Ui.Error("The remote state backend in use does not support locking, and therefor\n" +
"cannot be unlocked.")
return 1
}

isLocal := false
switch s := st.(type) {
case *state.BackupState:
Expand Down Expand Up @@ -103,7 +96,7 @@ func (c *UnlockCommand) Run(args []string) int {
}
}

if err := s.Unlock(lockID); err != nil {
if err := st.Unlock(lockID); err != nil {
c.Ui.Error(fmt.Sprintf("Failed to unlock state: %s", err))
return 1
}
Expand Down
11 changes: 2 additions & 9 deletions state/backup.go
Original file line number Diff line number Diff line change
Expand Up @@ -41,19 +41,12 @@ func (s *BackupState) PersistState() error {
return s.Real.PersistState()
}

// all states get wrapped by BackupState, so it has to be a Locker
func (s *BackupState) Lock(info *LockInfo) (string, error) {
if s, ok := s.Real.(Locker); ok {
return s.Lock(info)
}
return "", nil
return s.Real.Lock(info)
}

func (s *BackupState) Unlock(id string) error {
if s, ok := s.Real.(Locker); ok {
return s.Unlock(id)
}
return nil
return s.Real.Unlock(id)
}

func (s *BackupState) backup() error {
Expand Down

0 comments on commit 75458a1

Please sign in to comment.