Refactor store.New

Signed-off-by: Ulysses Souza <ulyssessouza@gmail.com>
This commit is contained in:
Ulysses Souza 2020-04-27 18:16:46 +02:00
parent bf243bfe31
commit 3380c9d459
3 changed files with 23 additions and 8 deletions

View File

@ -118,7 +118,7 @@ func main() {
logrus.Fatal(err) logrus.Fatal(err)
} }
s, err := store.New(opts.Config) s, err := store.New(store.WithRoot(opts.Config))
if err != nil { if err != nil {
logrus.Fatal(err) logrus.Fatal(err)
} }

View File

@ -72,9 +72,27 @@ type store struct {
root string root string
} }
type StoreOpt func(*store)
func WithRoot(root string) StoreOpt {
return func(s *store) {
s.root = root
}
}
// New returns a configured context store // New returns a configured context store
func New(root string) (Store, error) { func New(opts ...StoreOpt) (Store, error) {
cd := filepath.Join(root, contextsDir) home, err := os.UserHomeDir()
if err != nil {
return nil, err
}
s := &store {
root: home,
}
for _, opt := range opts {
opt(s)
}
cd := filepath.Join(s.root, contextsDir)
if _, err := os.Stat(cd); os.IsNotExist(err) { if _, err := os.Stat(cd); os.IsNotExist(err) {
if err = os.Mkdir(cd, 0755); err != nil { if err = os.Mkdir(cd, 0755); err != nil {
return nil, err return nil, err
@ -86,10 +104,7 @@ func New(root string) (Store, error) {
return nil, err return nil, err
} }
} }
return s, nil
return &store{
root: root,
}, nil
} }
// Get returns the context with the given name // Get returns the context with the given name

View File

@ -48,7 +48,7 @@ func (suite *StoreTestSuite) BeforeTest(suiteName, testName string) {
dir, err := ioutil.TempDir("", "store") dir, err := ioutil.TempDir("", "store")
require.Nil(suite.T(), err) require.Nil(suite.T(), err)
store, err := New(dir) store, err := New(WithRoot(dir))
require.Nil(suite.T(), err) require.Nil(suite.T(), err)
suite.dir = dir suite.dir = dir