Move finder_test filesystem helper functions to fs/test.go

Move the filesystem helper functions used by finder_test.go into the
fs package so they can also be used by fs tests.

Bug: 157656545
Test: m checkbuild
Change-Id: I5ac3a1f502d8e2cb7c15dd70ca85a46d20f939a6
This commit is contained in:
Colin Cross 2020-06-29 23:00:12 -07:00
parent 181c2a40d8
commit 7f8aa39abe
3 changed files with 380 additions and 369 deletions

File diff suppressed because it is too large Load diff

View file

@ -22,6 +22,7 @@ bootstrap_go_package {
srcs: [ srcs: [
"fs.go", "fs.go",
"readdir.go", "readdir.go",
"test.go",
], ],
testSrcs: [ testSrcs: [
"readdir_test.go", "readdir_test.go",

146
finder/fs/test.go Normal file
View file

@ -0,0 +1,146 @@
// Copyright 2020 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 fs
import (
"io/ioutil"
"path/filepath"
"reflect"
"sort"
"testing"
"time"
)
func Write(t *testing.T, path string, content string, filesystem *MockFs) {
parent := filepath.Dir(path)
filesystem.MkDirs(parent)
err := filesystem.WriteFile(path, []byte(content), 0777)
if err != nil {
t.Fatal(err.Error())
}
}
func Create(t *testing.T, path string, filesystem *MockFs) {
Write(t, path, "hi", filesystem)
}
func Delete(t *testing.T, path string, filesystem *MockFs) {
err := filesystem.Remove(path)
if err != nil {
t.Fatal(err.Error())
}
}
func RemoveAll(t *testing.T, path string, filesystem *MockFs) {
err := filesystem.RemoveAll(path)
if err != nil {
t.Fatal(err.Error())
}
}
func Move(t *testing.T, oldPath string, newPath string, filesystem *MockFs) {
err := filesystem.Rename(oldPath, newPath)
if err != nil {
t.Fatal(err.Error())
}
}
func Link(t *testing.T, newPath string, oldPath string, filesystem *MockFs) {
parentPath := filepath.Dir(newPath)
err := filesystem.MkDirs(parentPath)
if err != nil {
t.Fatal(err.Error())
}
err = filesystem.Symlink(oldPath, newPath)
if err != nil {
t.Fatal(err.Error())
}
}
func Read(t *testing.T, path string, filesystem *MockFs) string {
reader, err := filesystem.Open(path)
if err != nil {
t.Fatalf(err.Error())
}
bytes, err := ioutil.ReadAll(reader)
if err != nil {
t.Fatal(err.Error())
}
return string(bytes)
}
func ModTime(t *testing.T, path string, filesystem *MockFs) time.Time {
stats, err := filesystem.Lstat(path)
if err != nil {
t.Fatal(err.Error())
}
return stats.ModTime()
}
func SetReadable(t *testing.T, path string, readable bool, filesystem *MockFs) {
err := filesystem.SetReadable(path, readable)
if err != nil {
t.Fatal(err.Error())
}
}
func SetReadErr(t *testing.T, path string, readErr error, filesystem *MockFs) {
err := filesystem.SetReadErr(path, readErr)
if err != nil {
t.Fatal(err.Error())
}
}
func AssertSameResponse(t *testing.T, actual []string, expected []string) {
t.Helper()
sort.Strings(actual)
sort.Strings(expected)
if !reflect.DeepEqual(actual, expected) {
t.Fatalf("Expected Finder to return these %v paths:\n %v,\ninstead returned these %v paths: %v\n",
len(expected), expected, len(actual), actual)
}
}
func AssertSameStatCalls(t *testing.T, actual []string, expected []string) {
t.Helper()
sort.Strings(actual)
sort.Strings(expected)
if !reflect.DeepEqual(actual, expected) {
t.Fatalf("Finder made incorrect Stat calls.\n"+
"Actual:\n"+
"%v\n"+
"Expected:\n"+
"%v\n"+
"\n",
actual, expected)
}
}
func AssertSameReadDirCalls(t *testing.T, actual []string, expected []string) {
t.Helper()
sort.Strings(actual)
sort.Strings(expected)
if !reflect.DeepEqual(actual, expected) {
t.Fatalf("Finder made incorrect ReadDir calls.\n"+
"Actual:\n"+
"%v\n"+
"Expected:\n"+
"%v\n"+
"\n",
actual, expected)
}
}