Skip to content

Commit

Permalink
ensure e2e doesn't time out when it would have succeeded
Browse files Browse the repository at this point in the history
Signed-off-by: Evan Cordell <cordell.evan@gmail.com>
  • Loading branch information
ecordell committed Oct 4, 2021
1 parent 9df7471 commit f005b8e
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 6 deletions.
4 changes: 3 additions & 1 deletion .github/workflows/build.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -104,9 +104,11 @@ jobs:
- name: "Run e2e"
working-directory: "e2e/newenemy"
run: |
go test -v -timeout 20m ./...
go test -v -timeout 60m ./...
- uses: "actions/upload-artifact@v2"
if: "always()"
# this upload step is really flaky, don't fail the job if it fails
continue-on-error: true
with:
name: "node-logs"
path: "e2e/newenemy/*.log"
Expand Down
13 changes: 8 additions & 5 deletions e2e/newenemy/newenemy_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -96,11 +96,13 @@ func TestNoNewEnemy(t *testing.T) {
fmt.Sprintf(setSmallRanges, dbName),
))

t.Log("modifying network")
require.NoError(crdb.NetworkDelay(ctx, e2e.MustFile(ctx, t, "netattack.log"), 1, 100*time.Millisecond))

t.Log("modifying time")
require.NoError(crdb.TimeDelay(ctx, e2e.MustFile(ctx, t, "timeattack.log"), 1, -200*time.Millisecond))
timeDelay := 100 * time.Millisecond
require.NoError(crdb.TimeDelay(ctx, e2e.MustFile(ctx, t, "timeattack.log"), 1, -1*timeDelay))

t.Log("modifying network")
networkDelay := timeDelay / 2
require.NoError(crdb.NetworkDelay(ctx, e2e.MustFile(ctx, t, "netattack.log"), 1, networkDelay))

t.Log("create initial test schema")
require.NoError(initSchema(vulnerableSpiceDb[0].Client().V1Alpha1().Schema()))
Expand Down Expand Up @@ -139,7 +141,8 @@ func TestNoNewEnemy(t *testing.T) {
iterations := int(math.Ceil(3*stddev*samplestddev + mean))

t.Logf("check spicedb is protected after %d attempts", iterations)
checkCtx, checkCancel := context.WithTimeout(ctx, 10*time.Minute)
// *6 to cover the worst case where all requests are handled by the slow node
checkCtx, checkCancel := context.WithTimeout(ctx, time.Duration(iterations)*(networkDelay+timeDelay)*6)
protected, _ := checkNoNewEnemy(checkCtx, t, protectedSpiceDb, iterations)
require.NotNil(protected, "unable to determine if spicedb is protected within the time limit")
require.True(*protected, "protection is enabled, but newenemy detected")
Expand Down

0 comments on commit f005b8e

Please sign in to comment.