 Documentation
      ¶
      Documentation
      ¶
    
    
  
    
  
    Index ¶
- func PluginTestSuiteRunner(t *testing.T, newPlugin NewPluginFunc, destSpec specs.Destination, ...)
- func RecordDiff(l arrow.Record, r arrow.Record) string
- type Client
- type ClientResource
- type ManagedWriter
- type Metrics
- type MigrateStrategy
- type NewClientFunc
- type NewPluginFunc
- type Option
- type Plugin
- func (p *Plugin) Close(ctx context.Context) error
- func (p *Plugin) DeleteStale(ctx context.Context, tables schema.Tables, sourceName string, ...) error
- func (p *Plugin) Init(ctx context.Context, logger zerolog.Logger, spec specs.Destination) error
- func (p *Plugin) Metrics() Metrics
- func (p *Plugin) Migrate(ctx context.Context, tables schema.Tables) error
- func (p *Plugin) Name() string
- func (p *Plugin) Read(ctx context.Context, table *schema.Table, sourceName string, ...) error
- func (p *Plugin) Version() string
- func (p *Plugin) Write(ctx context.Context, sourceSpec specs.Source, tables schema.Tables, ...) error
 
- type PluginTestSuite
- type PluginTestSuiteTests
- type UnimplementedManagedWriter
- type UnimplementedUnmanagedWriter
- type UnmanagedWriter
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func PluginTestSuiteRunner ¶
func PluginTestSuiteRunner(t *testing.T, newPlugin NewPluginFunc, destSpec specs.Destination, tests PluginTestSuiteTests, testSourceOptions ...func(o *schema.TestSourceOptions))
Types ¶
type Client ¶
type Client interface {
	Migrate(ctx context.Context, tables schema.Tables) error
	Read(ctx context.Context, table *schema.Table, sourceName string, res chan<- arrow.Record) error
	ManagedWriter
	UnmanagedWriter
	DeleteStale(ctx context.Context, tables schema.Tables, sourceName string, syncTime time.Time) error
	Close(ctx context.Context) error
}
    type ClientResource ¶
type ManagedWriter ¶
type MigrateStrategy ¶
type MigrateStrategy struct {
	AddColumn           specs.MigrateMode
	AddColumnNotNull    specs.MigrateMode
	RemoveColumn        specs.MigrateMode
	RemoveColumnNotNull specs.MigrateMode
	ChangeColumn        specs.MigrateMode
}
    MigrateStrategy defines which tests we should include
type NewClientFunc ¶
type NewPluginFunc ¶
type NewPluginFunc func() *Plugin
type Option ¶
type Option func(*Plugin)
func WithBatchTimeout ¶
func WithDefaultBatchSize ¶
func WithManagedWriter ¶
func WithManagedWriter() Option
type Plugin ¶
type Plugin struct {
	// contains filtered or unexported fields
}
    func NewPlugin ¶
func NewPlugin(name string, version string, newClientFunc NewClientFunc, opts ...Option) *Plugin
NewPlugin creates a new destination plugin
func (*Plugin) DeleteStale ¶
func (*Plugin) Migrate ¶
we implement all DestinationClient functions so we can hook into pre-post behavior
type PluginTestSuite ¶
type PluginTestSuite struct {
	// contains filtered or unexported fields
}
    type PluginTestSuiteTests ¶
type PluginTestSuiteTests struct {
	// SkipOverwrite skips testing for "overwrite" mode. Use if the destination
	// plugin doesn't support this feature.
	SkipOverwrite bool
	// SkipDeleteStale skips testing "delete-stale" mode. Use if the destination
	// plugin doesn't support this feature.
	SkipDeleteStale bool
	// SkipAppend skips testing for "append" mode. Use if the destination
	// plugin doesn't support this feature.
	SkipAppend bool
	// SkipSecondAppend skips the second append step in the test.
	// This is useful in cases like cloud storage where you can't append to an
	// existing object after the file has been closed.
	SkipSecondAppend bool
	// SkipMigrateAppend skips a test for the migrate function where a column is added,
	// data is appended, then the column is removed and more data appended, checking that the migrations handle
	// this correctly.
	SkipMigrateAppend bool
	// SkipMigrateAppendForce skips a test for the migrate function where a column is changed in force mode
	SkipMigrateAppendForce bool
	// SkipMigrateOverwrite skips a test for the migrate function where a column is added,
	// data is appended, then the column is removed and more data overwritten, checking that the migrations handle
	// this correctly.
	SkipMigrateOverwrite bool
	// SkipMigrateOverwriteForce skips a test for the migrate function where a column is changed in force mode
	SkipMigrateOverwriteForce bool
	MigrateStrategyOverwrite MigrateStrategy
	MigrateStrategyAppend    MigrateStrategy
}
    type UnimplementedManagedWriter ¶
type UnimplementedManagedWriter struct{}
    func (UnimplementedManagedWriter) WriteTableBatch ¶
type UnimplementedUnmanagedWriter ¶
type UnimplementedUnmanagedWriter struct{}
    func (UnimplementedUnmanagedWriter) Metrics ¶
func (UnimplementedUnmanagedWriter) Metrics() Metrics
 Click to show internal directories. 
   Click to hide internal directories.