-
Notifications
You must be signed in to change notification settings - Fork 30
/
Copy pathe2e_test.go
64 lines (51 loc) · 1.44 KB
/
e2e_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
package test
import (
"os"
"os/exec"
"strings"
"testing"
"time"
"github.com/stretchr/testify/require"
)
func Test(t *testing.T) {
// for i := 0; i < 10; i++ {
err := os.Chdir("..")
require.NoError(t, err)
wd, err := os.Getwd()
require.NoError(t, err)
defer os.Chdir(wd)
cmd := exec.Command("neva", "run", "delayed_echo")
start := time.Now()
out, err := cmd.CombinedOutput()
elapsed := time.Since(start)
require.NoError(t, err, string(out))
// Check execution time is between 1-5 seconds
require.GreaterOrEqual(t, elapsed.Seconds(), 1.0)
require.LessOrEqual(t, elapsed.Seconds(), 5.0)
// Split output into lines and verify contents
lines := strings.Split(strings.TrimSpace(string(out)), "\n")
require.Equal(t, 7, len(lines), string(out)) // Hello + World + 5 numbers
// First line must be Hello
require.Equal(t, "Hello", lines[0], string(out))
// Create set of expected remaining values
expected := map[string]bool{
"World": false,
"1": false,
"2": false,
"3": false,
"4": false,
"5": false,
}
// Check remaining lines contain all expected values
for _, line := range lines[1:] {
_, exists := expected[line]
require.True(t, exists, "Unexpected value in output: %s", line)
expected[line] = true
}
// Verify all expected values were found
for val, found := range expected {
require.True(t, found, "Expected value not found: %s", val)
}
require.Equal(t, 0, cmd.ProcessState.ExitCode())
// }
}