executor

package
v0.9.0-rc1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 20, 2019 License: Apache-2.0 Imports: 24 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

View Source
var (
	// ErrAlreadyDone is returned when you try to do backup for pulse less then lastBackupedPulse
	ErrAlreadyDone = errors.New("backup already done for this pulse")
	// ErrBackupDisabled is returned when backups are disabled
	ErrBackupDisabled = errors.New("backup disabled")
)

Functions

func FinalizePulse

func FinalizePulse(ctx context.Context, pulses pulse.Calculator, backuper BackupMaker, jetKeeper JetKeeper, indexes object.IndexModifier, newPulse insolar.PulseNumber)

FinalizePulse starts backup process if needed

func NewdropTruncaterMock

func NewdropTruncaterMock(t minimock.Tester) *dropTruncaterMock

NewdropTruncaterMock returns a mock for github.com/insolar/insolar/ledger/heavy/executor.headTruncater

Types

type BackupInfo

type BackupInfo struct {
	// SHA256 is hash of backup file
	SHA256 string
	// Pulse is number of backuped pulse
	Pulse insolar.PulseNumber
	// LastBackupedVersion is last backaped badger's version\timestamp
	LastBackupedVersion uint64
	// Since is badger's version\timestamp from which we started backup
	Since uint64
}

BackupInfo contains meta information about current incremental backup

type BackupMaker

type BackupMaker interface {
	// MakeBackup starts process of incremental backups
	MakeBackup(ctx context.Context, lastFinalizedPulse insolar.PulseNumber) error
}

BackupMaker is interface for doing backups

type BackupMakerDefault

type BackupMakerDefault struct {
	// contains filtered or unexported fields
}

BackupMakerDefault is component which does incremental backups by consequent invoke MakeBackup()

func NewBackupMaker

func NewBackupMaker(ctx context.Context, backuper store.Backuper, config configuration.Backup, lastBackupedPulse insolar.PulseNumber) (*BackupMakerDefault, error)

func (*BackupMakerDefault) MakeBackup

func (b *BackupMakerDefault) MakeBackup(ctx context.Context, lastFinalizedPulse insolar.PulseNumber) error

type BackupMakerMock

type BackupMakerMock struct {
	MakeBackupMock mBackupMakerMockMakeBackup
	// contains filtered or unexported fields
}

BackupMakerMock implements BackupMaker

func NewBackupMakerMock

func NewBackupMakerMock(t minimock.Tester) *BackupMakerMock

NewBackupMakerMock returns a mock for BackupMaker

func (*BackupMakerMock) MakeBackup

func (mmMakeBackup *BackupMakerMock) MakeBackup(ctx context.Context, lastFinalizedPulse insolar.PulseNumber) (err error)

MakeBackup implements BackupMaker

func (*BackupMakerMock) MakeBackupAfterCounter

func (mmMakeBackup *BackupMakerMock) MakeBackupAfterCounter() uint64

MakeBackupAfterCounter returns a count of finished BackupMakerMock.MakeBackup invocations

func (*BackupMakerMock) MakeBackupBeforeCounter

func (mmMakeBackup *BackupMakerMock) MakeBackupBeforeCounter() uint64

MakeBackupBeforeCounter returns a count of BackupMakerMock.MakeBackup invocations

func (*BackupMakerMock) MinimockFinish

func (m *BackupMakerMock) MinimockFinish()

MinimockFinish checks that all mocked methods have been called the expected number of times

func (*BackupMakerMock) MinimockMakeBackupDone

func (m *BackupMakerMock) MinimockMakeBackupDone() bool

MinimockMakeBackupDone returns true if the count of the MakeBackup invocations corresponds the number of defined expectations

func (*BackupMakerMock) MinimockMakeBackupInspect

func (m *BackupMakerMock) MinimockMakeBackupInspect()

MinimockMakeBackupInspect logs each unmet expectation

func (*BackupMakerMock) MinimockWait

func (m *BackupMakerMock) MinimockWait(timeout mm_time.Duration)

MinimockWait waits for all mocked methods to be called the expected number of times

type BackupMakerMockMakeBackupExpectation

type BackupMakerMockMakeBackupExpectation struct {
	Counter uint64
	// contains filtered or unexported fields
}

BackupMakerMockMakeBackupExpectation specifies expectation struct of the BackupMaker.MakeBackup

func (*BackupMakerMockMakeBackupExpectation) Then

Then sets up BackupMaker.MakeBackup return parameters for the expectation previously defined by the When method

type BackupMakerMockMakeBackupParams

type BackupMakerMockMakeBackupParams struct {
	// contains filtered or unexported fields
}

BackupMakerMockMakeBackupParams contains parameters of the BackupMaker.MakeBackup

type BackupMakerMockMakeBackupResults

type BackupMakerMockMakeBackupResults struct {
	// contains filtered or unexported fields
}

BackupMakerMockMakeBackupResults contains results of the BackupMaker.MakeBackup

type DBRollback

type DBRollback struct {
	// contains filtered or unexported fields
}

DBRollback is used for rollback all data which is not finalized It removes all data which was added after pulse which we consider as finalized

func NewDBRollback

func NewDBRollback(jetKeeper JetKeeper, pulseCalculator pulse.Calculator, dbs ...headTruncater) *DBRollback

func (*DBRollback) Start

func (d *DBRollback) Start(ctx context.Context) error

type FinalizationKeeper

type FinalizationKeeper interface {
	OnPulse(ctx context.Context, current insolar.PulseNumber) error
}

FinalizationKeeper check how far from each other last finalized pulse and current one and if distance is more than limit it stops network

type FinalizationKeeperDefault

type FinalizationKeeperDefault struct {
	// contains filtered or unexported fields
}

func NewFinalizationKeeperDefault

func NewFinalizationKeeperDefault(jk JetKeeper, pc pulse.Calculator, limit int) *FinalizationKeeperDefault

func (*FinalizationKeeperDefault) OnPulse

type HeadTruncaterMock

type HeadTruncaterMock struct {
	TruncateHeadMock mHeadTruncaterMockTruncateHead
	// contains filtered or unexported fields
}

HeadTruncaterMock implements headTruncater

func NewHeadTruncaterMock

func NewHeadTruncaterMock(t minimock.Tester) *HeadTruncaterMock

NewHeadTruncaterMock returns a mock for headTruncater

func (*HeadTruncaterMock) MinimockFinish

func (m *HeadTruncaterMock) MinimockFinish()

MinimockFinish checks that all mocked methods have been called the expected number of times

func (*HeadTruncaterMock) MinimockTruncateHeadDone

func (m *HeadTruncaterMock) MinimockTruncateHeadDone() bool

MinimockTruncateHeadDone returns true if the count of the TruncateHead invocations corresponds the number of defined expectations

func (*HeadTruncaterMock) MinimockTruncateHeadInspect

func (m *HeadTruncaterMock) MinimockTruncateHeadInspect()

MinimockTruncateHeadInspect logs each unmet expectation

func (*HeadTruncaterMock) MinimockWait

func (m *HeadTruncaterMock) MinimockWait(timeout mm_time.Duration)

MinimockWait waits for all mocked methods to be called the expected number of times

func (*HeadTruncaterMock) TruncateHead

func (mmTruncateHead *HeadTruncaterMock) TruncateHead(ctx context.Context, from insolar.PulseNumber) (err error)

TruncateHead implements headTruncater

func (*HeadTruncaterMock) TruncateHeadAfterCounter

func (mmTruncateHead *HeadTruncaterMock) TruncateHeadAfterCounter() uint64

TruncateHeadAfterCounter returns a count of finished HeadTruncaterMock.TruncateHead invocations

func (*HeadTruncaterMock) TruncateHeadBeforeCounter

func (mmTruncateHead *HeadTruncaterMock) TruncateHeadBeforeCounter() uint64

TruncateHeadBeforeCounter returns a count of HeadTruncaterMock.TruncateHead invocations

type HeadTruncaterMockTruncateHeadExpectation

type HeadTruncaterMockTruncateHeadExpectation struct {
	Counter uint64
	// contains filtered or unexported fields
}

HeadTruncaterMockTruncateHeadExpectation specifies expectation struct of the headTruncater.TruncateHead

func (*HeadTruncaterMockTruncateHeadExpectation) Then

Then sets up headTruncater.TruncateHead return parameters for the expectation previously defined by the When method

type HeadTruncaterMockTruncateHeadParams

type HeadTruncaterMockTruncateHeadParams struct {
	// contains filtered or unexported fields
}

HeadTruncaterMockTruncateHeadParams contains parameters of the headTruncater.TruncateHead

type HeadTruncaterMockTruncateHeadResults

type HeadTruncaterMockTruncateHeadResults struct {
	// contains filtered or unexported fields
}

HeadTruncaterMockTruncateHeadResults contains results of the headTruncater.TruncateHead

type HeavyReplicator

type HeavyReplicator interface {
	// NotifyAboutMessage is method for notifying a sync component about new data.
	NotifyAboutMessage(context.Context, *payload.Replication)

	// Stop stops the component.
	Stop()
}

HeavyReplicator is a base interface for a heavy sync component.

type HeavyReplicatorDefault

type HeavyReplicatorDefault struct {
	// contains filtered or unexported fields
}

HeavyReplicatorDefault is a base impl for HeavyReplicator

func NewHeavyReplicatorDefault

func NewHeavyReplicatorDefault(
	records object.RecordModifier,
	indexes object.IndexModifier,
	pcs insolar.PlatformCryptographyScheme,
	pulseCalculator pulse.Calculator,
	drops drop.Modifier,
	keeper JetKeeper,
	backuper BackupMaker,
	jets jet.Modifier,
) *HeavyReplicatorDefault

NewHeavyReplicatorDefault creates new instance of HeavyReplicatorDefault.

func (*HeavyReplicatorDefault) NotifyAboutMessage

func (h *HeavyReplicatorDefault) NotifyAboutMessage(ctx context.Context, msg *payload.Replication)

NotifyAboutMessage is method for notifying a sync component about new data.

func (*HeavyReplicatorDefault) Stop

func (h *HeavyReplicatorDefault) Stop()

Stop stops the component.

type JetKeeper

type JetKeeper interface {
	// AddDropConfirmation performs adding jet to storage and checks pulse completion.
	AddDropConfirmation(ctx context.Context, pn insolar.PulseNumber, jet insolar.JetID, split bool) error
	// AddHotConfirmation performs adding hot confirmation to storage and checks pulse completion.
	AddHotConfirmation(ctx context.Context, pn insolar.PulseNumber, jet insolar.JetID, split bool) error
	// AddBackupConfirmation performs adding backup confirmation to storage and checks pulse completion.
	AddBackupConfirmation(ctx context.Context, pn insolar.PulseNumber) error
	// TopSyncPulse provides access to highest synced (replicated) pulse.
	TopSyncPulse() insolar.PulseNumber
	// HasJetConfirms says if given pulse has drop and hot confirms. Ignore backups
	HasAllJetConfirms(ctx context.Context, pn insolar.PulseNumber) bool
}

JetKeeper provides a method for adding jet to storage, checking pulse completion and getting access to highest synced pulse.

func NewJetKeeper

func NewJetKeeper(jets jet.Storage, db store.DB, pulses pulse.Calculator) JetKeeper

type JetKeeperMock

type JetKeeperMock struct {
	AddBackupConfirmationMock mJetKeeperMockAddBackupConfirmation

	AddDropConfirmationMock mJetKeeperMockAddDropConfirmation

	AddHotConfirmationMock mJetKeeperMockAddHotConfirmation

	HasAllJetConfirmsMock mJetKeeperMockHasAllJetConfirms

	TopSyncPulseMock mJetKeeperMockTopSyncPulse
	// contains filtered or unexported fields
}

JetKeeperMock implements JetKeeper

func NewJetKeeperMock

func NewJetKeeperMock(t minimock.Tester) *JetKeeperMock

NewJetKeeperMock returns a mock for JetKeeper

func (*JetKeeperMock) AddBackupConfirmation

func (mmAddBackupConfirmation *JetKeeperMock) AddBackupConfirmation(ctx context.Context, pn insolar.PulseNumber) (err error)

AddBackupConfirmation implements JetKeeper

func (*JetKeeperMock) AddBackupConfirmationAfterCounter

func (mmAddBackupConfirmation *JetKeeperMock) AddBackupConfirmationAfterCounter() uint64

AddBackupConfirmationAfterCounter returns a count of finished JetKeeperMock.AddBackupConfirmation invocations

func (*JetKeeperMock) AddBackupConfirmationBeforeCounter

func (mmAddBackupConfirmation *JetKeeperMock) AddBackupConfirmationBeforeCounter() uint64

AddBackupConfirmationBeforeCounter returns a count of JetKeeperMock.AddBackupConfirmation invocations

func (*JetKeeperMock) AddDropConfirmation

func (mmAddDropConfirmation *JetKeeperMock) AddDropConfirmation(ctx context.Context, pn insolar.PulseNumber, jet insolar.JetID, split bool) (err error)

AddDropConfirmation implements JetKeeper

func (*JetKeeperMock) AddDropConfirmationAfterCounter

func (mmAddDropConfirmation *JetKeeperMock) AddDropConfirmationAfterCounter() uint64

AddDropConfirmationAfterCounter returns a count of finished JetKeeperMock.AddDropConfirmation invocations

func (*JetKeeperMock) AddDropConfirmationBeforeCounter

func (mmAddDropConfirmation *JetKeeperMock) AddDropConfirmationBeforeCounter() uint64

AddDropConfirmationBeforeCounter returns a count of JetKeeperMock.AddDropConfirmation invocations

func (*JetKeeperMock) AddHotConfirmation

func (mmAddHotConfirmation *JetKeeperMock) AddHotConfirmation(ctx context.Context, pn insolar.PulseNumber, jet insolar.JetID, split bool) (err error)

AddHotConfirmation implements JetKeeper

func (*JetKeeperMock) AddHotConfirmationAfterCounter

func (mmAddHotConfirmation *JetKeeperMock) AddHotConfirmationAfterCounter() uint64

AddHotConfirmationAfterCounter returns a count of finished JetKeeperMock.AddHotConfirmation invocations

func (*JetKeeperMock) AddHotConfirmationBeforeCounter

func (mmAddHotConfirmation *JetKeeperMock) AddHotConfirmationBeforeCounter() uint64

AddHotConfirmationBeforeCounter returns a count of JetKeeperMock.AddHotConfirmation invocations

func (*JetKeeperMock) HasAllJetConfirms

func (mmHasAllJetConfirms *JetKeeperMock) HasAllJetConfirms(ctx context.Context, pn insolar.PulseNumber) (b1 bool)

HasAllJetConfirms implements JetKeeper

func (*JetKeeperMock) HasAllJetConfirmsAfterCounter

func (mmHasAllJetConfirms *JetKeeperMock) HasAllJetConfirmsAfterCounter() uint64

HasAllJetConfirmsAfterCounter returns a count of finished JetKeeperMock.HasAllJetConfirms invocations

func (*JetKeeperMock) HasAllJetConfirmsBeforeCounter

func (mmHasAllJetConfirms *JetKeeperMock) HasAllJetConfirmsBeforeCounter() uint64

HasAllJetConfirmsBeforeCounter returns a count of JetKeeperMock.HasAllJetConfirms invocations

func (*JetKeeperMock) MinimockAddBackupConfirmationDone

func (m *JetKeeperMock) MinimockAddBackupConfirmationDone() bool

MinimockAddBackupConfirmationDone returns true if the count of the AddBackupConfirmation invocations corresponds the number of defined expectations

func (*JetKeeperMock) MinimockAddBackupConfirmationInspect

func (m *JetKeeperMock) MinimockAddBackupConfirmationInspect()

MinimockAddBackupConfirmationInspect logs each unmet expectation

func (*JetKeeperMock) MinimockAddDropConfirmationDone

func (m *JetKeeperMock) MinimockAddDropConfirmationDone() bool

MinimockAddDropConfirmationDone returns true if the count of the AddDropConfirmation invocations corresponds the number of defined expectations

func (*JetKeeperMock) MinimockAddDropConfirmationInspect

func (m *JetKeeperMock) MinimockAddDropConfirmationInspect()

MinimockAddDropConfirmationInspect logs each unmet expectation

func (*JetKeeperMock) MinimockAddHotConfirmationDone

func (m *JetKeeperMock) MinimockAddHotConfirmationDone() bool

MinimockAddHotConfirmationDone returns true if the count of the AddHotConfirmation invocations corresponds the number of defined expectations

func (*JetKeeperMock) MinimockAddHotConfirmationInspect

func (m *JetKeeperMock) MinimockAddHotConfirmationInspect()

MinimockAddHotConfirmationInspect logs each unmet expectation

func (*JetKeeperMock) MinimockFinish

func (m *JetKeeperMock) MinimockFinish()

MinimockFinish checks that all mocked methods have been called the expected number of times

func (*JetKeeperMock) MinimockHasAllJetConfirmsDone

func (m *JetKeeperMock) MinimockHasAllJetConfirmsDone() bool

MinimockHasAllJetConfirmsDone returns true if the count of the HasAllJetConfirms invocations corresponds the number of defined expectations

func (*JetKeeperMock) MinimockHasAllJetConfirmsInspect

func (m *JetKeeperMock) MinimockHasAllJetConfirmsInspect()

MinimockHasAllJetConfirmsInspect logs each unmet expectation

func (*JetKeeperMock) MinimockTopSyncPulseDone

func (m *JetKeeperMock) MinimockTopSyncPulseDone() bool

MinimockTopSyncPulseDone returns true if the count of the TopSyncPulse invocations corresponds the number of defined expectations

func (*JetKeeperMock) MinimockTopSyncPulseInspect

func (m *JetKeeperMock) MinimockTopSyncPulseInspect()

MinimockTopSyncPulseInspect logs each unmet expectation

func (*JetKeeperMock) MinimockWait

func (m *JetKeeperMock) MinimockWait(timeout mm_time.Duration)

MinimockWait waits for all mocked methods to be called the expected number of times

func (*JetKeeperMock) TopSyncPulse

func (mmTopSyncPulse *JetKeeperMock) TopSyncPulse() (p1 insolar.PulseNumber)

TopSyncPulse implements JetKeeper

func (*JetKeeperMock) TopSyncPulseAfterCounter

func (mmTopSyncPulse *JetKeeperMock) TopSyncPulseAfterCounter() uint64

TopSyncPulseAfterCounter returns a count of finished JetKeeperMock.TopSyncPulse invocations

func (*JetKeeperMock) TopSyncPulseBeforeCounter

func (mmTopSyncPulse *JetKeeperMock) TopSyncPulseBeforeCounter() uint64

TopSyncPulseBeforeCounter returns a count of JetKeeperMock.TopSyncPulse invocations

type JetKeeperMockAddBackupConfirmationExpectation

type JetKeeperMockAddBackupConfirmationExpectation struct {
	Counter uint64
	// contains filtered or unexported fields
}

JetKeeperMockAddBackupConfirmationExpectation specifies expectation struct of the JetKeeper.AddBackupConfirmation

func (*JetKeeperMockAddBackupConfirmationExpectation) Then

Then sets up JetKeeper.AddBackupConfirmation return parameters for the expectation previously defined by the When method

type JetKeeperMockAddBackupConfirmationParams

type JetKeeperMockAddBackupConfirmationParams struct {
	// contains filtered or unexported fields
}

JetKeeperMockAddBackupConfirmationParams contains parameters of the JetKeeper.AddBackupConfirmation

type JetKeeperMockAddBackupConfirmationResults

type JetKeeperMockAddBackupConfirmationResults struct {
	// contains filtered or unexported fields
}

JetKeeperMockAddBackupConfirmationResults contains results of the JetKeeper.AddBackupConfirmation

type JetKeeperMockAddDropConfirmationExpectation

type JetKeeperMockAddDropConfirmationExpectation struct {
	Counter uint64
	// contains filtered or unexported fields
}

JetKeeperMockAddDropConfirmationExpectation specifies expectation struct of the JetKeeper.AddDropConfirmation

func (*JetKeeperMockAddDropConfirmationExpectation) Then

Then sets up JetKeeper.AddDropConfirmation return parameters for the expectation previously defined by the When method

type JetKeeperMockAddDropConfirmationParams

type JetKeeperMockAddDropConfirmationParams struct {
	// contains filtered or unexported fields
}

JetKeeperMockAddDropConfirmationParams contains parameters of the JetKeeper.AddDropConfirmation

type JetKeeperMockAddDropConfirmationResults

type JetKeeperMockAddDropConfirmationResults struct {
	// contains filtered or unexported fields
}

JetKeeperMockAddDropConfirmationResults contains results of the JetKeeper.AddDropConfirmation

type JetKeeperMockAddHotConfirmationExpectation

type JetKeeperMockAddHotConfirmationExpectation struct {
	Counter uint64
	// contains filtered or unexported fields
}

JetKeeperMockAddHotConfirmationExpectation specifies expectation struct of the JetKeeper.AddHotConfirmation

func (*JetKeeperMockAddHotConfirmationExpectation) Then

Then sets up JetKeeper.AddHotConfirmation return parameters for the expectation previously defined by the When method

type JetKeeperMockAddHotConfirmationParams

type JetKeeperMockAddHotConfirmationParams struct {
	// contains filtered or unexported fields
}

JetKeeperMockAddHotConfirmationParams contains parameters of the JetKeeper.AddHotConfirmation

type JetKeeperMockAddHotConfirmationResults

type JetKeeperMockAddHotConfirmationResults struct {
	// contains filtered or unexported fields
}

JetKeeperMockAddHotConfirmationResults contains results of the JetKeeper.AddHotConfirmation

type JetKeeperMockHasAllJetConfirmsExpectation

type JetKeeperMockHasAllJetConfirmsExpectation struct {
	Counter uint64
	// contains filtered or unexported fields
}

JetKeeperMockHasAllJetConfirmsExpectation specifies expectation struct of the JetKeeper.HasAllJetConfirms

func (*JetKeeperMockHasAllJetConfirmsExpectation) Then

Then sets up JetKeeper.HasAllJetConfirms return parameters for the expectation previously defined by the When method

type JetKeeperMockHasAllJetConfirmsParams

type JetKeeperMockHasAllJetConfirmsParams struct {
	// contains filtered or unexported fields
}

JetKeeperMockHasAllJetConfirmsParams contains parameters of the JetKeeper.HasAllJetConfirms

type JetKeeperMockHasAllJetConfirmsResults

type JetKeeperMockHasAllJetConfirmsResults struct {
	// contains filtered or unexported fields
}

JetKeeperMockHasAllJetConfirmsResults contains results of the JetKeeper.HasAllJetConfirms

type JetKeeperMockTopSyncPulseExpectation

type JetKeeperMockTopSyncPulseExpectation struct {
	Counter uint64
	// contains filtered or unexported fields
}

JetKeeperMockTopSyncPulseExpectation specifies expectation struct of the JetKeeper.TopSyncPulse

type JetKeeperMockTopSyncPulseResults

type JetKeeperMockTopSyncPulseResults struct {
	// contains filtered or unexported fields
}

JetKeeperMockTopSyncPulseResults contains results of the JetKeeper.TopSyncPulse

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL