From 37a135ed2b56a75083140799cb4c2baedc4923bb Mon Sep 17 00:00:00 2001 From: Modular Magician Date: Tue, 23 Jun 2020 23:12:17 +0000 Subject: [PATCH] add desc to schema for google_dataproc_job (#3664) Co-authored-by: Edward Sun Signed-off-by: Modular Magician --- .changelog/3664.txt | 3 + google-beta/resource_dataproc_job.go | 249 ++++++++++++++++----------- 2 files changed, 149 insertions(+), 103 deletions(-) create mode 100644 .changelog/3664.txt diff --git a/.changelog/3664.txt b/.changelog/3664.txt new file mode 100644 index 0000000000..8ec013c069 --- /dev/null +++ b/.changelog/3664.txt @@ -0,0 +1,3 @@ +```release-note:none + +``` diff --git a/google-beta/resource_dataproc_job.go b/google-beta/resource_dataproc_job.go index ce2e420d9b..e35d0039e8 100644 --- a/google-beta/resource_dataproc_job.go +++ b/google-beta/resource_dataproc_job.go @@ -25,34 +25,38 @@ func resourceDataprocJob() *schema.Resource { Schema: map[string]*schema.Schema{ "project": { - Type: schema.TypeString, - Optional: true, - Computed: true, - ForceNew: true, + Type: schema.TypeString, + Optional: true, + Computed: true, + ForceNew: true, + Description: `The project in which the cluster can be found and jobs subsequently run against. If it is not provided, the provider project is used.`, }, // Ref: https://cloud.google.com/dataproc/docs/reference/rest/v1/projects.regions.jobs#JobReference "region": { - Type: schema.TypeString, - Optional: true, - Default: "global", - ForceNew: true, + Type: schema.TypeString, + Optional: true, + Default: "global", + ForceNew: true, + Description: `The Cloud Dataproc region. This essentially determines which clusters are available for this job to be submitted to. If not specified, defaults to global.`, }, // If a job is still running, trying to delete a job will fail. Setting // this flag to true however will force the deletion by first cancelling // the job and then deleting it "force_delete": { - Type: schema.TypeBool, - Default: false, - Optional: true, + Type: schema.TypeBool, + Default: false, + Optional: true, + Description: `By default, you can only delete inactive jobs within Dataproc. Setting this to true, and calling destroy, will ensure that the job is first cancelled before issuing the delete.`, }, "reference": { - Type: schema.TypeList, - Optional: true, - Computed: true, - MaxItems: 1, + Type: schema.TypeList, + Optional: true, + Computed: true, + MaxItems: 1, + Description: `The reference of the job`, Elem: &schema.Resource{ Schema: map[string]*schema.Schema{ "job_id": { @@ -68,9 +72,10 @@ func resourceDataprocJob() *schema.Resource { }, "placement": { - Type: schema.TypeList, - Required: true, - MaxItems: 1, + Type: schema.TypeList, + Required: true, + MaxItems: 1, + Description: `The config of job placement.`, Elem: &schema.Resource{ Schema: map[string]*schema.Schema{ "cluster_name": { @@ -89,9 +94,10 @@ func resourceDataprocJob() *schema.Resource { }, "status": { - Type: schema.TypeList, - Computed: true, - MaxItems: 1, + Type: schema.TypeList, + Computed: true, + MaxItems: 1, + Description: `The status of the job.`, Elem: &schema.Resource{ Schema: map[string]*schema.Schema{ "state": { @@ -373,6 +379,7 @@ var pySparkSchema = &schema.Schema{ Optional: true, ForceNew: true, MaxItems: 1, + Description: `The config of pySpark job.`, ExactlyOneOf: []string{"pyspark_config", "spark_config", "hadoop_config", "hive_config", "pig_config", "sparksql_config"}, Elem: &schema.Resource{ Schema: map[string]*schema.Schema{ @@ -490,6 +497,7 @@ var sparkSchema = &schema.Schema{ Optional: true, ForceNew: true, MaxItems: 1, + Description: `The config of the Spark job.`, ExactlyOneOf: []string{"pyspark_config", "spark_config", "hadoop_config", "hive_config", "pig_config", "sparksql_config"}, Elem: &schema.Resource{ Schema: map[string]*schema.Schema{ @@ -498,6 +506,7 @@ var sparkSchema = &schema.Schema{ Type: schema.TypeString, Optional: true, ForceNew: true, + Description: `The class containing the main method of the driver. Must be in a provided jar or jar that is already on the classpath. Conflicts with main_jar_file_uri`, ExactlyOneOf: []string{"spark_config.0.main_class", "spark_config.0.main_jar_file_uri"}, }, @@ -505,42 +514,48 @@ var sparkSchema = &schema.Schema{ Type: schema.TypeString, Optional: true, ForceNew: true, + Description: `The HCFS URI of jar file containing the driver jar. Conflicts with main_class`, ExactlyOneOf: []string{"spark_config.0.main_jar_file_uri", "spark_config.0.main_class"}, }, "args": { - Type: schema.TypeList, - Optional: true, - ForceNew: true, - Elem: &schema.Schema{Type: schema.TypeString}, + Type: schema.TypeList, + Optional: true, + ForceNew: true, + Description: `The arguments to pass to the driver.`, + Elem: &schema.Schema{Type: schema.TypeString}, }, "jar_file_uris": { - Type: schema.TypeList, - Optional: true, - ForceNew: true, - Elem: &schema.Schema{Type: schema.TypeString}, + Type: schema.TypeList, + Optional: true, + ForceNew: true, + Description: `HCFS URIs of jar files to add to the CLASSPATHs of the Spark driver and tasks.`, + Elem: &schema.Schema{Type: schema.TypeString}, }, "file_uris": { - Type: schema.TypeList, - Optional: true, - ForceNew: true, - Elem: &schema.Schema{Type: schema.TypeString}, + Type: schema.TypeList, + Optional: true, + ForceNew: true, + Description: `HCFS URIs of files to be copied to the working directory of Spark drivers and distributed tasks. Useful for naively parallel tasks.`, + Elem: &schema.Schema{Type: schema.TypeString}, }, "archive_uris": { - Type: schema.TypeList, - Optional: true, - ForceNew: true, - Elem: &schema.Schema{Type: schema.TypeString}, + Type: schema.TypeList, + Optional: true, + ForceNew: true, + Description: `HCFS URIs of archives to be extracted in the working directory of .jar, .tar, .tar.gz, .tgz, and .zip.`, + Elem: &schema.Schema{Type: schema.TypeString}, }, "properties": { - Type: schema.TypeMap, - Optional: true, - ForceNew: true, - Elem: &schema.Schema{Type: schema.TypeString}, + Type: schema.TypeMap, + Optional: true, + ForceNew: true, + Description: `A mapping of property names to values, used to configure Spark. Properties that conflict with values set by the Cloud Dataproc API may be overwritten. Can include properties set in /etc/spark/conf/spark-defaults.conf and classes in user code.`, + Elem: &schema.Schema{Type: schema.TypeString}, }, "logging_config": loggingConfig, @@ -603,6 +618,7 @@ var hadoopSchema = &schema.Schema{ Optional: true, ForceNew: true, MaxItems: 1, + Description: `The config of Hadoop job`, ExactlyOneOf: []string{"spark_config", "pyspark_config", "hadoop_config", "hive_config", "pig_config", "sparksql_config"}, Elem: &schema.Resource{ Schema: map[string]*schema.Schema{ @@ -611,6 +627,7 @@ var hadoopSchema = &schema.Schema{ Type: schema.TypeString, Optional: true, ForceNew: true, + Description: `The class containing the main method of the driver. Must be in a provided jar or jar that is already on the classpath. Conflicts with main_jar_file_uri`, ExactlyOneOf: []string{"hadoop_config.0.main_jar_file_uri", "hadoop_config.0.main_class"}, }, @@ -618,42 +635,48 @@ var hadoopSchema = &schema.Schema{ Type: schema.TypeString, Optional: true, ForceNew: true, + Description: `The HCFS URI of jar file containing the driver jar. Conflicts with main_class`, ExactlyOneOf: []string{"hadoop_config.0.main_jar_file_uri", "hadoop_config.0.main_class"}, }, "args": { - Type: schema.TypeList, - Optional: true, - ForceNew: true, - Elem: &schema.Schema{Type: schema.TypeString}, + Type: schema.TypeList, + Optional: true, + ForceNew: true, + Description: `The arguments to pass to the driver.`, + Elem: &schema.Schema{Type: schema.TypeString}, }, "jar_file_uris": { - Type: schema.TypeList, - Optional: true, - ForceNew: true, - Elem: &schema.Schema{Type: schema.TypeString}, + Type: schema.TypeList, + Optional: true, + ForceNew: true, + Description: `HCFS URIs of jar files to add to the CLASSPATHs of the Spark driver and tasks.`, + Elem: &schema.Schema{Type: schema.TypeString}, }, "file_uris": { - Type: schema.TypeList, - Optional: true, - ForceNew: true, - Elem: &schema.Schema{Type: schema.TypeString}, + Type: schema.TypeList, + Optional: true, + ForceNew: true, + Description: `HCFS URIs of files to be copied to the working directory of Spark drivers and distributed tasks. Useful for naively parallel tasks.`, + Elem: &schema.Schema{Type: schema.TypeString}, }, "archive_uris": { - Type: schema.TypeList, - Optional: true, - ForceNew: true, - Elem: &schema.Schema{Type: schema.TypeString}, + Type: schema.TypeList, + Optional: true, + ForceNew: true, + Description: `HCFS URIs of archives to be extracted in the working directory of .jar, .tar, .tar.gz, .tgz, and .zip.`, + Elem: &schema.Schema{Type: schema.TypeString}, }, "properties": { - Type: schema.TypeMap, - Optional: true, - ForceNew: true, - Elem: &schema.Schema{Type: schema.TypeString}, + Type: schema.TypeMap, + Optional: true, + ForceNew: true, + Description: `A mapping of property names to values, used to configure Spark. Properties that conflict with values set by the Cloud Dataproc API may be overwritten. Can include properties set in /etc/spark/conf/spark-defaults.conf and classes in user code.`, + Elem: &schema.Schema{Type: schema.TypeString}, }, "logging_config": loggingConfig, @@ -716,6 +739,7 @@ var hiveSchema = &schema.Schema{ Optional: true, ForceNew: true, MaxItems: 1, + Description: `The config of hive job`, ExactlyOneOf: []string{"spark_config", "pyspark_config", "hadoop_config", "hive_config", "pig_config", "sparksql_config"}, Elem: &schema.Resource{ Schema: map[string]*schema.Schema{ @@ -724,6 +748,7 @@ var hiveSchema = &schema.Schema{ Type: schema.TypeList, Optional: true, ForceNew: true, + Description: `The list of Hive queries or statements to execute as part of the job. Conflicts with query_file_uri`, Elem: &schema.Schema{Type: schema.TypeString}, ExactlyOneOf: []string{"hive_config.0.query_file_uri", "hive_config.0.query_list"}, }, @@ -732,34 +757,39 @@ var hiveSchema = &schema.Schema{ Type: schema.TypeString, Optional: true, ForceNew: true, + Description: `HCFS URI of file containing Hive script to execute as the job. Conflicts with query_list`, ExactlyOneOf: []string{"hive_config.0.query_file_uri", "hive_config.0.query_list"}, }, "continue_on_failure": { - Type: schema.TypeBool, - Optional: true, - ForceNew: true, + Type: schema.TypeBool, + Optional: true, + ForceNew: true, + Description: `Whether to continue executing queries if a query fails. The default value is false. Setting to true can be useful when executing independent parallel queries. Defaults to false.`, }, "script_variables": { - Type: schema.TypeMap, - Optional: true, - ForceNew: true, - Elem: &schema.Schema{Type: schema.TypeString}, + Type: schema.TypeMap, + Optional: true, + ForceNew: true, + Description: `Mapping of query variable names to values (equivalent to the Hive command: SET name="value";).`, + Elem: &schema.Schema{Type: schema.TypeString}, }, "properties": { - Type: schema.TypeMap, - Optional: true, - ForceNew: true, - Elem: &schema.Schema{Type: schema.TypeString}, + Type: schema.TypeMap, + Optional: true, + ForceNew: true, + Description: `A mapping of property names and values, used to configure Hive. Properties that conflict with values set by the Cloud Dataproc API may be overwritten. Can include properties set in /etc/hadoop/conf/*-site.xml, /etc/hive/conf/hive-site.xml, and classes in user code.`, + Elem: &schema.Schema{Type: schema.TypeString}, }, "jar_file_uris": { - Type: schema.TypeList, - Optional: true, - ForceNew: true, - Elem: &schema.Schema{Type: schema.TypeString}, + Type: schema.TypeList, + Optional: true, + ForceNew: true, + Description: `HCFS URIs of jar files to add to the CLASSPATH of the Hive server and Hadoop MapReduce (MR) tasks. Can contain Hive SerDes and UDFs.`, + Elem: &schema.Schema{Type: schema.TypeString}, }, }, }, @@ -815,6 +845,7 @@ var pigSchema = &schema.Schema{ Optional: true, ForceNew: true, MaxItems: 1, + Description: `The config of pag job.`, ExactlyOneOf: []string{"spark_config", "pyspark_config", "hadoop_config", "hive_config", "pig_config", "sparksql_config"}, Elem: &schema.Resource{ Schema: map[string]*schema.Schema{ @@ -823,6 +854,7 @@ var pigSchema = &schema.Schema{ Type: schema.TypeList, Optional: true, ForceNew: true, + Description: `The list of Hive queries or statements to execute as part of the job. Conflicts with query_file_uri`, Elem: &schema.Schema{Type: schema.TypeString}, ExactlyOneOf: []string{"pig_config.0.query_file_uri", "pig_config.0.query_list"}, }, @@ -831,34 +863,39 @@ var pigSchema = &schema.Schema{ Type: schema.TypeString, Optional: true, ForceNew: true, + Description: `HCFS URI of file containing Hive script to execute as the job. Conflicts with query_list`, ExactlyOneOf: []string{"pig_config.0.query_file_uri", "pig_config.0.query_list"}, }, "continue_on_failure": { - Type: schema.TypeBool, - Optional: true, - ForceNew: true, + Type: schema.TypeBool, + Optional: true, + ForceNew: true, + Description: `Whether to continue executing queries if a query fails. The default value is false. Setting to true can be useful when executing independent parallel queries. Defaults to false.`, }, "script_variables": { - Type: schema.TypeMap, - Optional: true, - ForceNew: true, - Elem: &schema.Schema{Type: schema.TypeString}, + Type: schema.TypeMap, + Optional: true, + ForceNew: true, + Description: `Mapping of query variable names to values (equivalent to the Pig command: name=[value]).`, + Elem: &schema.Schema{Type: schema.TypeString}, }, "properties": { - Type: schema.TypeMap, - Optional: true, - ForceNew: true, - Elem: &schema.Schema{Type: schema.TypeString}, + Type: schema.TypeMap, + Optional: true, + ForceNew: true, + Description: `A mapping of property names to values, used to configure Pig. Properties that conflict with values set by the Cloud Dataproc API may be overwritten. Can include properties set in /etc/hadoop/conf/*-site.xml, /etc/pig/conf/pig.properties, and classes in user code.`, + Elem: &schema.Schema{Type: schema.TypeString}, }, "jar_file_uris": { - Type: schema.TypeList, - Optional: true, - ForceNew: true, - Elem: &schema.Schema{Type: schema.TypeString}, + Type: schema.TypeList, + Optional: true, + ForceNew: true, + Description: `HCFS URIs of jar files to add to the CLASSPATH of the Pig Client and Hadoop MapReduce (MR) tasks. Can contain Pig UDFs.`, + Elem: &schema.Schema{Type: schema.TypeString}, }, "logging_config": loggingConfig, @@ -917,6 +954,7 @@ var sparkSqlSchema = &schema.Schema{ Optional: true, ForceNew: true, MaxItems: 1, + Description: `The config of SparkSql job`, ExactlyOneOf: []string{"spark_config", "pyspark_config", "hadoop_config", "hive_config", "pig_config", "sparksql_config"}, Elem: &schema.Resource{ Schema: map[string]*schema.Schema{ @@ -925,6 +963,7 @@ var sparkSqlSchema = &schema.Schema{ Type: schema.TypeList, Optional: true, ForceNew: true, + Description: `The list of SQL queries or statements to execute as part of the job. Conflicts with query_file_uri`, Elem: &schema.Schema{Type: schema.TypeString}, ExactlyOneOf: []string{"sparksql_config.0.query_file_uri", "sparksql_config.0.query_list"}, }, @@ -933,28 +972,32 @@ var sparkSqlSchema = &schema.Schema{ Type: schema.TypeString, Optional: true, ForceNew: true, + Description: `The HCFS URI of the script that contains SQL queries. Conflicts with query_list`, ExactlyOneOf: []string{"sparksql_config.0.query_file_uri", "sparksql_config.0.query_list"}, }, "script_variables": { - Type: schema.TypeMap, - Optional: true, - ForceNew: true, - Elem: &schema.Schema{Type: schema.TypeString}, + Type: schema.TypeMap, + Optional: true, + ForceNew: true, + Description: `Mapping of query variable names to values (equivalent to the Spark SQL command: SET name="value";).`, + Elem: &schema.Schema{Type: schema.TypeString}, }, "properties": { - Type: schema.TypeMap, - Optional: true, - ForceNew: true, - Elem: &schema.Schema{Type: schema.TypeString}, + Type: schema.TypeMap, + Optional: true, + ForceNew: true, + Description: `A mapping of property names to values, used to configure Spark SQL's SparkConf. Properties that conflict with values set by the Cloud Dataproc API may be overwritten.`, + Elem: &schema.Schema{Type: schema.TypeString}, }, "jar_file_uris": { - Type: schema.TypeList, - Optional: true, - ForceNew: true, - Elem: &schema.Schema{Type: schema.TypeString}, + Type: schema.TypeList, + Optional: true, + ForceNew: true, + Description: `HCFS URIs of jar files to be added to the Spark CLASSPATH.`, + Elem: &schema.Schema{Type: schema.TypeString}, }, "logging_config": loggingConfig,