Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add cadence values migration #5192

Merged
merged 31 commits into from
Jan 26, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
31 commits
Select commit Hold shift + click to select a range
ff1df48
Merge branch 'feature/stable-cadence' of https://github.com/onflow/fl…
SupunS Jan 2, 2024
baf218f
Add cadence values migration step
SupunS Jan 2, 2024
7662f25
Add test for cadence value migrators
SupunS Jan 3, 2024
d1b2059
Merge updated paylaods with original payloads
SupunS Jan 4, 2024
af1cc82
Refactor
SupunS Jan 4, 2024
fdb0068
Write new payloads created during updates
SupunS Jan 8, 2024
d8669b1
Move PayloadsFromEmulatorSnapshot to utils
SupunS Jan 8, 2024
5fb1f02
Close migrator after completion
SupunS Jan 8, 2024
9eb4edb
Use LocalIDGenerator for generating Id's for link value migration
SupunS Jan 8, 2024
559fa95
Return commiting errors
SupunS Jan 9, 2024
92f88b7
Add transaction code used to store values in tests
SupunS Jan 9, 2024
a534015
Handle migration errors gracefully
SupunS Jan 9, 2024
f778b32
Separate link value migration from the rest
SupunS Jan 9, 2024
177c5c4
Add instructions for creating an emulator snapshot
SupunS Jan 9, 2024
8e59274
Add test for type-value/string-value key hashing
SupunS Jan 10, 2024
79d0d72
Add test for cacons and link value migrations
SupunS Jan 12, 2024
85b2076
Add environment.Accounts to migration runtime
SupunS Jan 12, 2024
cb39d98
Add test for account-types as dictionary keys
SupunS Jan 12, 2024
a7bdfb7
Add test for entitlements
SupunS Jan 17, 2024
88dd673
Update to the latest cadence migrations
SupunS Jan 18, 2024
650ffa1
Add test for running migrations in a diferent order
SupunS Jan 18, 2024
3be77eb
Update cadence
SupunS Jan 18, 2024
82365ae
Assert the account IDs
SupunS Jan 18, 2024
4de5312
Refactor
SupunS Jan 18, 2024
59def00
fix program loading
turbolent Jan 23, 2024
143ad1d
replace TODO with explanation
turbolent Jan 24, 2024
df8428b
Merge branch 'bastian/stable-cadence-update' of https://github.com/on…
SupunS Jan 25, 2024
ac05489
Fix tests
SupunS Jan 25, 2024
e0769ca
Merge branch 'feature/stable-cadence' into supun/cadence-migrations
turbolent Jan 25, 2024
bbe17b8
go mod tidy
turbolent Jan 25, 2024
039970c
Fix lint
SupunS Jan 26, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Separate link value migration from the rest
  • Loading branch information
SupunS committed Jan 9, 2024
commit f778b320843560f3efed982a15fa32b000c24b6a
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,8 @@ import (
"github.com/onflow/flow-go/model/flow"
"github.com/onflow/flow-go/module/metrics"
"github.com/onflow/flow-go/storage"

"github.com/onflow/cadence/runtime/interpreter"
)

func getStateCommitment(commits storage.Commits, blockHash flow.Identifier) (flow.StateCommitment, error) {
Expand Down Expand Up @@ -85,14 +87,17 @@ func extractExecutionState(

rwf := reporters.NewReportFileWriterFactory(dir, log)

capabilityIDs := map[interpreter.AddressPath]interpreter.UInt64Value{}

var migrations = []ledger.Migration{
migrators.CreateAccountBasedMigration(
log,
nWorker,
[]migrators.AccountBasedMigration{
// do account usage migration before and after as a sanity check.
&migrators.AccountUsageMigrator{},
migrators.NewCadenceValueMigrator(rwf),
migrators.NewCadenceLinkValueMigrator(rwf, capabilityIDs),
migrators.NewCadenceValueMigrator(rwf, capabilityIDs),
&migrators.AccountUsageMigrator{},
}),
}
Expand Down
101 changes: 64 additions & 37 deletions cmd/util/ledger/migrations/cadence_values_migration.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,29 +24,25 @@ import (
"github.com/onflow/cadence/runtime/interpreter"
)

type CadenceValueMigrator struct {
log zerolog.Logger
reporter reporters.ReportWriter
type CadenceBaseMigrator struct {
log zerolog.Logger
reporter reporters.ReportWriter
valueMigrations func(
_ environment.Accounts,
reporter *cadenceValueMigrationReporter,
) []migrations.ValueMigration
}

var _ AccountBasedMigration = (*CadenceValueMigrator)(nil)
var _ io.Closer = (*CadenceValueMigrator)(nil)
var _ AccountBasedMigration = (*CadenceBaseMigrator)(nil)
var _ io.Closer = (*CadenceBaseMigrator)(nil)

func NewCadenceValueMigrator(
rwf reporters.ReportWriterFactory,
) *CadenceValueMigrator {
return &CadenceValueMigrator{
reporter: rwf.ReportWriter("cadence-value-migrator"),
}
}

func (m *CadenceValueMigrator) Close() error {
func (m *CadenceBaseMigrator) Close() error {
// Close the report writer so it flushes to file.
m.reporter.Close()
return nil
}

func (m *CadenceValueMigrator) InitMigration(
func (m *CadenceBaseMigrator) InitMigration(
log zerolog.Logger,
_ []*ledger.Payload,
_ int,
Expand All @@ -55,7 +51,7 @@ func (m *CadenceValueMigrator) InitMigration(
return nil
}

func (m *CadenceValueMigrator) MigrateAccount(
func (m *CadenceBaseMigrator) MigrateAccount(
_ context.Context,
address common.Address,
oldPayloads []*ledger.Payload,
Expand All @@ -72,18 +68,10 @@ func (m *CadenceValueMigrator) MigrateAccount(
migrationRuntime.Storage,
)

capabilityIDs := map[interpreter.AddressPath]interpreter.UInt64Value{}

reporter := newValueMigrationReporter(m.reporter, m.log)

m.log.Info().Msg("Migrating cadence values")

idGenerator := environment.NewAccountLocalIDGenerator(
tracing.NewMockTracerSpan(),
util.NopMeter{},
accounts,
)

migration.Migrate(
&migrations.AddressSliceIterator{
Addresses: []common.Address{
Expand All @@ -92,18 +80,7 @@ func (m *CadenceValueMigrator) MigrateAccount(
},
migration.NewValueMigrationsPathMigrator(
reporter,
&capcons.CapabilityValueMigration{
CapabilityIDs: capabilityIDs,
Reporter: reporter,
},
&capcons.LinkValueMigration{
CapabilityIDs: capabilityIDs,
AccountIDGenerator: idGenerator,
Reporter: reporter,
},
string_normalization.NewStringNormalizingMigration(),
account_type.NewAccountTypeMigration(),
type_value.NewTypeValueMigration(),
m.valueMigrations(accounts, reporter)...,
),
)

Expand All @@ -123,7 +100,7 @@ func (m *CadenceValueMigrator) MigrateAccount(
return m.mergeRegisterChanges(migrationRuntime, result.WriteSet)
}

func (m *CadenceValueMigrator) mergeRegisterChanges(
func (m *CadenceBaseMigrator) mergeRegisterChanges(
mr *migratorRuntime,
changes map[flow.RegisterID]flow.RegisterValue,
SupunS marked this conversation as resolved.
Show resolved Hide resolved
) ([]*ledger.Payload, error) {
Expand Down Expand Up @@ -157,6 +134,56 @@ func (m *CadenceValueMigrator) mergeRegisterChanges(
return newPayloads, nil
}

func NewCadenceValueMigrator(
rwf reporters.ReportWriterFactory,
capabilityIDs map[interpreter.AddressPath]interpreter.UInt64Value,
) *CadenceBaseMigrator {
return &CadenceBaseMigrator{
reporter: rwf.ReportWriter("cadence-value-migrator"),
valueMigrations: func(
accounts environment.Accounts,
reporter *cadenceValueMigrationReporter,
) []migrations.ValueMigration {
// All cadence migrations except the `capcons.LinkValueMigration`.
return []migrations.ValueMigration{
&capcons.CapabilityValueMigration{
CapabilityIDs: capabilityIDs,
Reporter: reporter,
},
string_normalization.NewStringNormalizingMigration(),
account_type.NewAccountTypeMigration(),
type_value.NewTypeValueMigration(),
}
},
}
}

func NewCadenceLinkValueMigrator(
rwf reporters.ReportWriterFactory,
capabilityIDs map[interpreter.AddressPath]interpreter.UInt64Value,
) *CadenceBaseMigrator {
return &CadenceBaseMigrator{
reporter: rwf.ReportWriter("cadence-link-value-migrator"),
valueMigrations: func(
accounts environment.Accounts,
reporter *cadenceValueMigrationReporter,
) []migrations.ValueMigration {
idGenerator := environment.NewAccountLocalIDGenerator(
SupunS marked this conversation as resolved.
Show resolved Hide resolved
tracing.NewMockTracerSpan(),
util.NopMeter{},
accounts,
)
return []migrations.ValueMigration{
&capcons.LinkValueMigration{
CapabilityIDs: capabilityIDs,
AccountIDGenerator: idGenerator,
Reporter: reporter,
},
}
},
}
}

// cadenceValueMigrationReporter is the reporter for cadence value migrations
type cadenceValueMigrationReporter struct {
rw reporters.ReportWriter
Expand Down
44 changes: 41 additions & 3 deletions cmd/util/ledger/migrations/cadence_values_migration_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,8 @@ func TestCadenceValuesMigration(t *testing.T) {
// Migrate

rwf := &testReportWriterFactory{}
valueMigration := NewCadenceValueMigrator(rwf)
capabilityIDs := map[interpreter.AddressPath]interpreter.UInt64Value{}
valueMigration := NewCadenceValueMigrator(rwf, capabilityIDs)

buf := bytes.Buffer{}
logger := zerolog.New(&buf).Level(zerolog.ErrorLevel)
Expand Down Expand Up @@ -129,10 +130,47 @@ func TestCadenceValuesMigration(t *testing.T) {
},
)

// Check error logs
// Check error logs - should be empty.
assert.Equal(t, 0, buf.Len())
}

lines := readLines(&buf)
func TestLinkValueMigrationTypeErrors(t *testing.T) {

t.Parallel()

address, err := common.HexToAddress("01cf0e2f2f715450")
require.NoError(t, err)

// Get the old payloads

payloads, err := util.PayloadsFromEmulatorSnapshot(snapshotPath)
require.NoError(t, err)

// Migrate

rwf := &testReportWriterFactory{}
capabilityIDs := map[interpreter.AddressPath]interpreter.UInt64Value{}
valueMigration := NewCadenceLinkValueMigrator(rwf, capabilityIDs)

buf := bytes.Buffer{}
logger := zerolog.New(&buf).Level(zerolog.ErrorLevel)

err = valueMigration.InitMigration(logger, nil, 0)
require.NoError(t, err)

_, err = valueMigration.MigrateAccount(nil, address, payloads)
require.NoError(t, err)

err = valueMigration.Close()
require.NoError(t, err)

// Check reporters. No values should have been migrated.
reportWriter := valueMigration.reporter.(*testReportWriter)
assert.Empty(t, reportWriter.entries)

// Check error logs.
// Should have two type loading errors for link value migration.
lines := readLines(&buf)
require.Len(t, lines, 2)
assert.Contains(t, lines[0], "failed to run LinkValueMigration for path {01cf0e2f2f715450 /public/flowTokenReceiver}")
assert.Contains(t, lines[1], "failed to run LinkValueMigration for path {01cf0e2f2f715450 /public/flowTokenBalance}")
Expand Down