Files
ascend-docker-runtime/mindxcheckutils/mindxcheckutils_test.go
2022-03-29 13:53:57 +08:00

87 lines
2.8 KiB
Go

// Package mindxcheckutils is a check utils package
/**
* Copyright (c) Huawei Technologies Co., Ltd. 2020-2022. All rights reserved.
*/
package mindxcheckutils
import (
"os"
"strings"
"testing"
)
func TestNormalFileCheckRegularFile(t *testing.T) {
tmpDir, filePath, err := createTestFile(t, "test_file.txt")
defer removeTmpDir(t, tmpDir)
err = os.Symlink(filePath, tmpDir+"/syslink")
if err != nil {
t.Fatalf("create symlink failed %q: %s", filePath, err)
}
if _, _, err = normalFileCheck(tmpDir, true, false); err != nil {
t.Fatalf("check allow dir failed %q: %s", tmpDir+"/__test__", err)
}
if _, _, err = normalFileCheck(tmpDir, false, false); !strings.Contains(err.Error(), "not regular file") {
t.Fatalf("check not allow dir failed %q: %s", tmpDir+"/__test__", err)
}
if _, _, err = normalFileCheck("/dev/zero", true, false); !strings.Contains(err.Error(), "not regular file/dir") {
t.Fatalf("check /dev/zero failed %q: %s", tmpDir+"/__test__", err)
}
if _, _, err = normalFileCheck(tmpDir+"/syslink", false, false); !strings.Contains(err.Error(), "symlinks") {
t.Fatalf("check symlinks failed %q: %s", tmpDir+"/syslink", err)
}
if _, _, err = normalFileCheck(filePath, false, false); err != nil {
t.Fatalf("check failed %q: %s", filePath, err)
}
if _, _, err = normalFileCheck(tmpDir+"/notexisted", false, false); !strings.Contains(err.Error(), "not existed") {
t.Fatalf("check symlinks failed %q: %s", tmpDir+"/syslink", err)
}
}
func TestFileCheckRegularFile(t *testing.T) {
tmpDir, filePath, err := createTestFile(t, "test_file.txt")
defer removeTmpDir(t, tmpDir)
err = os.Symlink(filePath, tmpDir+"/syslink")
if err != nil {
t.Fatalf("create symlink failed %q: %s", filePath, err)
}
if _, err = FileChecker(tmpDir, true, false, false, 0); err != nil {
t.Fatalf("check allow dir failed %q: %s", tmpDir+"/__test__", err)
}
if _, err = FileChecker(tmpDir, false, false, false, 0); err != nil &&
!strings.Contains(err.Error(), "not regular file") {
t.Fatalf("check not allow dir failed %q: %s", tmpDir+"/__test__", err)
}
if _, err = FileChecker("/dev/zero", true, false, false, 0); err != nil &&
!strings.Contains(err.Error(), "not regular file/dir") {
t.Fatalf("check /dev/zero failed %q: %s", tmpDir+"/__test__", err)
}
}
func createTestFile(t *testing.T, fileName string) (string, string, error) {
tmpDir := os.TempDir()
const permission os.FileMode = 0700
if os.MkdirAll(tmpDir+"/__test__", permission) != nil {
t.Fatalf("MkdirAll failed %q", tmpDir+"/__test__")
}
_, err := os.Create(tmpDir + "/__test__" + fileName)
if err != nil {
t.Fatalf("create file failed %q: %s", tmpDir+"/__test__", err)
}
return tmpDir + "/__test__", tmpDir + "/__test__" + fileName, err
}
func removeTmpDir(t *testing.T, tmpDir string) {
if os.RemoveAll(tmpDir) != nil {
t.Logf("removeall %v", tmpDir)
}
}