summaryrefslogtreecommitdiff
diff options
authorMichael Vogt <mvo@ubuntu.com>2016-02-12 15:24:45 +0100
committerMichael Vogt <mvo@ubuntu.com>2016-02-12 15:24:45 +0100
commit22ba43797492444fad8684aeabbf43c61068064e (patch)
tree5aa9861d753310c7d88d74c749a5c535a5e323ec
parent6c4bb71c3743eb0a284f07bd8c044bd28a6707e3 (diff)
Never return nil in NewLocalSnapRepository()bugfix/crash-less
If the directory is not (yet) there do not return nil and cause potential crashes.
-rw-r--r--snappy/snap_local_repo.go7
-rw-r--r--snappy/snapp_test.go8
2 files changed, 8 insertions, 7 deletions
diff --git a/snappy/snap_local_repo.go b/snappy/snap_local_repo.go
index 02c78f5c77..72c478d586 100644
--- a/snappy/snap_local_repo.go
+++ b/snappy/snap_local_repo.go
@@ -20,7 +20,6 @@
package snappy
import (
- "os"
"path/filepath"
"github.com/ubuntu-core/snappy/dirs"
@@ -39,11 +38,9 @@ type SnapLocalRepository struct {
// NewLocalSnapRepository returns a new SnapLocalRepository for the given
// path
func NewLocalSnapRepository() *SnapLocalRepository {
- path := dirs.SnapSnapsDir
- if s, err := os.Stat(path); err != nil || !s.IsDir() {
- return nil
+ return &SnapLocalRepository{
+ path: dirs.SnapSnapsDir,
}
- return &SnapLocalRepository{path: path}
}
// Installed returns the installed snaps from this repository
diff --git a/snappy/snapp_test.go b/snappy/snapp_test.go
index f6b23ef61a..e12b79e2bf 100644
--- a/snappy/snapp_test.go
+++ b/snappy/snapp_test.go
@@ -171,10 +171,14 @@ frameworks:
c.Check(fmk, DeepEquals, []string{"one", "two"})
}
-func (s *SnapTestSuite) TestLocalSnapRepositoryInvalid(c *C) {
+func (s *SnapTestSuite) TestLocalSnapRepositoryInvalidIsStillOk(c *C) {
dirs.SnapSnapsDir = "invalid-path"
snap := NewLocalSnapRepository()
- c.Assert(snap, IsNil)
+ c.Assert(snap, NotNil)
+
+ installed, err := snap.Installed()
+ c.Assert(err, IsNil)
+ c.Assert(installed, HasLen, 0)
}
func (s *SnapTestSuite) TestLocalSnapRepositorySimple(c *C) {