diff --git a/mmv1/third_party/terraform/resources/resource_bigquery_table.go b/mmv1/third_party/terraform/resources/resource_bigquery_table.go index 8f9d2fde0fbf..97d74bdb98a3 100644 --- a/mmv1/third_party/terraform/resources/resource_bigquery_table.go +++ b/mmv1/third_party/terraform/resources/resource_bigquery_table.go @@ -522,6 +522,14 @@ func resourceBigQueryTable() *schema.Resource { Optional: true, Description: `When set, what mode of hive partitioning to use when reading data.`, }, + // RequirePartitionFilter: [Optional] If set to true, queries over this table + // require a partition filter that can be used for partition elimination to be + // specified. + "require_partition_filter": { + Type: schema.TypeBool, + Optional: true, + Description: `If set to true, queries over this table require a partition filter that can be used for partition elimination to be specified.`, + }, // SourceUriPrefix: [Optional] [Experimental] When hive partition detection is requested, a common for all source uris must be required. // The prefix must end immediately before the partition key encoding begins. "source_uri_prefix": { @@ -1399,6 +1407,10 @@ func expandHivePartitioningOptions(configured interface{}) *bigquery.HivePartiti opts.Mode = v.(string) } + if v, ok := raw["require_partition_filter"]; ok { + opts.RequirePartitionFilter = v.(bool) + } + if v, ok := raw["source_uri_prefix"]; ok { opts.SourceUriPrefix = v.(string) } @@ -1413,6 +1425,10 @@ func flattenHivePartitioningOptions(opts *bigquery.HivePartitioningOptions) []ma result["mode"] = opts.Mode } + if opts.RequirePartitionFilter { + result["require_partition_filter"] = opts.RequirePartitionFilter + } + if opts.SourceUriPrefix != "" { result["source_uri_prefix"] = opts.SourceUriPrefix } diff --git a/mmv1/third_party/terraform/tests/resource_bigquery_table_test.go b/mmv1/third_party/terraform/tests/resource_bigquery_table_test.go index 3d8fdcc98354..60cf75979ced 100644 --- a/mmv1/third_party/terraform/tests/resource_bigquery_table_test.go +++ b/mmv1/third_party/terraform/tests/resource_bigquery_table_test.go @@ -973,6 +973,7 @@ resource "google_bigquery_table" "test" { hive_partitioning_options { mode = "AUTO" source_uri_prefix = "gs://${google_storage_bucket.test.name}/" + require_partition_filter = true } } @@ -1011,6 +1012,7 @@ resource "google_bigquery_table" "test" { hive_partitioning_options { mode = "CUSTOM" source_uri_prefix = "gs://${google_storage_bucket.test.name}/{key1:STRING}" + require_partition_filter = true } schema = <