fusego/samples/in_process.go

153 lines
3.7 KiB
Go
Raw Normal View History

// Copyright 2015 Google Inc. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package samples
import (
2015-03-20 02:44:50 +03:00
"fmt"
2015-03-20 03:10:04 +03:00
"io"
2015-03-20 02:44:50 +03:00
"io/ioutil"
2015-03-20 02:46:02 +03:00
"log"
"strings"
2015-03-20 02:44:50 +03:00
"time"
"github.com/googlecloudplatform/gcsfuse/timeutil"
"github.com/jacobsa/fuse"
"github.com/jacobsa/ogletest"
2015-03-20 02:46:02 +03:00
"golang.org/x/net/context"
)
// A struct that implements common behavior needed by tests in the samples/
// directory. Use it as an embedded field in your test fixture, calling its
// SetUp method from your SetUp method after setting the FileSystem field.
type SampleTest struct {
// The file system under test and the configuration with which it should be
// mounted. These must be set by the user of this type before calling SetUp;
// all the other fields below are set by SetUp itself.
FileSystem fuse.FileSystem
MountConfig fuse.MountConfig
2015-03-20 02:46:02 +03:00
// A context object that can be used for long-running operations.
Ctx context.Context
// A clock with a fixed initial time. The test's set up method may use this
// to wire the file system with a clock, if desired.
Clock timeutil.SimulatedClock
// The directory at which the file system is mounted.
Dir string
2015-03-20 02:44:50 +03:00
2015-03-20 03:10:04 +03:00
// Anothing non-nil in this slice will be closed by TearDown. The test will
// fail if closing fails.
ToClose []io.Closer
2015-03-20 02:44:50 +03:00
mfs *fuse.MountedFileSystem
}
2015-03-23 08:16:51 +03:00
// Mount t.FileSystem and initialize the other exported fields of the struct.
// Panics on error.
//
// REQUIRES: t.FileSystem has been set.
func (t *SampleTest) SetUp(ti *ogletest.TestInfo) {
err := t.initialize(t.FileSystem, &t.MountConfig)
2015-03-20 02:44:50 +03:00
if err != nil {
panic(err)
}
}
2015-03-23 08:16:51 +03:00
// Like SetUp, but doens't panic.
2015-03-20 02:44:50 +03:00
func (t *SampleTest) initialize(
fs fuse.FileSystem,
config *fuse.MountConfig) (err error) {
2015-03-20 02:46:02 +03:00
// Initialize the context.
t.Ctx = context.Background()
2015-03-20 02:44:50 +03:00
// Initialize the clock.
t.Clock.SetTime(time.Date(2012, 8, 15, 22, 56, 0, 0, time.Local))
// Set up a temporary directory.
t.Dir, err = ioutil.TempDir("", "sample_test")
if err != nil {
err = fmt.Errorf("TempDir: %v", err)
return
}
// Mount the file system.
t.mfs, err = fuse.Mount(t.Dir, fs, config)
if err != nil {
err = fmt.Errorf("Mount: %v", err)
return
}
2015-03-23 08:23:22 +03:00
// Wait for it to be ready.
2015-03-20 02:50:36 +03:00
err = t.mfs.WaitForReady(t.Ctx)
if err != nil {
err = fmt.Errorf("WaitForReady: %v", err)
return
}
2015-03-20 02:44:50 +03:00
return
}
// Unmount the file system and clean up. Panics on error.
func (t *SampleTest) TearDown() {
2015-03-20 02:47:46 +03:00
err := t.destroy()
if err != nil {
panic(err)
}
}
// Like TearDown, but doesn't panic.
2015-03-20 02:47:46 +03:00
func (t *SampleTest) destroy() (err error) {
2015-03-20 03:10:04 +03:00
// Close what is necessary.
for _, c := range t.ToClose {
if c == nil {
continue
}
ogletest.ExpectEq(nil, c.Close())
}
2015-03-20 02:46:02 +03:00
// Was the file system mounted?
if t.mfs == nil {
return
}
// Unmount the file system. Try again on "resource busy" errors.
delay := 10 * time.Millisecond
for {
2015-03-20 02:47:46 +03:00
err = t.mfs.Unmount()
2015-03-20 02:46:02 +03:00
if err == nil {
break
}
if strings.Contains(err.Error(), "resource busy") {
log.Println("Resource busy error while unmounting; trying again")
time.Sleep(delay)
delay = time.Duration(1.3 * float64(delay))
continue
}
2015-03-20 02:47:46 +03:00
err = fmt.Errorf("MountedFileSystem.Unmount: %v", err)
return
2015-03-20 02:46:02 +03:00
}
2015-03-20 02:47:46 +03:00
if err = t.mfs.Join(t.Ctx); err != nil {
err = fmt.Errorf("MountedFileSystem.Join: %v", err)
return
2015-03-20 02:46:02 +03:00
}
2015-03-20 02:47:46 +03:00
return
2015-03-20 02:46:02 +03:00
}