driver_test.go 3.57 KB
Newer Older
1 2 3 4 5 6 7 8 9 10
package driver

import (
	"context"
	"errors"
	"fmt"
	"io"
	"testing"

	"github.com/ethereum-optimism/optimism/op-node/rollup/derive"
11
	"github.com/ethereum-optimism/optimism/op-service/eth"
12
	"github.com/ethereum-optimism/optimism/op-service/testlog"
13 14 15 16 17 18 19 20 21 22 23 24 25
	"github.com/ethereum/go-ethereum/log"
	"github.com/stretchr/testify/require"
)

func TestDerivationComplete(t *testing.T) {
	driver := createDriver(t, fmt.Errorf("derivation complete: %w", io.EOF))
	err := driver.Step(context.Background())
	require.ErrorIs(t, err, io.EOF)
}

func TestTemporaryError(t *testing.T) {
	driver := createDriver(t, fmt.Errorf("whoopsie: %w", derive.ErrTemporary))
	err := driver.Step(context.Background())
26
	require.NoError(t, err, "should allow derivation to continue after temporary error")
27 28 29 30 31 32 33 34 35 36 37 38 39 40 41
}

func TestNotEnoughDataError(t *testing.T) {
	driver := createDriver(t, fmt.Errorf("idk: %w", derive.NotEnoughData))
	err := driver.Step(context.Background())
	require.NoError(t, err)
}

func TestGenericError(t *testing.T) {
	expected := errors.New("boom")
	driver := createDriver(t, expected)
	err := driver.Step(context.Background())
	require.ErrorIs(t, err, expected)
}

42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
func TestTargetBlock(t *testing.T) {
	t.Run("Reached", func(t *testing.T) {
		driver := createDriverWithNextBlock(t, derive.NotEnoughData, 1000)
		driver.targetBlockNum = 1000
		err := driver.Step(context.Background())
		require.ErrorIs(t, err, io.EOF)
	})

	t.Run("Exceeded", func(t *testing.T) {
		driver := createDriverWithNextBlock(t, derive.NotEnoughData, 1000)
		driver.targetBlockNum = 500
		err := driver.Step(context.Background())
		require.ErrorIs(t, err, io.EOF)
	})

	t.Run("NotYetReached", func(t *testing.T) {
		driver := createDriverWithNextBlock(t, derive.NotEnoughData, 1000)
		driver.targetBlockNum = 1001
		err := driver.Step(context.Background())
		// No error to indicate derivation should continue
		require.NoError(t, err)
	})
}

66 67 68 69 70 71
func TestNoError(t *testing.T) {
	driver := createDriver(t, nil)
	err := driver.Step(context.Background())
	require.NoError(t, err)
}

72 73 74 75
func TestValidateClaim(t *testing.T) {
	t.Run("Valid", func(t *testing.T) {
		driver := createDriver(t, io.EOF)
		expected := eth.Bytes32{0x11}
76
		driver.l2OutputRoot = func(_ uint64) (eth.Bytes32, error) {
77 78
			return expected, nil
		}
79
		err := driver.ValidateClaim(uint64(0), expected)
80
		require.NoError(t, err)
81 82 83 84
	})

	t.Run("Invalid", func(t *testing.T) {
		driver := createDriver(t, io.EOF)
85
		driver.l2OutputRoot = func(_ uint64) (eth.Bytes32, error) {
86 87
			return eth.Bytes32{0x22}, nil
		}
88
		err := driver.ValidateClaim(uint64(0), eth.Bytes32{0x11})
89
		require.ErrorIs(t, err, ErrClaimNotValid)
90 91 92 93
	})

	t.Run("Error", func(t *testing.T) {
		driver := createDriver(t, io.EOF)
94
		expectedErr := errors.New("boom")
95
		driver.l2OutputRoot = func(_ uint64) (eth.Bytes32, error) {
96
			return eth.Bytes32{}, expectedErr
97
		}
98
		err := driver.ValidateClaim(uint64(0), eth.Bytes32{0x11})
99
		require.ErrorIs(t, err, expectedErr)
100 101 102
	})
}

103
func createDriver(t *testing.T, derivationResult error) *Driver {
104 105 106 107 108
	return createDriverWithNextBlock(t, derivationResult, 0)
}

func createDriverWithNextBlock(t *testing.T, derivationResult error, nextBlockNum uint64) *Driver {
	derivation := &stubDerivation{nextErr: derivationResult, nextBlockNum: nextBlockNum}
109
	return &Driver{
110 111 112
		logger:         testlog.Logger(t, log.LvlDebug),
		pipeline:       derivation,
		targetBlockNum: 1_000_000,
113 114 115 116
	}
}

type stubDerivation struct {
117 118
	nextErr      error
	nextBlockNum uint64
119 120 121 122 123 124 125
}

func (s stubDerivation) Step(ctx context.Context) error {
	return s.nextErr
}

func (s stubDerivation) SafeL2Head() eth.L2BlockRef {
126 127 128
	return eth.L2BlockRef{
		Number: s.nextBlockNum,
	}
129
}