1
0
Fork 0
mirror of https://github.com/moby/moby.git synced 2022-11-09 12:21:53 -05:00

Hack: don't run integration tests in /var/lib/docker/unit-tests; add missing cleanups in a few tests

This commit is contained in:
Solomon Hykes 2013-10-16 20:10:20 +00:00
parent cd61fb2e6f
commit 1da335f784
4 changed files with 37 additions and 16 deletions

View file

@ -91,6 +91,7 @@ func TestGetInfo(t *testing.T) {
func TestGetEvents(t *testing.T) { func TestGetEvents(t *testing.T) {
runtime := mkRuntime(t) runtime := mkRuntime(t)
defer nuke(runtime)
srv := &Server{ srv := &Server{
runtime: runtime, runtime: runtime,
events: make([]utils.JSONMessage, 0, 64), events: make([]utils.JSONMessage, 0, 64),

View file

@ -74,12 +74,6 @@ func cleanup(runtime *Runtime) error {
return nil return nil
} }
func cleanupLast(runtime *Runtime) error {
cleanup(runtime)
runtime.deviceSet.Shutdown()
return nil
}
func layerArchive(tarfile string) (io.Reader, error) { func layerArchive(tarfile string) (io.Reader, error) {
// FIXME: need to close f somewhere // FIXME: need to close f somewhere
f, err := os.Open(tarfile) f, err := os.Open(tarfile)
@ -178,11 +172,20 @@ func init() {
log.Fatalf("Unable to cleanup devmapper: %s", err) log.Fatalf("Unable to cleanup devmapper: %s", err)
} }
// Make it our Store root // Setup the base runtime, which will be duplicated for each test.
if runtime, err := NewRuntimeFromDirectory(unitTestStoreBase, false); err != nil { // (no tests are run directly in the base)
setupBaseImage()
// Create the "global runtime" with a long-running daemon for integration tests
spawnGlobalDaemon()
startFds, startGoroutines = utils.GetTotalUsedFds(), runtime.NumGoroutine()
}
func setupBaseImage() {
runtime, err := NewRuntimeFromDirectory(unitTestStoreBase, false)
if err != nil {
log.Fatalf("Unable to create a runtime for tests:", err) log.Fatalf("Unable to create a runtime for tests:", err)
} else {
globalRuntime = runtime
} }
// Create a device, which triggers the initiation of the base FS // Create a device, which triggers the initiation of the base FS
@ -192,29 +195,45 @@ func init() {
// Create the "Server" // Create the "Server"
srv := &Server{ srv := &Server{
runtime: globalRuntime, runtime: runtime,
enableCors: false, enableCors: false,
pullingPool: make(map[string]struct{}), pullingPool: make(map[string]struct{}),
pushingPool: make(map[string]struct{}), pushingPool: make(map[string]struct{}),
} }
// If the unit test is not found, try to download it. // If the unit test is not found, try to download it.
if img, err := globalRuntime.repositories.LookupImage(unitTestImageName); err != nil || img.ID != unitTestImageID { if img, err := runtime.repositories.LookupImage(unitTestImageName); err != nil || img.ID != unitTestImageID {
// Retrieve the Image // Retrieve the Image
if err := srv.ImagePull(unitTestImageName, "", os.Stdout, utils.NewStreamFormatter(false), nil, nil, true); err != nil { if err := srv.ImagePull(unitTestImageName, "", os.Stdout, utils.NewStreamFormatter(false), nil, nil, true); err != nil {
log.Fatalf("Unable to pull the test image:", err) log.Fatalf("Unable to pull the test image:", err)
} }
} }
}
func spawnGlobalDaemon() {
if globalRuntime != nil {
utils.Debugf("Global runtime already exists. Skipping.")
return
}
globalRuntime = mkRuntime(log.New(os.Stderr, "", 0))
srv := &Server{
runtime: globalRuntime,
enableCors: false,
pullingPool: make(map[string]struct{}),
pushingPool: make(map[string]struct{}),
}
// Spawn a Daemon // Spawn a Daemon
go func() { go func() {
utils.Debugf("Spawning global daemon for integration tests")
if err := ListenAndServe(testDaemonProto, testDaemonAddr, srv, os.Getenv("DEBUG") != ""); err != nil { if err := ListenAndServe(testDaemonProto, testDaemonAddr, srv, os.Getenv("DEBUG") != ""); err != nil {
log.Fatalf("Unable to spawn the test daemon:", err) log.Fatalf("Unable to spawn the test daemon:", err)
} }
}() }()
// Give some time to ListenAndServer to actually start // Give some time to ListenAndServer to actually start
// FIXME: use inmem transports instead of tcp
time.Sleep(time.Second) time.Sleep(time.Second)
startFds, startGoroutines = utils.GetTotalUsedFds(), runtime.NumGoroutine()
} }
// FIXME: test that ImagePull(json=true) send correct json output // FIXME: test that ImagePull(json=true) send correct json output

View file

@ -351,6 +351,7 @@ func TestPools(t *testing.T) {
func TestLogEvent(t *testing.T) { func TestLogEvent(t *testing.T) {
runtime := mkRuntime(t) runtime := mkRuntime(t)
defer nuke(runtime)
srv := &Server{ srv := &Server{
runtime: runtime, runtime: runtime,
events: make([]utils.JSONMessage, 0, 64), events: make([]utils.JSONMessage, 0, 64),

View file

@ -11,7 +11,7 @@ func displayFdGoroutines(t *testing.T) {
} }
func TestFinal(t *testing.T) { func TestFinal(t *testing.T) {
cleanupLast(globalRuntime) nuke(globalRuntime)
t.Logf("Start Fds: %d, Start Goroutines: %d", startFds, startGoroutines) t.Logf("Start Fds: %d, Start Goroutines: %d", startFds, startGoroutines)
displayFdGoroutines(t) displayFdGoroutines(t)
} }