From 74a6e6029a0b2db196b1a8a1e1c469ca0a8c3b17 Mon Sep 17 00:00:00 2001 From: Paulo Gomes Date: Tue, 29 Aug 2023 22:27:59 +0100 Subject: [PATCH] Re-introduce osfs.Default The Default var was incorrectly removed as part of #31. This PR revert that change and adds tests to avoid future regression. Signed-off-by: Paulo Gomes --- osfs/os.go | 3 +++ osfs/os_js_test.go | 15 +++++++++++++++ osfs/os_test.go | 24 ++++++++++++++++++++++++ 3 files changed, 42 insertions(+) create mode 100644 osfs/os_test.go diff --git a/osfs/os.go b/osfs/os.go index 32ea0e5..cb7489a 100644 --- a/osfs/os.go +++ b/osfs/os.go @@ -18,6 +18,9 @@ const ( defaultCreateMode = 0o666 ) +// Default Filesystem representing the root of the os filesystem. +var Default = &ChrootOS{} + // New returns a new OS filesystem. func New(baseDir string, opts ...Option) billy.Filesystem { o := &options{} diff --git a/osfs/os_js_test.go b/osfs/os_js_test.go index a62d103..fbefdf4 100644 --- a/osfs/os_js_test.go +++ b/osfs/os_js_test.go @@ -7,9 +7,11 @@ import ( "fmt" "os" "path/filepath" + "reflect" "testing" "github.com/go-git/go-billy/v5" + "github.com/go-git/go-billy/v5/helper/chroot" "github.com/go-git/go-billy/v5/test" . "gopkg.in/check.v1" @@ -46,3 +48,16 @@ func (s *OSSuite) TestCapabilities(c *C) { caps := billy.Capabilities(s.FS) c.Assert(caps, Equals, billy.DefaultCapabilities&^billy.LockCapability) } + +func TestDefault(t *testing.T) { + want := &chroot.ChrootHelper{} // memfs is wrapped around ChrootHelper. + got := Default + + if reflect.TypeOf(got) != reflect.TypeOf(want) { + t.Errorf("wanted Default to be %T got %T", want, got) + } +} + +func TestNewAPI(t *testing.T) { + _ = New("/") +} diff --git a/osfs/os_test.go b/osfs/os_test.go new file mode 100644 index 0000000..81ecf62 --- /dev/null +++ b/osfs/os_test.go @@ -0,0 +1,24 @@ +//go:build !js +// +build !js + +package osfs + +import ( + "reflect" + "testing" +) + +func TestDefault(t *testing.T) { + want := &ChrootOS{} + got := Default + + if reflect.TypeOf(got) != reflect.TypeOf(want) { + t.Errorf("wanted Default to be %T got %T", want, got) + } +} + +func TestNewAPI(t *testing.T) { + _ = New("/") + _ = New("/", WithBoundOS()) + _ = New("/", WithChrootOS()) +}