Skip to content

Commit

Permalink
Merge pull request #636 from ajkannan/minor-cleanup
Browse files Browse the repository at this point in the history
Docs, tests, and lint cleanup
  • Loading branch information
aozarov committed Feb 12, 2016
2 parents 1ab48bb + deb228f commit 8fb9e91
Show file tree
Hide file tree
Showing 17 changed files with 224 additions and 171 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -52,15 +52,15 @@ public class InsertAllRequest implements Serializable {
* id used by BigQuery to detect duplicate insertion requests on a best-effort basis.
*
* <p>Example usage of creating a row to insert:
* <pre> {@code
* List<Long> repeatedFieldValue = Arrays.asList(1L, 2L);
* Map<String, Object> recordContent = new HashMap<String, Object>();
* recordContent.put("subfieldName1", "value");
* recordContent.put("subfieldName2", repeatedFieldValue);
* Map<String, Object> rowContent = new HashMap<String, Object>();
* rowContent.put("fieldName1", true);
* rowContent.put("fieldName2", recordContent);
* RowToInsert row = new RowToInsert("rowId", rowContent);
* <pre> {@code
* List<Long> repeatedFieldValue = Arrays.asList(1L, 2L);
* Map<String, Object> recordContent = new HashMap<String, Object>();
* recordContent.put("subfieldName1", "value");
* recordContent.put("subfieldName2", repeatedFieldValue);
* Map<String, Object> rowContent = new HashMap<String, Object>();
* rowContent.put("fieldName1", true);
* rowContent.put("fieldName2", recordContent);
* RowToInsert row = new RowToInsert("rowId", rowContent);
* }</pre>
*
* @see <a href ="https://cloud.google.com/bigquery/streaming-data-into-bigquery#dataconsistency">
Expand Down Expand Up @@ -177,16 +177,16 @@ public Builder addRow(RowToInsert rowToInsert) {
* Adds a row to be inserted with associated id.
*
* <p>Example usage of adding a row with associated id:
* <pre> {@code
* InsertAllRequest.Builder builder = InsertAllRequest.builder(tableId);
* List<Long> repeatedFieldValue = Arrays.asList(1L, 2L);
* Map<String, Object> recordContent = new HashMap<String, Object>();
* recordContent.put("subfieldName1", "value");
* recordContent.put("subfieldName2", repeatedFieldValue);
* Map<String, Object> rowContent = new HashMap<String, Object>();
* rowContent.put("fieldName1", true);
* rowContent.put("fieldName2", recordContent);
* builder.addRow("rowId", rowContent);
* <pre> {@code
* InsertAllRequest.Builder builder = InsertAllRequest.builder(tableId);
* List<Long> repeatedFieldValue = Arrays.asList(1L, 2L);
* Map<String, Object> recordContent = new HashMap<String, Object>();
* recordContent.put("subfieldName1", "value");
* recordContent.put("subfieldName2", repeatedFieldValue);
* Map<String, Object> rowContent = new HashMap<String, Object>();
* rowContent.put("fieldName1", true);
* rowContent.put("fieldName2", recordContent);
* builder.addRow("rowId", rowContent);
* }</pre>
*/
public Builder addRow(String id, Map<String, Object> content) {
Expand All @@ -198,16 +198,16 @@ public Builder addRow(String id, Map<String, Object> content) {
* Adds a row to be inserted without an associated id.
*
* <p>Example usage of adding a row without an associated id:
* <pre> {@code
* InsertAllRequest.Builder builder = InsertAllRequest.builder(tableId);
* List<Long> repeatedFieldValue = Arrays.asList(1L, 2L);
* Map<String, Object> recordContent = new HashMap<String, Object>();
* recordContent.put("subfieldName1", "value");
* recordContent.put("subfieldName2", repeatedFieldValue);
* Map<String, Object> rowContent = new HashMap<String, Object>();
* rowContent.put("fieldName1", true);
* rowContent.put("fieldName2", recordContent);
* builder.addRow(rowContent);
* <pre> {@code
* InsertAllRequest.Builder builder = InsertAllRequest.builder(tableId);
* List<Long> repeatedFieldValue = Arrays.asList(1L, 2L);
* Map<String, Object> recordContent = new HashMap<String, Object>();
* recordContent.put("subfieldName1", "value");
* recordContent.put("subfieldName2", repeatedFieldValue);
* Map<String, Object> rowContent = new HashMap<String, Object>();
* rowContent.put("fieldName1", true);
* rowContent.put("fieldName2", recordContent);
* builder.addRow(rowContent);
* }</pre>
*/
public Builder addRow(Map<String, Object> content) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,26 +35,26 @@
* {@link QueryResponse#jobCompleted()} returns {@code true}.
*
* <p>Example usage of a query request:
* <pre> {@code
* // Substitute "field", "table" and "dataset" with real field, table and dataset identifiers
* QueryRequest request = QueryRequest.builder("SELECT field FROM table")
* .defaultDataset(DatasetId.of("dataset"))
* .maxWaitTime(60000L)
* .maxResults(1000L)
* .build();
* QueryResponse response = bigquery.query(request);
* while (!response.jobCompleted()) {
* Thread.sleep(1000);
* response = bigquery.getQueryResults(response.jobId());
* }
* List<BigQueryError> executionErrors = response.executionErrors();
* // look for errors in executionErrors
* QueryResult result = response.result();
* Iterator<List<FieldValue>> rowIterator = result.iterateAll();
* while(rowIterator.hasNext()) {
* List<FieldValue> row = rowIterator.next();
* // do something with row
* }
* <pre> {@code
* // Substitute "field", "table" and "dataset" with real field, table and dataset identifiers
* QueryRequest request = QueryRequest.builder("SELECT field FROM table")
* .defaultDataset(DatasetId.of("dataset"))
* .maxWaitTime(60000L)
* .maxResults(1000L)
* .build();
* QueryResponse response = bigquery.query(request);
* while (!response.jobCompleted()) {
* Thread.sleep(1000);
* response = bigquery.getQueryResults(response.jobId());
* }
* List<BigQueryError> executionErrors = response.executionErrors();
* // look for errors in executionErrors
* QueryResult result = response.result();
* Iterator<List<FieldValue>> rowIterator = result.iterateAll();
* while(rowIterator.hasNext()) {
* List<FieldValue> row = rowIterator.next();
* // do something with row
* }
* }</pre>
*
* @see <a href="https://cloud.google.com/bigquery/docs/reference/v2/jobs/query">Query</a>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -29,20 +29,20 @@
* Query Request ({@link BigQuery#query(QueryRequest)}).
*
* <p>Example usage of a query response:
* <pre> {@code
* QueryResponse response = bigquery.query(request);
* while (!response.jobCompleted()) {
* Thread.sleep(1000);
* response = bigquery.getQueryResults(response.jobId());
* }
* List<BigQueryError> executionErrors = response.executionErrors();
* // look for errors in executionErrors
* QueryResult result = response.result();
* Iterator<List<FieldValue>> rowIterator = result.iterateAll();
* while(rowIterator.hasNext()) {
* List<FieldValue> row = rowIterator.next();
* // do something with row
* }
* <pre> {@code
* QueryResponse response = bigquery.query(request);
* while (!response.jobCompleted()) {
* Thread.sleep(1000);
* response = bigquery.getQueryResults(response.jobId());
* }
* List<BigQueryError> executionErrors = response.executionErrors();
* // look for errors in executionErrors
* QueryResult result = response.result();
* Iterator<List<FieldValue>> rowIterator = result.iterateAll();
* while(rowIterator.hasNext()) {
* List<FieldValue> row = rowIterator.next();
* // do something with row
* }
* }</pre>
*
* @see <a href="https://cloud.google.com/bigquery/docs/reference/v2/jobs/getQueryResults">Get Query
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,14 +14,8 @@
* limitations under the License.
*/

package com.google.gcloud.bigquery;

import static com.google.gcloud.bigquery.BigQuery.DatasetField;
import static com.google.gcloud.bigquery.BigQuery.JobField;
import static com.google.gcloud.bigquery.BigQuery.JobListOption;
import static com.google.gcloud.bigquery.BigQuery.JobOption;
import static com.google.gcloud.bigquery.BigQuery.TableField;
import static com.google.gcloud.bigquery.BigQuery.TableOption;
package com.google.gcloud.bigquery.it;

import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertNotNull;
Expand All @@ -32,7 +26,42 @@
import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableMap;
import com.google.gcloud.Page;
import com.google.gcloud.WriteChannel;
import com.google.gcloud.bigquery.BigQuery;
import com.google.gcloud.bigquery.BigQuery.DatasetField;
import com.google.gcloud.bigquery.BigQuery.DatasetOption;
import com.google.gcloud.bigquery.BigQuery.JobField;
import com.google.gcloud.bigquery.BigQuery.JobListOption;
import com.google.gcloud.bigquery.BigQuery.JobOption;
import com.google.gcloud.bigquery.BigQuery.TableField;
import com.google.gcloud.bigquery.BigQuery.TableOption;
import com.google.gcloud.bigquery.BigQueryError;
import com.google.gcloud.bigquery.BigQueryException;
import com.google.gcloud.bigquery.CopyJobConfiguration;
import com.google.gcloud.bigquery.Dataset;
import com.google.gcloud.bigquery.DatasetId;
import com.google.gcloud.bigquery.DatasetInfo;
import com.google.gcloud.bigquery.ExternalTableDefinition;
import com.google.gcloud.bigquery.ExtractJobConfiguration;
import com.google.gcloud.bigquery.Field;
import com.google.gcloud.bigquery.FieldValue;
import com.google.gcloud.bigquery.FormatOptions;
import com.google.gcloud.bigquery.InsertAllRequest;
import com.google.gcloud.bigquery.InsertAllResponse;
import com.google.gcloud.bigquery.Job;
import com.google.gcloud.bigquery.JobInfo;
import com.google.gcloud.bigquery.LoadJobConfiguration;
import com.google.gcloud.bigquery.QueryJobConfiguration;
import com.google.gcloud.bigquery.QueryRequest;
import com.google.gcloud.bigquery.QueryResponse;
import com.google.gcloud.bigquery.Schema;
import com.google.gcloud.bigquery.StandardTableDefinition;
import com.google.gcloud.bigquery.Table;
import com.google.gcloud.bigquery.TableDefinition;
import com.google.gcloud.bigquery.TableId;
import com.google.gcloud.bigquery.TableInfo;
import com.google.gcloud.bigquery.ViewDefinition;
import com.google.gcloud.bigquery.WriteChannelConfiguration;
import com.google.gcloud.bigquery.testing.RemoteBigQueryHelper;
import com.google.gcloud.storage.BlobInfo;
import com.google.gcloud.storage.BucketInfo;
Expand All @@ -45,7 +74,6 @@
import org.junit.Test;
import org.junit.rules.Timeout;

import java.io.FileNotFoundException;
import java.io.IOException;
import java.nio.ByteBuffer;
import java.nio.charset.StandardCharsets;
Expand Down Expand Up @@ -140,7 +168,7 @@ public class ITBigQueryTest {
public Timeout globalTimeout = Timeout.seconds(300);

@BeforeClass
public static void beforeClass() throws IOException, InterruptedException {
public static void beforeClass() throws InterruptedException {
RemoteBigQueryHelper bigqueryHelper = RemoteBigQueryHelper.create();
RemoteGcsHelper gcsHelper = RemoteGcsHelper.create();
bigquery = bigqueryHelper.options().service();
Expand Down Expand Up @@ -169,8 +197,9 @@ public static void afterClass() throws ExecutionException, InterruptedException
if (bigquery != null) {
RemoteBigQueryHelper.forceDelete(bigquery, DATASET);
}
if (storage != null && !RemoteGcsHelper.forceDelete(storage, BUCKET, 10, TimeUnit.SECONDS)) {
if (LOG.isLoggable(Level.WARNING)) {
if (storage != null) {
boolean wasDeleted = RemoteGcsHelper.forceDelete(storage, BUCKET, 10, TimeUnit.SECONDS);
if (!wasDeleted && LOG.isLoggable(Level.WARNING)) {
LOG.log(Level.WARNING, "Deletion of bucket {0} timed out, bucket is not empty", BUCKET);
}
}
Expand Down Expand Up @@ -685,7 +714,7 @@ public void testListJobsWithSelectedFields() {
}

@Test
public void testCreateAndGetJob() throws InterruptedException {
public void testCreateAndGetJob() {
String sourceTableName = "test_create_and_get_job_source_table";
String destinationTableName = "test_create_and_get_job_destination_table";
TableId sourceTable = TableId.of(DATASET, sourceTableName);
Expand Down Expand Up @@ -717,7 +746,7 @@ public void testCreateAndGetJob() throws InterruptedException {
}

@Test
public void testCreateAndGetJobWithSelectedFields() throws InterruptedException {
public void testCreateAndGetJobWithSelectedFields() {
String sourceTableName = "test_create_and_get_job_with_selected_fields_source_table";
String destinationTableName = "test_create_and_get_job_with_selected_fields_destination_table";
TableId sourceTable = TableId.of(DATASET, sourceTableName);
Expand Down Expand Up @@ -874,20 +903,20 @@ public void testCancelJob() throws InterruptedException {
}

@Test
public void testCancelNonExistingJob() throws InterruptedException {
public void testCancelNonExistingJob() {
assertFalse(bigquery.cancel("test_cancel_non_existing_job"));
}

@Test
public void testInsertFromFile() throws InterruptedException, FileNotFoundException {
public void testInsertFromFile() throws InterruptedException {
String destinationTableName = "test_insert_from_file_table";
TableId tableId = TableId.of(DATASET, destinationTableName);
WriteChannelConfiguration configuration = WriteChannelConfiguration.builder(tableId)
.formatOptions(FormatOptions.json())
.createDisposition(JobInfo.CreateDisposition.CREATE_IF_NEEDED)
.schema(TABLE_SCHEMA)
.build();
try (TableDataWriteChannel channel = bigquery.writer(configuration)) {
try (WriteChannel channel = bigquery.writer(configuration)) {
channel.write(ByteBuffer.wrap(JSON_CONTENT.getBytes(StandardCharsets.UTF_8)));
} catch (IOException e) {
fail("IOException was not expected");
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,14 +21,14 @@
*
* <p>
* A typical capture usage:
* <pre> {@code
* <pre> {@code
* X restorableObj; // X instanceof Restorable<X>
* RestorableState<X> state = restorableObj.capture();
* .. persist state
* }</pre>
*
* A typical restore usage:
* <pre> {@code
* <pre> {@code
* RestorableState<X> state = ... // read from persistence
* X restorableObj = state.restore();
* ...
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -24,14 +24,14 @@
* to the Datastore upon {@link #submit}.
* A usage example:
* <pre> {@code
* Entity entity1 = datastore.get(key1);
* Batch batch = datastore.newBatch();
* Entity entity2 = Entity.builder(key2).set("name", "John").build();
* entity1 = Entity.builder(entity1).clear().setNull("bla").build();
* Entity entity3 = Entity.builder(key3).set("title", "title").build();
* batch.update(entity1);
* batch.add(entity2, entity3);
* batch.submit();
* Entity entity1 = datastore.get(key1);
* Batch batch = datastore.newBatch();
* Entity entity2 = Entity.builder(key2).set("name", "John").build();
* entity1 = Entity.builder(entity1).clear().setNull("bla").build();
* Entity entity3 = Entity.builder(key3).set("title", "title").build();
* batch.update(entity1);
* batch.add(entity2, entity3);
* batch.submit();
* } </pre>
*/
public interface Batch extends DatastoreBatchWriter {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -43,27 +43,27 @@
* <h3>A usage example:</h3>
*
* <p>When the type of the results is known the preferred usage would be:
* <pre>{@code
* Query<Entity> query =
* Query.gqlQueryBuilder(Query.ResultType.ENTITY, "select * from kind").build();
* QueryResults<Entity> results = datastore.run(query);
* while (results.hasNext()) {
* Entity entity = results.next();
* ...
* }
* <pre> {@code
* Query<Entity> query =
* Query.gqlQueryBuilder(Query.ResultType.ENTITY, "select * from kind").build();
* QueryResults<Entity> results = datastore.run(query);
* while (results.hasNext()) {
* Entity entity = results.next();
* ...
* }
* } </pre>
*
* <p>When the type of the results is unknown you can use this approach:
* <pre>{@code
* Query<?> query = Query.gqlQueryBuilder("select __key__ from kind").build();
* QueryResults<?> results = datastore.run(query);
* if (Key.class.isAssignableFrom(results.resultClass())) {
* QueryResults<Key> keys = (QueryResults<Key>) results;
* while (keys.hasNext()) {
* Key key = keys.next();
* ...
* }
* <pre> {@code
* Query<?> query = Query.gqlQueryBuilder("select __key__ from kind").build();
* QueryResults<?> results = datastore.run(query);
* if (Key.class.isAssignableFrom(results.resultClass())) {
* QueryResults<Key> keys = (QueryResults<Key>) results;
* while (keys.hasNext()) {
* Key key = keys.next();
* ...
* }
* }
* } </pre>
*
* @param <V> the type of the result values this query will produce
Expand Down
Loading

0 comments on commit 8fb9e91

Please sign in to comment.