From 7af12e369f1e197c05c55ca3f5301a4332c941b1 Mon Sep 17 00:00:00 2001 From: Anand Swaminathan Date: Fri, 14 Aug 2020 12:37:53 -0700 Subject: [PATCH] Add Parent_id index for Admin database (#115) * Add Parent_id index for Admin database --- flyteadmin/pkg/repositories/config/migrations.go | 10 +++++++++- flyteadmin/pkg/repositories/models/node_execution.go | 2 +- flyteadmin/tests/node_execution_test.go | 4 ++-- 3 files changed, 12 insertions(+), 4 deletions(-) diff --git a/flyteadmin/pkg/repositories/config/migrations.go b/flyteadmin/pkg/repositories/config/migrations.go index 2debdd84c7..a8f53bc9e7 100644 --- a/flyteadmin/pkg/repositories/config/migrations.go +++ b/flyteadmin/pkg/repositories/config/migrations.go @@ -233,7 +233,6 @@ var Migrations = []*gormigrate.Migration{ return tx.Model(&models.NodeExecution{}).DropColumn("cache_status").Error }, }, - { ID: "2020-07-31-node-execution", Migrate: func(tx *gorm.DB) error { @@ -243,4 +242,13 @@ var Migrations = []*gormigrate.Migration{ return tx.Model(&models.NodeExecution{}).DropColumn("parent_id").DropColumn("node_execution_metadata").Error }, }, + { + ID: "2020-08-13-node-execution", + Migrate: func(tx *gorm.DB) error { + return tx.AutoMigrate(&models.NodeExecution{}).Error + }, + Rollback: func(tx *gorm.DB) error { + return tx.Model(&models.NodeExecution{}).DropColumn("parent_id").DropColumn("node_execution_metadata").Error + }, + }, } diff --git a/flyteadmin/pkg/repositories/models/node_execution.go b/flyteadmin/pkg/repositories/models/node_execution.go index 89ddb3b70c..a55d669510 100644 --- a/flyteadmin/pkg/repositories/models/node_execution.go +++ b/flyteadmin/pkg/repositories/models/node_execution.go @@ -32,7 +32,7 @@ type NodeExecution struct { // Metadata about the node execution. NodeExecutionMetadata []byte // Parent that spawned this node execution - value is empty for executions at level 0 - ParentID *uint `sql:"default:null"` + ParentID *uint `sql:"default:null" gorm:"index"` // List of child node executions - for cases like Dynamic task, sub workflow, etc ChildNodeExecutions []NodeExecution `gorm:"foreignkey:ParentID"` // The task execution (if any) which launched this node execution. diff --git a/flyteadmin/tests/node_execution_test.go b/flyteadmin/tests/node_execution_test.go index 13a0c8aeab..56921c53a9 100644 --- a/flyteadmin/tests/node_execution_test.go +++ b/flyteadmin/tests/node_execution_test.go @@ -347,7 +347,7 @@ func TestListNodeExecutionWithParent(t *testing.T) { assert.Len(t, response.NodeExecutions, 2) nodeExecutionResponse = response.NodeExecutions[0] assert.True(t, proto.Equal(&core.NodeExecutionIdentifier{ - NodeId: "child", + NodeId: "child2", ExecutionId: nodeExecutionId.ExecutionId, }, nodeExecutionResponse.Id)) assert.Equal(t, core.NodeExecution_RUNNING, nodeExecutionResponse.Closure.Phase) @@ -356,7 +356,7 @@ func TestListNodeExecutionWithParent(t *testing.T) { nodeExecutionResponse = response.NodeExecutions[1] assert.True(t, proto.Equal(&core.NodeExecutionIdentifier{ - NodeId: "child2", + NodeId: "child", ExecutionId: nodeExecutionId.ExecutionId, }, nodeExecutionResponse.Id)) assert.Equal(t, core.NodeExecution_RUNNING, nodeExecutionResponse.Closure.Phase)