Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

cmd package test improvements #258

Merged
merged 33 commits into from
Dec 7, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
33 commits
Select commit Hold shift + click to select a range
7c3f0a8
cmd package test improvements
shireenf-ibm Oct 31, 2023
dc942c6
tiny fix
shireenf-ibm Oct 31, 2023
212d606
Merge branch 'main' into issue_110_tests_improvements_cmd_pkg
shireenf-ibm Oct 31, 2023
a667626
Merge branch 'main' of github.com:np-guard/netpol-analyzer into issue…
shireenf-ibm Nov 9, 2023
ebcdfa9
Merge branch 'main' into issue_110_tests_improvements_cmd_pkg
shireenf-ibm Nov 9, 2023
486b3bf
comment-out a test with json format since its output file cause other…
shireenf-ibm Nov 9, 2023
7414779
merge with master
shireenf-ibm Nov 9, 2023
22fb7c3
Merge branch 'issue_110_tests_improvements_cmd_pkg' of github.com:np-…
shireenf-ibm Nov 9, 2023
f8be434
Merge branch 'main' of github.com:np-guard/netpol-analyzer into issue…
shireenf-ibm Nov 9, 2023
ebc8e39
Merge branch 'main' into issue_110_tests_improvements_cmd_pkg
shireenf-ibm Nov 9, 2023
5b20ddb
Merge branch 'main' into issue_110_tests_improvements_cmd_pkg
shireenf-ibm Nov 12, 2023
d8f0639
Merge branch 'main' into issue_110_tests_improvements_cmd_pkg
shireenf-ibm Nov 13, 2023
8519e81
Merge branch 'main' of github.com:np-guard/netpol-analyzer into issue…
shireenf-ibm Nov 16, 2023
e2fe5d2
remove dups
shireenf-ibm Nov 19, 2023
f20ee2b
handling case of json output which can not be saved under its test dir
shireenf-ibm Nov 19, 2023
8757a78
adding cli test `command_test` to the make test-update
shireenf-ibm Nov 19, 2023
b8c98ad
Merge branch 'main' into issue_110_tests_improvements_cmd_pkg
shireenf-ibm Nov 20, 2023
6587c5c
running make test-update after merge
shireenf-ibm Nov 20, 2023
2cea8d7
code updates
shireenf-ibm Nov 23, 2023
4a4bcab
generating new output files by running make test-update
shireenf-ibm Nov 23, 2023
d605524
remove old output files
shireenf-ibm Nov 23, 2023
9c72618
remove cli output dir (not needed anymore)
shireenf-ibm Nov 23, 2023
58d7f14
fixes
shireenf-ibm Dec 3, 2023
871ecfa
Update pkg/internal/testutils/testutils.go
shireenf-ibm Dec 6, 2023
32f4dde
fixes
shireenf-ibm Dec 6, 2023
412e405
fix lint err
shireenf-ibm Dec 6, 2023
ba4346c
fix
shireenf-ibm Dec 6, 2023
dcd4357
merge master
shireenf-ibm Dec 6, 2023
a2ee0e2
Merge branch 'main' of github.com:np-guard/netpol-analyzer into issue…
shireenf-ibm Dec 6, 2023
601291e
empty format handle
shireenf-ibm Dec 6, 2023
9775afd
fixing diff testName issue
shireenf-ibm Dec 7, 2023
971f844
moving output to a new dir
shireenf-ibm Dec 7, 2023
f3ed640
pkges depth and get tests dir
shireenf-ibm Dec 7, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
33 changes: 17 additions & 16 deletions pkg/cli/command_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -128,18 +128,19 @@ func TestCommandsFailExecute(t *testing.T) {
expectedErrorContains: "both directory paths dir1 and dir2 are required",
},
{
name: "diff_command_args_contain_dirpath_should_return_error_of_unsupported_flag",
args: []string{"diff", "--dirpath", filepath.Join(testutils.GetTestsDirWithDepth(currentDirDepth), "onlineboutique")},
name: "diff_command_args_contain_dirpath_should_return_error_of_unsupported_flag",
args: []string{"diff", "--dirpath", filepath.Join(testutils.GetDirWithDepth(testutils.TestsDirName, currentDirDepth),
"onlineboutique")},
expectedErrorContains: "dirpath flag is not used with diff command",
},
{
name: "diff_command_with_unsupported_output_format_should_return_error",
args: []string{
"diff",
"--dir1",
filepath.Join(testutils.GetTestsDirWithDepth(currentDirDepth), "onlineboutique_workloads"),
filepath.Join(testutils.GetDirWithDepth(testutils.TestsDirName, currentDirDepth), "onlineboutique_workloads"),
"--dir2",
filepath.Join(testutils.GetTestsDirWithDepth(currentDirDepth), "onlineboutique_workloads_changed_workloads"),
filepath.Join(testutils.GetDirWithDepth(testutils.TestsDirName, currentDirDepth), "onlineboutique_workloads_changed_workloads"),
"-o",
"png"},
expectedErrorContains: "png output format is not supported.",
Expand All @@ -149,7 +150,7 @@ func TestCommandsFailExecute(t *testing.T) {
args: []string{
"eval",
"--dirpath",
filepath.Join(testutils.GetTestsDirWithDepth(currentDirDepth), "onlineboutique"),
filepath.Join(testutils.GetDirWithDepth(testutils.TestsDirName, currentDirDepth), "onlineboutique"),
"-s",
"default/adservice-77d5cd745d-t8mx4",
"-d",
Expand All @@ -163,7 +164,7 @@ func TestCommandsFailExecute(t *testing.T) {
args: []string{
"list",
"--dirpath",
filepath.Join(testutils.GetTestsDirWithDepth(currentDirDepth), "onlineboutique"),
filepath.Join(testutils.GetDirWithDepth(testutils.TestsDirName, currentDirDepth), "onlineboutique"),
"-o",
"png"},
expectedErrorContains: "png output format is not supported.",
Expand All @@ -173,7 +174,7 @@ func TestCommandsFailExecute(t *testing.T) {
args: []string{
"list",
"--dirpath",
filepath.Join(testutils.GetTestsDirWithDepth(currentDirDepth), "onlineboutique_workloads"),
filepath.Join(testutils.GetDirWithDepth(testutils.TestsDirName, currentDirDepth), "onlineboutique_workloads"),
"-q",
"-v",
},
Expand All @@ -184,7 +185,7 @@ func TestCommandsFailExecute(t *testing.T) {
args: []string{
"eval",
"--dirpath",
filepath.Join(testutils.GetTestsDirWithDepth(currentDirDepth), "onlineboutique_with_pods_severe_error"),
filepath.Join(testutils.GetDirWithDepth(testutils.TestsDirName, currentDirDepth), "onlineboutique_with_pods_severe_error"),
"-s",
"adservice-77d5cd745d-t8mx4",
"-d",
Expand Down Expand Up @@ -265,7 +266,7 @@ func TestListCommandOutput(t *testing.T) {
tt := tt
testName, expectedOutputFileName := getListCmdTestNameAndExpectedOutputFile(tt.dirName, tt.focusWorkload, tt.format)
t.Run(testName, func(t *testing.T) {
args := []string{"list", "--dirpath", filepath.Join(testutils.GetTestsDirWithDepth(currentDirDepth), tt.dirName)}
args := []string{"list", "--dirpath", filepath.Join(testutils.GetDirWithDepth(testutils.TestsDirName, currentDirDepth), tt.dirName)}
args = append(args, addCmdOptionalArgs(tt.format, tt.outputFile, tt.focusWorkload)...)
actualOut, err := buildAndExecuteCommand(args)
require.Nil(t, err, "test: %q", testName)
Expand Down Expand Up @@ -318,8 +319,8 @@ func TestDiffCommandOutput(t *testing.T) {
tt := tt
testName, expectedOutputFileName := testutils.DiffTestNameByTestArgs(tt.dir1, tt.dir2, determineFileSuffix(tt.format))
t.Run(testName, func(t *testing.T) {
args := []string{"diff", "--dir1", filepath.Join(testutils.GetTestsDirWithDepth(currentDirDepth), tt.dir1), "--dir2",
filepath.Join(testutils.GetTestsDirWithDepth(currentDirDepth), tt.dir2)}
args := []string{"diff", "--dir1", filepath.Join(testutils.GetDirWithDepth(testutils.TestsDirName, currentDirDepth), tt.dir1), "--dir2",
filepath.Join(testutils.GetDirWithDepth(testutils.TestsDirName, currentDirDepth), tt.dir2)}
args = append(args, addCmdOptionalArgs(tt.format, tt.outputFile, "")...)
actualOut, err := buildAndExecuteCommand(args)
require.Nil(t, err, "test: %q", testName)
Expand Down Expand Up @@ -361,8 +362,8 @@ func TestEvalCommandOutput(t *testing.T) {
tt := tt
testName := "eval_" + tt.dir + "_from_" + tt.sourcePod + "_to_" + tt.destPod
t.Run(testName, func(t *testing.T) {
args := []string{"eval", "--dirpath", filepath.Join(testutils.GetTestsDirWithDepth(currentDirDepth), tt.dir), "-s", tt.sourcePod, "-d",
tt.destPod, "-p", tt.port}
args := []string{"eval", "--dirpath", filepath.Join(testutils.GetDirWithDepth(testutils.TestsDirName, currentDirDepth), tt.dir),
"-s", tt.sourcePod, "-d", tt.destPod, "-p", tt.port}
actualOut, err := buildAndExecuteCommand(args)
require.Nil(t, err, "test: %q", testName)
require.Contains(t, actualOut, fmt.Sprintf("%v", tt.evalResult),
Expand All @@ -383,9 +384,9 @@ func TestCommandWithFailFlag(t *testing.T) {
args: []string{
"diff",
"--dir1",
filepath.Join(testutils.GetTestsDirWithDepth(currentDirDepth), "onlineboutique"),
filepath.Join(testutils.GetDirWithDepth(testutils.TestsDirName, currentDirDepth), "onlineboutique"),
"--dir2",
filepath.Join(testutils.GetTestsDirWithDepth(currentDirDepth), "onlineboutique_with_pods_severe_error"),
filepath.Join(testutils.GetDirWithDepth(testutils.TestsDirName, currentDirDepth), "onlineboutique_with_pods_severe_error"),
"--fail"},
},
{
Expand All @@ -394,7 +395,7 @@ func TestCommandWithFailFlag(t *testing.T) {
args: []string{
"list",
"--dirpath",
filepath.Join(testutils.GetTestsDirWithDepth(currentDirDepth), "document_with_syntax_error"),
filepath.Join(testutils.GetDirWithDepth(testutils.TestsDirName, currentDirDepth), "document_with_syntax_error"),
"--fail",
},
},
Expand Down
20 changes: 10 additions & 10 deletions pkg/internal/testutils/testutils.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,31 +19,31 @@ var update = flag.Bool("update", false, "write or override golden files")

const (
dirLevelUp = ".."
testsDirName = "tests"
TestsDirName = "tests"
connlistExpectedOutputFilePartialName = "connlist_output."
StandardPkgLevelDepth = 3 // e.g. pkg/netpol/connlist
internalPkgLevelDepth = 5 // e.g. pkg/netpol/connlist/internal/ingressanalyzer
underscore = "_"
dotSign = "."
formatStr = "_format_"
outputFilesDir = "output_files"
outputFilesDir = "test_outputs"
focusWlAnnotation = "_focus_workload_"
)

func GetTestsDir() string {
return GetTestsDirWithDepth(StandardPkgLevelDepth)
func GetTestsDir() string { // called from netpol packages
return GetDirWithDepth(TestsDirName, StandardPkgLevelDepth)
}

func GetTestsDirFromInternalPkg() string {
return GetTestsDirWithDepth(internalPkgLevelDepth)
func GetTestsDirFromInternalPkg() string { // called from netpol/internal packages
return GetDirWithDepth(TestsDirName, internalPkgLevelDepth)
}

func GetTestsDirWithDepth(depth int) string {
func GetDirWithDepth(dirName string, depth int) string {
res, _ := os.Getwd()
for i := 0; i < depth; i++ {
res = filepath.Join(res, dirLevelUp)
}
return filepath.Join(res, testsDirName)
return filepath.Join(res, dirName)
}
adisos marked this conversation as resolved.
Show resolved Hide resolved

// ConnlistTestNameByTestArgs returns connlist test name and test's expected output file from some tests args
Expand All @@ -70,7 +70,7 @@ func DiffTestNameByTestArgs(ref1, ref2, format string) (testName, expectedOutput
// if --update flag is on, writes the actual output to the expected output file
func CheckActualVsExpectedOutputMatch(t *testing.T, expectedOutputFileName, actualOutput, testInfo, testingPkg string,
currDirDepth int) {
expectedOutputFile := filepath.Join(GetTestsDirWithDepth(currDirDepth), outputFilesDir, testingPkg, expectedOutputFileName)
expectedOutputFile := filepath.Join(GetDirWithDepth(outputFilesDir, currDirDepth), testingPkg, expectedOutputFileName)
// if the --update flag is on (then generate/ override the expected output file with the actualOutput)
if *update {
err := output.WriteToFile(actualOutput, expectedOutputFile)
Expand All @@ -89,7 +89,7 @@ func CheckActualVsExpectedOutputMatch(t *testing.T, expectedOutputFileName, actu
WarnOnErrorReadingFile(err, expectedOutputFile)
}
actualOutputFileName := "actual_" + expectedOutputFileName
actualOutputFile := filepath.Join(GetTestsDirWithDepth(currDirDepth), outputFilesDir, testingPkg, actualOutputFileName)
actualOutputFile := filepath.Join(GetDirWithDepth(outputFilesDir, currDirDepth), testingPkg, actualOutputFileName)
if cleanStr(string(expectedOutput)) != cleanStr(actualOutput) {
err := output.WriteToFile(actualOutput, actualOutputFile)
if err != nil {
Expand Down
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Diff not rendered.
Loading