opentofu/backend/local
Martin Atkins 9cda37205d backend/local: create local state file if backend write fails
In the old remote state system we had the idea of a local backup, which
is actually still present for the legacy backends but no longer applies
for the new-style backends like the s3 backend.

It's problematic when an apply runs for long enough that someone's
time-limited AWS STS credentials expire and then Terraform fails and can't
persist state to S3.

To reduce the risk of lost state, here we add some extra fallback code
for the local apply operation in particular. If either state writing
or state persisting fail then we attempt to write the state to a special
backup file errored.tfstate, and produce an error message that guides the
user on how to retry uploading this state.

In the unlikely event that we can't write to local disk either (e.g.
permissions problems) we take a last-ditch attempt to dump the JSON onto
stdout and advise the user to manually copy it into a file for import.
If even that doesn't work for some reason, we assume a critical Terraform
bug (JSON-serialization problem with states?) and bail out with an
apologetic error message.

This is implemented for the apply command in particular because this is
the one command where new objects are created in real APIs that we don't
want to lose track of. For other operations it's less bad to just generate
a simple error message and have the user retry.

This fixes #14298.
2017-05-23 11:18:01 -07:00
..
test-fixtures backend/local: check for empty config on apply 2017-02-15 16:00:59 -08:00
backend_apply_test.go backend/local: create local state file if backend write fails 2017-05-23 11:18:01 -07:00
backend_apply.go backend/local: create local state file if backend write fails 2017-05-23 11:18:01 -07:00
backend_local.go update local.Local to match the latest Backend 2017-02-28 16:07:31 -05:00
backend_plan_test.go backend/local: validate module exists for plan 2017-01-29 20:02:12 -08:00
backend_plan.go provide contexts to clistate.Lock calls 2017-04-01 17:09:20 -04:00
backend_refresh_test.go backend/local: refresh with no config should not crash on input 2017-02-22 13:10:08 -08:00
backend_refresh.go provide contexts to clistate.Lock calls 2017-04-01 17:09:20 -04:00
backend_test.go always wrap remote state in a BackupState 2017-04-24 22:15:19 -04:00
backend.go always wrap remote state in a BackupState 2017-04-24 22:15:19 -04:00
cli.go command: use backend.CLIIinit 2017-02-28 10:58:29 -08:00
counthookaction_string.go Restore stringer-generated files back to new version 2017-04-21 14:49:18 -07:00
hook_count_action.go backend/local 2017-01-26 14:33:49 -08:00
hook_count_test.go backend/local 2017-01-26 14:33:49 -08:00
hook_count.go backend/local 2017-01-26 14:33:49 -08:00
hook_state_test.go backend/local 2017-01-26 14:33:49 -08:00
hook_state.go backend/local 2017-01-26 14:33:49 -08:00
local_test.go backend/local 2017-01-26 14:33:49 -08:00
testing.go backend/local: run backend.TestBackend 2017-03-09 16:17:21 +05:30