blob: 6709ea07c8980c1e6c302de35da5b627a041784a [file] [log] [blame]
// Copyright 2015 The Vanadium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
// Package jiritest provides utilities for testing jiri functionality.
package jiritest
import (
"io/ioutil"
"os"
"path/filepath"
"testing"
"time"
"fuchsia.googlesource.com/jiri"
"fuchsia.googlesource.com/jiri/cmdline"
"fuchsia.googlesource.com/jiri/color"
"fuchsia.googlesource.com/jiri/log"
"fuchsia.googlesource.com/jiri/tool"
)
// NewX is similar to jiri.NewX, but is meant for usage in a testing environment.
func NewX(t *testing.T) (*jiri.X, func()) {
ctx := tool.NewContextFromEnv(cmdline.EnvFromOS())
color := color.NewColor(color.ColorNever)
logger := log.NewLogger(log.InfoLevel, color, false, 0, time.Second*100, nil, nil)
root, err := ioutil.TempDir("", "")
if err != nil {
t.Fatalf("TempDir() failed: %v", err)
}
if err := os.Mkdir(filepath.Join(root, jiri.RootMetaDir), 0755); err != nil {
t.Fatalf("TempDir() failed: %v", err)
}
cleanup := func() {
if err := os.RemoveAll(root); err != nil {
t.Fatalf("RemoveAll(%q) failed: %v", root, err)
}
}
return &jiri.X{Context: ctx, Root: root, Jobs: jiri.DefaultJobs, Color: color, Logger: logger, Attempts: 1, LockfileEnabled: false}, cleanup
}