Simplified tests
This commit is contained in:
parent
59d6653eba
commit
8103faa8b6
@ -15,26 +15,26 @@ var programs = []struct {
|
|||||||
ExpectedOutput string
|
ExpectedOutput string
|
||||||
ExpectedExitCode int
|
ExpectedExitCode int
|
||||||
}{
|
}{
|
||||||
{"empty.q", "", 0},
|
{"empty", "", 0},
|
||||||
{"math.q", "", 10},
|
{"math", "", 10},
|
||||||
{"precedence.q", "", 10},
|
{"precedence", "", 10},
|
||||||
{"square-sum.q", "", 25},
|
{"square-sum", "", 25},
|
||||||
{"chained-calls.q", "", 9},
|
{"chained-calls", "", 9},
|
||||||
{"nested-calls.q", "", 4},
|
{"nested-calls", "", 4},
|
||||||
{"overwrite.q", "", 3},
|
{"overwrite", "", 3},
|
||||||
{"reuse.q", "", 3},
|
{"reuse", "", 3},
|
||||||
{"return.q", "", 6},
|
{"return", "", 6},
|
||||||
{"reassign.q", "", 2},
|
{"reassign", "", 2},
|
||||||
{"branch.q", "", 0},
|
{"branch", "", 0},
|
||||||
{"branch-and.q", "", 0},
|
{"branch-and", "", 0},
|
||||||
{"branch-or.q", "", 0},
|
{"branch-or", "", 0},
|
||||||
{"branch-combined.q", "", 0},
|
{"branch-combined", "", 0},
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestPrograms(t *testing.T) {
|
func TestPrograms(t *testing.T) {
|
||||||
for _, test := range programs {
|
for _, test := range programs {
|
||||||
t.Run(test.Name, func(t *testing.T) {
|
t.Run(test.Name, func(t *testing.T) {
|
||||||
run(t, filepath.Join("programs", test.Name), test.ExpectedOutput, test.ExpectedExitCode)
|
run(t, filepath.Join("programs", test.Name+".q"), test.ExpectedOutput, test.ExpectedExitCode)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -57,7 +57,6 @@ func run(t *testing.T, name string, expectedOutput string, expectedExitCode int)
|
|||||||
b := build.New(name)
|
b := build.New(name)
|
||||||
assert.True(t, len(b.Executable()) > 0)
|
assert.True(t, len(b.Executable()) > 0)
|
||||||
|
|
||||||
t.Run("Compile", func(t *testing.T) {
|
|
||||||
result, err := b.Run()
|
result, err := b.Run()
|
||||||
assert.Nil(t, err)
|
assert.Nil(t, err)
|
||||||
|
|
||||||
@ -67,9 +66,7 @@ func run(t *testing.T, name string, expectedOutput string, expectedExitCode int)
|
|||||||
stat, err := os.Stat(b.Executable())
|
stat, err := os.Stat(b.Executable())
|
||||||
assert.Nil(t, err)
|
assert.Nil(t, err)
|
||||||
assert.True(t, stat.Size() > 0)
|
assert.True(t, stat.Size() > 0)
|
||||||
})
|
|
||||||
|
|
||||||
t.Run("Output", func(t *testing.T) {
|
|
||||||
cmd := exec.Command(b.Executable())
|
cmd := exec.Command(b.Executable())
|
||||||
output, err := cmd.Output()
|
output, err := cmd.Output()
|
||||||
exitCode := 0
|
exitCode := 0
|
||||||
@ -86,5 +83,4 @@ func run(t *testing.T, name string, expectedOutput string, expectedExitCode int)
|
|||||||
|
|
||||||
assert.Equal(t, exitCode, expectedExitCode)
|
assert.Equal(t, exitCode, expectedExitCode)
|
||||||
assert.DeepEqual(t, string(output), expectedOutput)
|
assert.DeepEqual(t, string(output), expectedOutput)
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user