Revision 2d510d2f272c7b96926477987ef7b7e9e3f5667c authored by Anton Kaliaev on 20 January 2020, 10:41:26 UTC, committed by GitHub on 20 January 2020, 10:41:26 UTC
* rpc: update urls to rpc website

* rpc: check blockMeta is not nil in Commit

Refs #4319
1 parent 9cbfe79
Raw File
provider_test.go
package lite

import (
	"errors"
	"testing"

	"github.com/stretchr/testify/assert"
	"github.com/stretchr/testify/require"

	log "github.com/tendermint/tendermint/libs/log"
	lerr "github.com/tendermint/tendermint/lite/errors"
	"github.com/tendermint/tendermint/types"
	dbm "github.com/tendermint/tm-db"
)

// missingProvider doesn't store anything, always a miss.
// Designed as a mock for testing.
type missingProvider struct{}

// NewMissingProvider returns a provider which does not store anything and always misses.
func NewMissingProvider() PersistentProvider {
	return missingProvider{}
}

func (missingProvider) SaveFullCommit(FullCommit) error { return nil }
func (missingProvider) LatestFullCommit(chainID string, minHeight, maxHeight int64) (FullCommit, error) {
	return FullCommit{}, lerr.ErrCommitNotFound()
}
func (missingProvider) ValidatorSet(chainID string, height int64) (*types.ValidatorSet, error) {
	return nil, errors.New("missing validator set")
}
func (missingProvider) SetLogger(_ log.Logger) {}

func TestMemProvider(t *testing.T) {
	p := NewDBProvider("mem", dbm.NewMemDB())
	checkProvider(t, p, "test-mem", "empty")
}

func TestMultiProvider(t *testing.T) {
	p := NewMultiProvider(
		NewMissingProvider(),
		NewDBProvider("mem", dbm.NewMemDB()),
		NewMissingProvider(),
	)
	checkProvider(t, p, "test-cache", "kjfhekfhkewhgit")
}

func checkProvider(t *testing.T, p PersistentProvider, chainID, app string) {
	assert, require := assert.New(t), require.New(t)
	appHash := []byte(app)
	keys := genPrivKeys(5)
	count := 10

	// Make a bunch of full commits.
	fcz := make([]FullCommit, count)
	for i := 0; i < count; i++ {
		vals := keys.ToValidators(10, int64(count/2))
		h := int64(20 + 10*i)
		fcz[i] = keys.GenFullCommit(chainID, h, nil, vals, vals, appHash, []byte("params"), []byte("results"), 0, 5)
	}

	// Check that provider is initially empty.
	fc, err := p.LatestFullCommit(chainID, 1, 1<<63-1)
	require.NotNil(err)
	assert.True(lerr.IsErrCommitNotFound(err))

	// Save all full commits to the provider.
	for _, fc := range fcz {
		err = p.SaveFullCommit(fc)
		require.Nil(err)
		// Make sure we can get it back.
		fc2, err := p.LatestFullCommit(chainID, fc.Height(), fc.Height())
		assert.Nil(err)
		assert.Equal(fc.SignedHeader, fc2.SignedHeader)
		assert.Equal(fc.Validators, fc2.Validators)
		assert.Equal(fc.NextValidators, fc2.NextValidators)
	}

	// Make sure we get the last hash if we overstep.
	fc, err = p.LatestFullCommit(chainID, 1, 5000)
	if assert.Nil(err) {
		assert.Equal(fcz[count-1].Height(), fc.Height())
		assert.Equal(fcz[count-1], fc)
	}

	// ... and middle ones as well.
	fc, err = p.LatestFullCommit(chainID, 1, 47)
	if assert.Nil(err) {
		// we only step by 10, so 40 must be the one below this
		assert.EqualValues(40, fc.Height())
	}

}

// This will make a get height, and if it is good, set the data as well.
func checkLatestFullCommit(t *testing.T, p PersistentProvider, chainID string, ask, expect int64) {
	fc, err := p.LatestFullCommit(chainID, 1, ask)
	require.Nil(t, err)
	if assert.Equal(t, expect, fc.Height()) {
		err = p.SaveFullCommit(fc)
		require.Nil(t, err)
	}
}

func TestMultiLatestFullCommit(t *testing.T) {
	require := require.New(t)

	// We will write data to the second level of the cache (p2), and see what
	// gets cached/stored in.
	p := NewDBProvider("mem1", dbm.NewMemDB())
	p2 := NewDBProvider("mem2", dbm.NewMemDB())
	cp := NewMultiProvider(p, p2)

	chainID := "cache-best-height"
	appHash := []byte("01234567")
	keys := genPrivKeys(5)
	count := 10

	// Set a bunch of full commits.
	for i := 0; i < count; i++ {
		vals := keys.ToValidators(10, int64(count/2))
		h := int64(10 * (i + 1))
		fc := keys.GenFullCommit(chainID, h, nil, vals, vals, appHash, []byte("params"), []byte("results"), 0, 5)
		err := p2.SaveFullCommit(fc)
		require.NoError(err)
	}

	// Get a few heights from the cache and set them proper.
	checkLatestFullCommit(t, cp, chainID, 57, 50)
	checkLatestFullCommit(t, cp, chainID, 33, 30)

	// make sure they are set in p as well (but nothing else)
	checkLatestFullCommit(t, p, chainID, 44, 30)
	checkLatestFullCommit(t, p, chainID, 50, 50)
	checkLatestFullCommit(t, p, chainID, 99, 50)

	// now, query the cache for a higher value
	checkLatestFullCommit(t, p2, chainID, 99, 90)
	checkLatestFullCommit(t, cp, chainID, 99, 90)
}
back to top