Change some os.IsNotExist to errors.Is(err, os.ErrNotExist) for non-os errors.

os.IsNotExist doesn't unwrap errors. errors.Is does.

The ioutil.ReadFile ones happened to be fine but I changed them so
we're consistent with the rule: if the error comes from os, you can
use os.IsNotExist, but from any other package, use errors.Is.
(errors.Is always would also work, but not worth updating all the code)

The motivation here was that we were logging about failure to migrate
legacy relay node prefs file on startup, even though the code tried
to avoid that.

See golang/go#41122
This commit is contained in:
Brad Fitzpatrick 2020-11-02 08:33:34 -08:00
parent 037daad47a
commit 01ee638cca
4 changed files with 20 additions and 4 deletions

View File

@ -63,7 +63,7 @@ func loadConfig() config {
} }
b, err := ioutil.ReadFile(*configPath) b, err := ioutil.ReadFile(*configPath)
switch { switch {
case os.IsNotExist(err): case errors.Is(err, os.ErrNotExist):
return writeNewConfig() return writeNewConfig()
case err != nil: case err != nil:
log.Fatal(err) log.Fatal(err)

View File

@ -803,8 +803,8 @@ func (b *LocalBackend) loadStateLocked(key StateKey, prefs *Prefs, legacyPath st
if legacyPath != "" { if legacyPath != "" {
b.prefs, err = LoadPrefs(legacyPath) b.prefs, err = LoadPrefs(legacyPath)
if err != nil { if err != nil {
if !os.IsNotExist(err) { if !errors.Is(err, os.ErrNotExist) {
b.logf("Failed to load legacy prefs: %v", err) b.logf("failed to load legacy prefs: %v", err)
} }
b.prefs = NewPrefs() b.prefs = NewPrefs()
} else { } else {

View File

@ -5,8 +5,12 @@
package ipn package ipn
import ( import (
"errors"
"fmt"
"os"
"reflect" "reflect"
"testing" "testing"
"time"
"github.com/tailscale/wireguard-go/wgcfg" "github.com/tailscale/wireguard-go/wgcfg"
"tailscale.com/control/controlclient" "tailscale.com/control/controlclient"
@ -330,3 +334,14 @@ func TestPrefsPretty(t *testing.T) {
} }
} }
} }
func TestLoadPrefsNotExist(t *testing.T) {
bogusFile := fmt.Sprintf("/tmp/not-exist-%d", time.Now().UnixNano())
p, err := LoadPrefs(bogusFile)
if errors.Is(err, os.ErrNotExist) {
// expected.
return
}
t.Fatalf("unexpected prefs=%#v, err=%v", p, err)
}

View File

@ -9,6 +9,7 @@
import ( import (
"bufio" "bufio"
"bytes" "bytes"
"errors"
"fmt" "fmt"
"io" "io"
"io/ioutil" "io/ioutil"
@ -130,7 +131,7 @@ func (m directManager) Up(config Config) error {
contents, err := ioutil.ReadFile(resolvConf) contents, err := ioutil.ReadFile(resolvConf)
// If the original did not exist, still back up an empty file. // If the original did not exist, still back up an empty file.
// The presence of a backup file is the way we know that Up ran. // The presence of a backup file is the way we know that Up ran.
if err != nil && !os.IsNotExist(err) { if err != nil && !errors.Is(err, os.ErrNotExist) {
return err return err
} }
if err := atomicfile.WriteFile(backupConf, contents, 0644); err != nil { if err := atomicfile.WriteFile(backupConf, contents, 0644); err != nil {