From eadef66c7806c6f24ad3b9ae91c7c09dce1c78cf Mon Sep 17 00:00:00 2001 From: Andrew Farries Date: Thu, 2 Jan 2025 11:02:52 +0000 Subject: [PATCH] Stop using pointers for `OpCreateIndex` fields (#565) Set JSON schema defaults for the optional fields in `OpCreateIndex` so that the generated types don't use pointers. This simplifies the use of those fields. --- pkg/migrations/op_create_index.go | 14 +++++++------- pkg/migrations/op_create_index_test.go | 6 +++--- pkg/migrations/types.go | 8 ++++---- schema.json | 12 ++++++++---- 4 files changed, 22 insertions(+), 18 deletions(-) diff --git a/pkg/migrations/op_create_index.go b/pkg/migrations/op_create_index.go index 7408471bd..80f71de4d 100644 --- a/pkg/migrations/op_create_index.go +++ b/pkg/migrations/op_create_index.go @@ -20,27 +20,27 @@ func (o *OpCreateIndex) Start(ctx context.Context, conn db.DB, latestSchema stri // create index concurrently stmtFmt := "CREATE INDEX CONCURRENTLY %s ON %s" - if o.Unique != nil && *o.Unique { + if o.Unique { stmtFmt = "CREATE UNIQUE INDEX CONCURRENTLY %s ON %s" } stmt := fmt.Sprintf(stmtFmt, pq.QuoteIdentifier(o.Name), pq.QuoteIdentifier(table.Name)) - if o.Method != nil { - stmt += fmt.Sprintf(" USING %s", string(*o.Method)) + if o.Method != "" { + stmt += fmt.Sprintf(" USING %s", string(o.Method)) } stmt += fmt.Sprintf(" (%s)", strings.Join( quoteColumnNames(table.PhysicalColumnNamesFor(o.Columns...)), ", "), ) - if o.StorageParameters != nil { - stmt += fmt.Sprintf(" WITH (%s)", *o.StorageParameters) + if o.StorageParameters != "" { + stmt += fmt.Sprintf(" WITH (%s)", o.StorageParameters) } - if o.Predicate != nil { - stmt += fmt.Sprintf(" WHERE %s", *o.Predicate) + if o.Predicate != "" { + stmt += fmt.Sprintf(" WHERE %s", o.Predicate) } _, err := conn.ExecContext(ctx, stmt) diff --git a/pkg/migrations/op_create_index_test.go b/pkg/migrations/op_create_index_test.go index ad8c67af2..a47cf1f5d 100644 --- a/pkg/migrations/op_create_index_test.go +++ b/pkg/migrations/op_create_index_test.go @@ -143,7 +143,7 @@ func TestCreateIndex(t *testing.T) { Name: "idx_users_name_after_2019", Table: "users", Columns: []string{"registered_at_year"}, - Predicate: ptr("registered_at_year > 2019"), + Predicate: "registered_at_year > 2019", }, }, }, @@ -235,8 +235,8 @@ func TestCreateIndex(t *testing.T) { Name: "idx_users_name_hash", Table: "users", Columns: []string{"name"}, - Method: ptr(migrations.OpCreateIndexMethodHash), - StorageParameters: ptr("fillfactor = 70"), + Method: migrations.OpCreateIndexMethodHash, + StorageParameters: "fillfactor = 70", }, }, }, diff --git a/pkg/migrations/types.go b/pkg/migrations/types.go index 2346d0bab..888d19091 100644 --- a/pkg/migrations/types.go +++ b/pkg/migrations/types.go @@ -177,22 +177,22 @@ type OpCreateIndex struct { Columns []string `json:"columns"` // Index method to use for the index: btree, hash, gist, spgist, gin, brin - Method *OpCreateIndexMethod `json:"method,omitempty"` + Method OpCreateIndexMethod `json:"method,omitempty"` // Index name Name string `json:"name"` // Conditional expression for defining a partial index - Predicate *string `json:"predicate,omitempty"` + Predicate string `json:"predicate,omitempty"` // Storage parameters for the index - StorageParameters *string `json:"storage_parameters,omitempty"` + StorageParameters string `json:"storage_parameters,omitempty"` // Name of table on which to define the index Table string `json:"table"` // Indicates if the index is unique - Unique *bool `json:"unique,omitempty"` + Unique bool `json:"unique,omitempty"` } type OpCreateIndexMethod string diff --git a/schema.json b/schema.json index 729699dff..4a35ee072 100644 --- a/schema.json +++ b/schema.json @@ -238,20 +238,24 @@ }, "predicate": { "description": "Conditional expression for defining a partial index", - "type": "string" + "type": "string", + "default": "" }, "method": { "description": "Index method to use for the index: btree, hash, gist, spgist, gin, brin", "type": "string", - "enum": ["btree", "hash", "gist", "spgist", "gin", "brin"] + "enum": ["btree", "hash", "gist", "spgist", "gin", "brin"], + "default": "btree" }, "storage_parameters": { "description": "Storage parameters for the index", - "type": "string" + "type": "string", + "default": "" }, "unique": { "description": "Indicates if the index is unique", - "type": "boolean" + "type": "boolean", + "default": false } }, "required": ["columns", "name", "table"],