Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: add Connection interface #1374

Merged
merged 311 commits into from
May 6, 2022
Merged
Changes from 1 commit
Commits
Show all changes
311 commits
Select commit Hold shift + click to select a range
ca33f25
manage dependencies
stephaniewang526 Oct 26, 2021
517e287
Merge branch 'main' into query-interface
stephaniewang526 Oct 26, 2021
a5b7734
manage dependencies
stephaniewang526 Oct 26, 2021
f299562
Merge branch 'main' into query-interface
stephaniewang526 Oct 26, 2021
5ee68b4
update pagination logic
stephaniewang526 Oct 27, 2021
ac33915
Minor cleanup
prash-mi Oct 28, 2021
427e82d
Updated the bufferSize
prash-mi Oct 28, 2021
90a238d
Added testBQResultSetPagination
prash-mi Oct 28, 2021
b1dd598
refactored processQueryResponseResults
prash-mi Oct 28, 2021
12ad71c
updated testBQResultSetPagination to use generated table
prash-mi Oct 29, 2021
7651405
implemented a child thread for fetching next page
prash-mi Nov 9, 2021
403c6ef
Adding processQueryResponseResults2 (Independent pageFetcher and prod…
prash-mi Nov 10, 2021
d93d183
Adding processQueryResponseResults2 (Independent pageFetcher and prod…
prash-mi Nov 10, 2021
2989d32
Merge branch 'main' into query-interface
stephaniewang526 Nov 12, 2021
6ba31b7
nit: correct Javadoc
stephaniewang526 Nov 15, 2021
e6a480b
Added getPageCacheSize for dynamically computing the size of pageCache
prash-mi Nov 16, 2021
a4ec57f
Fixed NPE @ getPageCacheSize
prash-mi Nov 17, 2021
c593545
Refactored - Renamed processQueryResponseResults methods
prash-mi Nov 17, 2021
dede418
Refactored - exception handling for processQueryResponseResults
prash-mi Nov 17, 2021
6c79796
Added testConnectionCancel for testing ConnectionImpl.cancel
prash-mi Nov 19, 2021
4156217
Added ConnectionImpl.cancel implementation and the interrupt logic in…
prash-mi Nov 19, 2021
07885e6
Lint
prash-mi Nov 19, 2021
109d123
Commented testConnectionCancel - Need to update the Cancel Method logic
prash-mi Nov 22, 2021
1a582f3
Implemented processQueryResponseResults_thread_pooled
prash-mi Nov 22, 2021
b8e39fa
nit: rename a few vars
stephaniewang526 Nov 22, 2021
7bd4e7b
Uncommented testConnectionCancel
prash-mi Nov 23, 2021
6748795
Cleaned processQueryResponseResults. Removed unused methods. Implemen…
prash-mi Nov 23, 2021
2cb8099
Cleaned processQueryResponseResults. Removed unused methods. Implemen…
prash-mi Nov 23, 2021
c04e620
Merge branch 'main' into query-interface
stephaniewang526 Nov 23, 2021
74f177d
add sessions support and BigQueryResultSetStats interface and impl
stephaniewang526 Nov 23, 2021
58ed6d2
add BigQueryResultSetStats to getQueryResults path; refactor jobs.get…
stephaniewang526 Nov 23, 2021
5fad3e5
feat: add support for BI Engine Statistics
stephaniewang526 Dec 1, 2021
f42e1ac
fix conflict
stephaniewang526 Dec 2, 2021
73e05fd
Updated pageCacheSize and buffer's size between a MIN and MAX bound.
prash-mi Dec 7, 2021
86bdf13
🦉 Updates from OwlBot
gcf-owl-bot[bot] Dec 8, 2021
512ee95
Merge branch 'query-interface' of https://github.com/stephaniewang526…
prash-mi Dec 9, 2021
bcf6dfd
Refactored processQueryResponseResults to avoid code duplicity. Added…
prash-mi Dec 9, 2021
1d900b5
Implemented processGetQueryResponseResults(results, jobId) & Refactor…
prash-mi Dec 9, 2021
40a9226
Implemented BigQueryDryRunResultImpl
prash-mi Dec 21, 2021
26d55e3
implemented dryRun
prash-mi Dec 21, 2021
8c14392
Implemented execute select logic when the FastQuery is not Supported
prash-mi Dec 28, 2021
ca9b7d4
added null check at useReadAPI
prash-mi Dec 29, 2021
8e683e7
Added BQResultSet Test cases
prash-mi Dec 29, 2021
0e8b973
code cleanup and refactoring
stephaniewang526 Dec 29, 2021
fd9122a
Merge remote-tracking branch 'origin/query-interface' into query-inte…
stephaniewang526 Dec 29, 2021
af0b8f7
resolve merge conflict
stephaniewang526 Dec 29, 2021
8d65193
add import
stephaniewang526 Dec 29, 2021
e8f1e71
additional lint
stephaniewang526 Dec 29, 2021
26bc6bb
🦉 Updates from OwlBot
gcf-owl-bot[bot] Dec 29, 2021
4aea35a
add test requirements
stephaniewang526 Dec 29, 2021
6816ada
Merge remote-tracking branch 'origin/query-interface' into query-inte…
stephaniewang526 Dec 29, 2021
a9c47ef
add dryRun implementation
stephaniewang526 Jan 9, 2022
b738b57
Added schema check @ testConnectionImplDryRun
prash-mi Jan 17, 2022
b82d831
Added schema check @ testConnectionImplDryRun
prash-mi Jan 17, 2022
2a34bc6
Added Java Doc, Removed commented code of processGetQueryResults
prash-mi Jan 17, 2022
0ca0724
Added SetUp and testExecuteSelect
prash-mi Jan 19, 2022
d911ea7
Exposing processQueryResponseResults for testing
prash-mi Jan 19, 2022
5e5666a
Exposing processQueryResponseResults for testing
prash-mi Jan 19, 2022
49959a5
Added testFastQueryMultiplePages and testCancel
prash-mi Jan 19, 2022
66e947e
Added testQueryDryRun
prash-mi Jan 19, 2022
4daeb76
Exposing Async methods for testing
prash-mi Jan 20, 2022
b32bbdc
Exposing Async methods for testing
prash-mi Jan 20, 2022
171da1f
Exposing tableDataListRpc for testing
prash-mi Jan 20, 2022
8971a27
Exposed tableDataListRpc for testing
prash-mi Jan 20, 2022
9bc67d4
Added testcases for the 3 async methods
prash-mi Jan 20, 2022
d70ad74
Exposing getQueryResultsFirstPage, isFastQuerySupported and getSubseq…
prash-mi Jan 21, 2022
98c6578
Exposing getQueryResultsFirstPage, isFastQuerySupported and getSubseq…
prash-mi Jan 21, 2022
4251f25
Added testGetQueryResultsFirstPage and testLegacyQuerySinglePage test…
prash-mi Jan 21, 2022
cae60ef
Deleted TODO
prash-mi Jan 21, 2022
497a824
Exposed getDestinationTable and tableDataList for testing
prash-mi Jan 21, 2022
cec20bb
Exposed getDestinationTable and tableDataList for testing
prash-mi Jan 21, 2022
27a68d0
Added testFastQueryLongRunning testcase
prash-mi Jan 21, 2022
c3c2d14
Added testLegacyQueryMultiplePages
prash-mi Jan 21, 2022
5bbb066
Added BigqueryStorage and Arrow's dependencies
prash-mi Feb 2, 2022
92e8883
Added draft impl for highThroughPutRead
prash-mi Feb 2, 2022
44e871c
Merge branch 'main' into query-interface
stephaniewang526 Feb 2, 2022
b0bf13a
resolve dependency issues
stephaniewang526 Feb 2, 2022
c1743c9
🦉 Updates from OwlBot
gcf-owl-bot[bot] Feb 2, 2022
3297e4d
Added Attribute to for ArrowSchema
prash-mi Feb 8, 2022
ca244eb
updated highThroughPutRead
prash-mi Feb 8, 2022
7cded43
Revert "Added Attribute to for ArrowSchema"
prash-mi Feb 8, 2022
33920a7
composed BigQueryResultSetImpl with all the params
prash-mi Feb 8, 2022
c25ae5a
Added parsing logic for ArrowVectors
prash-mi Feb 10, 2022
f411699
Update processRows
prash-mi Feb 11, 2022
39ed020
updated next methods and getters for 3 data types
prash-mi Feb 11, 2022
99301ef
Added translateAndThrow(Exception ex)
prash-mi Feb 15, 2022
19318bb
Refactored processRows, added exception handling
prash-mi Feb 15, 2022
0fb2906
Added arrow-memory-netty
prash-mi Feb 15, 2022
8714d89
Updated highThroughPutRead - Code fix and refactoring
prash-mi Feb 15, 2022
d1e3b64
clean up Connection.java and remove methods meant only for testing fr…
stephaniewang526 Feb 16, 2022
30cbd57
Updated to StandardSQLTypeName
prash-mi Feb 22, 2022
f0dd594
Added Arrow specific logic for primitive getters
prash-mi Feb 23, 2022
820b454
Added Arrow specific parsing logic for primitive getters
prash-mi Feb 23, 2022
661dbf5
Added Arrow specific parsing logic for additional datatypes
prash-mi Feb 24, 2022
b4cfb2d
Modified the getter's logic for parsing arrow
prash-mi Feb 24, 2022
3191005
Added Interrupt logic for Arrow processing
prash-mi Feb 24, 2022
92a7b59
Added Arrow Support in ResultSet Methods
prash-mi Mar 3, 2022
77db382
Removed typecasting from processRows method
prash-mi Mar 3, 2022
1f64c63
Added Json typecasting logic
prash-mi Mar 3, 2022
d7cbe09
Updated Arrow dependency to latest
prash-mi Mar 4, 2022
2c01cf6
Added UseReadAPI property
prash-mi Mar 4, 2022
999df03
Updated useReadAPI
prash-mi Mar 4, 2022
b9bdd85
Updated useReadAPI
prash-mi Mar 4, 2022
3986358
feat: add Interval type support (#1844)
stephaniewang526 Feb 11, 2022
4248a7f
Reformat
prash-mi Mar 7, 2022
b339e4a
Merge branch 'main' into query-interface
stephaniewang526 Mar 7, 2022
87e3f9e
remove unused declacred dependency: org.apache.arrow:arrow-memory-net…
stephaniewang526 Mar 7, 2022
b7076e7
🦉 Updates from OwlBot post-processor
gcf-owl-bot[bot] Mar 7, 2022
45440de
fixed getDate
prash-mi Mar 8, 2022
10581dc
Merge branch 'query-interface' of https://github.com/stephaniewang526…
prash-mi Mar 8, 2022
d77bb27
format
prash-mi Mar 8, 2022
a8b63d2
Added containsIntervalType check
prash-mi Mar 8, 2022
8423576
Added containsIntervalType check
prash-mi Mar 8, 2022
bd746ee
Merge branch 'main' into query-interface
stephaniewang526 Mar 8, 2022
d7f3de0
add back the arrow-netty dependency
stephaniewang526 Mar 8, 2022
9cb0527
add a rule to ignore org.apache.arrow:arrow-memory-netty in maven-dep…
stephaniewang526 Mar 8, 2022
ca2e27c
Fixed getTime
prash-mi Mar 9, 2022
3eb7bc4
Updated getString
prash-mi Mar 9, 2022
03cc9ea
🦉 Updates from OwlBot post-processor
gcf-owl-bot[bot] Mar 10, 2022
26d880e
Merge branch 'main' into query-interface
stephaniewang526 Mar 10, 2022
bbe20d5
Added Nightly Integration test for testing Read API integration
prash-mi Mar 15, 2022
7986f69
Merge remote-tracking branch 'origin/query-interface' into query-inte…
prash-mi Mar 15, 2022
e049c38
Added Nightly Integration test for testing Read API integration
prash-mi Mar 15, 2022
44b9f32
Added Nightly Integration test for testing Read API integration
prash-mi Mar 15, 2022
708fa53
Modified Nightly Integration test
prash-mi Mar 15, 2022
90ce594
Fixed NPE during bulk read
prash-mi Mar 15, 2022
44f7dc2
Merge remote-tracking branch 'origin/query-interface' into query-inte…
prash-mi Mar 15, 2022
f427725
Fixed class cast exception @ getLong
prash-mi Mar 15, 2022
4c7bfc7
Added @BetaApi Annotation
prash-mi Mar 16, 2022
82f6745
Added @BetaApi Annotation
prash-mi Mar 16, 2022
78d691c
Exposed methods for unit testing
prash-mi Mar 17, 2022
f24e4c2
Added more unit testing
prash-mi Mar 17, 2022
69de2e8
fixed getString to handle LocalDateTime
prash-mi Mar 21, 2022
4fa2f96
Added ConnImplBenchmark
prash-mi Mar 24, 2022
5eaa7b6
Added instructions for running ConnImplBenchmark
prash-mi Mar 24, 2022
a7f20ed
Updated Java Docs
prash-mi Mar 29, 2022
01f6a18
Merge branch 'main' into query-interface
stephaniewang526 Mar 29, 2022
1218d2f
add IT TODOs
stephaniewang526 Mar 29, 2022
5675160
Fixed getInt for JSONField types (Int returned as Text)
prash-mi Apr 4, 2022
e15c1cf
Added JsonType tests
prash-mi Apr 4, 2022
f407e1b
Added test - testForAllDataTypeValues
prash-mi Apr 4, 2022
52f23e1
Added translateAndThrowBigQuerySQLException
prash-mi Apr 5, 2022
f77a791
Added Exception Handling for executeSelect methods
prash-mi Apr 5, 2022
dece7ac
Added testInvalidQuery
prash-mi Apr 5, 2022
e2f3fc8
Added testMultipleRuns
prash-mi Apr 5, 2022
e8b2705
Added testPositionalParams
prash-mi Apr 5, 2022
0efcd96
updated positional query
prash-mi Apr 5, 2022
f303962
Merge branch 'main' into query-interface
stephaniewang526 Apr 12, 2022
fb77468
update logic to not use Read API when QueryParameters are passed sinc…
stephaniewang526 Apr 13, 2022
9486217
update support for query parameters
stephaniewang526 Apr 18, 2022
dcbd33e
chore(main): release 2.10.8 (#1979)
release-please[bot] Apr 14, 2022
5a20d42
chore(main): release 2.10.9-SNAPSHOT (#1980)
release-please[bot] Apr 14, 2022
384dece
deps: update dependency com.google.cloud:native-image-support to v0.1…
renovate-bot Apr 15, 2022
1f22d4f
chore(deps): update dependency com.google.cloud:google-cloud-bigquery…
renovate-bot Apr 15, 2022
7f18b6a
deps: update dependency com.google.cloud:google-cloud-shared-dependen…
renovate-bot Apr 15, 2022
78903db
chore(deps): update dependency com.google.cloud:google-cloud-bigquery…
renovate-bot Apr 16, 2022
f989b3c
test(deps): update dependency com.google.cloud:google-cloud-datacatal…
renovate-bot Apr 16, 2022
7dfcda1
chore(main): release 2.10.9 (#1984)
release-please[bot] Apr 16, 2022
abe9b7e
chore(main): release 2.10.10-SNAPSHOT (#1988)
release-please[bot] Apr 16, 2022
00c9e40
chore(deps): update dependency com.google.cloud:google-cloud-bigquery…
renovate-bot Apr 18, 2022
917b3ea
deps: update dependency com.google.cloud:google-cloud-storage to v2.6…
renovate-bot Apr 18, 2022
d864514
deps: update dependency com.google.cloud:google-cloud-bigtable to v2.…
renovate-bot Apr 18, 2022
1d262dc
chore(main): release 2.10.10 (#1992)
release-please[bot] Apr 18, 2022
ac03e54
fix dependencies.sh
stephaniewang526 Apr 18, 2022
27a0304
Merge branch 'main' into query-interface
stephaniewang526 Apr 19, 2022
e33f705
🦉 Updates from OwlBot post-processor
gcf-owl-bot[bot] Apr 19, 2022
c9b02ad
update query parameters for dryRun
stephaniewang526 Apr 19, 2022
68b6acf
Merge remote-tracking branch 'origin/query-interface' into query-inte…
stephaniewang526 Apr 19, 2022
e5be724
Made Label optional by making it a vararg
prash-mi Apr 20, 2022
c6f6883
Made Label optional by making it a vararg
prash-mi Apr 20, 2022
ffa3be0
Removed null labels
prash-mi Apr 20, 2022
bcdaa6d
Renamed cancel to close
prash-mi Apr 21, 2022
eb37332
Refactored testConnectionCancel
prash-mi Apr 21, 2022
1b03be8
Renamed cancel() to close()
prash-mi Apr 21, 2022
48d99d5
Renamed testCancel
prash-mi Apr 21, 2022
8cbef78
Added testPositionalParams
prash-mi Apr 21, 2022
251eace
Replaced all the shutdownNows with MoreExecutors.shutdownAndAwaitTerm…
prash-mi Apr 26, 2022
28d620c
Using TimeUnit.DAYS.toMillis for conversion from Days to Millis
prash-mi Apr 26, 2022
d8af94f
deleted outdated comment
prash-mi Apr 26, 2022
57fd5e4
nit update
stephaniewang526 Apr 26, 2022
78259c5
update based on comments
stephaniewang526 Apr 26, 2022
9b8db32
Merge remote-tracking branch 'origin/query-interface' into query-inte…
prash-mi Apr 27, 2022
25eb4e5
updated to using a public dataset
prash-mi Apr 27, 2022
e7b4cb6
updated cancel() to close()
prash-mi Apr 27, 2022
1a7e512
using constants for clientConnectionConfiguration
prash-mi Apr 27, 2022
6a1f69d
using constants for clientConnectionConfiguration
prash-mi Apr 27, 2022
15b5fae
updated Warmup iterations to 1
prash-mi Apr 27, 2022
9191dbb
updated dataset
prash-mi Apr 27, 2022
350767c
Fix for testConnectionClose IT
prash-mi Apr 27, 2022
b071123
update labels and close method
gcf-owl-bot[bot] Apr 19, 2022
9ebf5e7
update based on comments
prash-mi Apr 26, 2022
6c2a9f9
Merge branch 'main' into query-interface
stephaniewang526 Apr 28, 2022
11c156c
Merge remote-tracking branch 'origin/query-interface' into query-inte…
prash-mi Apr 29, 2022
ad75b17
Refactored code - Replaced Tuple<Map<String, Object>, Boolean> with Row
prash-mi Apr 29, 2022
274b4b7
Added class Row and Refactored code - Replaced Tuple<Map<String, Obje…
prash-mi Apr 29, 2022
dfa5fd6
Added overloaded constructor with just message as an argument
prash-mi Apr 29, 2022
69014c4
refactored and added BigQuerySQLException in next()
prash-mi Apr 29, 2022
5d59bb5
refactored and added throwing BigQuerySQLException
prash-mi Apr 29, 2022
90a767a
Added fieldvalue null checks
prash-mi Apr 29, 2022
409deb9
modified close
prash-mi Apr 29, 2022
b5a0899
modified close
prash-mi Apr 29, 2022
7ff528f
modified getLong
prash-mi Apr 29, 2022
f52620e
address feedback
prash-mi Apr 26, 2022
d77320d
update based on comments
prash-mi Apr 26, 2022
6a7875e
chore(deps): update dependency com.google.cloud:google-cloud-bigquery…
renovate-bot Apr 19, 2022
b174634
feat: next release from main branch is 2.10.9 (#1996)
prash-mi Apr 19, 2022
849d22b
build(deps): update dependency com.google.cloud:google-cloud-shared-c…
renovate-bot Apr 20, 2022
91af825
test(deps): update dependency org.mockito:mockito-core to v4.5.0 (#1999)
renovate-bot Apr 20, 2022
5689ec0
test(deps): update dependency org.mockito:mockito-core to v4.5.1 (#2003)
renovate-bot Apr 21, 2022
0e4122e
build(deps): update dependency org.apache.maven.plugins:maven-javadoc…
renovate-bot Apr 21, 2022
6e9083a
build(deps): update dependency org.sonatype.plugins:nexus-staging-mav…
renovate-bot Apr 21, 2022
17bbe83
chore(deps): update dependency com.google.cloud:google-cloud-bigquery…
renovate-bot Apr 22, 2022
e402471
chore(deps): update dependency com.google.cloud:libraries-bom to v25.…
renovate-bot Apr 26, 2022
4f2c3d7
docs(sample): remove unused dependency and add setup instructions (#2…
mpeddada1 Apr 27, 2022
4078b9f
build(deps): update dependency org.apache.maven.plugins:maven-project…
renovate-bot Apr 28, 2022
684a9da
chore: IT clean-up (#2012)
stephaniewang526 Apr 28, 2022
f4e2208
build(deps): update dependency com.google.cloud:google-cloud-shared-c…
renovate-bot Apr 28, 2022
439e0ae
address feedback
prash-mi Apr 29, 2022
c3e5b67
Merge branch 'main' into query-interface
stephaniewang526 Apr 29, 2022
eececc3
add clarification to dryRun query params
stephaniewang526 Apr 29, 2022
6c6d173
Fixed BigQuerySQLException in the Integration Tests
prash-mi May 2, 2022
72d5cbf
Merge remote-tracking branch 'origin/query-interface' into query-inte…
prash-mi May 2, 2022
74b4c65
Added line comment
prash-mi May 2, 2022
a9c5ed1
Updated getInt to include check for Long
prash-mi May 2, 2022
a76843b
Added testReadAPIIterationAndOrder IT
prash-mi May 2, 2022
df2208d
Merge branch 'main' into query-interface
stephaniewang526 May 2, 2022
e1acb6d
Add testReadAPIConnectionMultiClose, Removed ReadClientConnectionConf…
prash-mi May 4, 2022
825fc7b
Refactored for removal of ReadClientConnectionConfiguration
prash-mi May 4, 2022
cdcbe50
Added more properties and default values
prash-mi May 4, 2022
95b52d7
Changed the type of preFetchedRowLimit from Long to Integer
prash-mi May 4, 2022
1f01fd8
Updated method signature - Changed the type of preFetchedRowLimit fro…
prash-mi May 4, 2022
fd42822
Refactor - Removed the usage of ReadClientConnectionConfiguration
prash-mi May 4, 2022
1185236
Refactor - Removed the usage of ReadClientConnectionConfiguration
prash-mi May 4, 2022
35c03ae
Changed the type of preFetchedRowLimit to Integer
prash-mi May 4, 2022
6179a18
Refactor due to Change in the type of preFetchedRowLimit to Integer
prash-mi May 4, 2022
2608284
lint
prash-mi May 4, 2022
e5b26c7
some cleanup and corrections
stephaniewang526 May 4, 2022
8c9d6e5
nit
stephaniewang526 May 4, 2022
58a3272
mark createConnection as Beta
stephaniewang526 May 5, 2022
da4d7f3
disable graalvm IT until it works with Apache Arrow
stephaniewang526 May 5, 2022
8f673db
Added instance check for IntegerArrayField
prash-mi May 5, 2022
50cc2a6
Added Connection createConnection()
prash-mi May 5, 2022
71dfce2
Added testIterateAndOrderDefaultConnSettings IT
prash-mi May 5, 2022
650e6a0
Added Connection createConnection(). Marked createConnection(@NonNull…
prash-mi May 5, 2022
f4d2247
Added com.google.cloud.bigquery.Connection createConnection()
prash-mi May 5, 2022
6ac85f3
add IT and some clean up
stephaniewang526 May 5, 2022
adc0805
add org.checkerframework:checker-qual:jar:3.21.4:compile as a depende…
stephaniewang526 May 5, 2022
ec764e6
🦉 Updates from OwlBot post-processor
gcf-owl-bot[bot] May 5, 2022
be30663
provide BigQueryResultStats in dryRun results
stephaniewang526 May 6, 2022
3a5b836
Fixed testQueryDryRun UT failure - Added jobConfigurationQuery
prash-mi May 6, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -211,6 +211,11 @@ public class ITBigQueryTest {
.setMode(Field.Mode.REPEATED)
.setDescription("IntegerArrayDescription")
.build();
private static final Field STRING_ARRAY_FIELD_SCHEMA =
Field.newBuilder("StringArrayField", LegacySQLTypeName.STRING)
.setMode(Field.Mode.REPEATED)
.setDescription("StringArrayDescription")
.build();
private static final Field BOOLEAN_FIELD_SCHEMA =
Field.newBuilder("BooleanField", LegacySQLTypeName.BOOLEAN)
.setMode(Field.Mode.NULLABLE)
Expand Down Expand Up @@ -313,12 +318,11 @@ public class ITBigQueryTest {
BIGNUMERIC_FIELD_SCHEMA2,
BIGNUMERIC_FIELD_SCHEMA3,
BIGNUMERIC_FIELD_SCHEMA4,
TIME_FIELD_SCHEMA,
DATE_FIELD_SCHEMA,
DATE_TIME_FIELD_SCHEMA,
STRUCT_FIELD_SCHEMA
);

TIME_FIELD_SCHEMA,
DATE_FIELD_SCHEMA,
DATE_TIME_FIELD_SCHEMA,
STRUCT_FIELD_SCHEMA,
STRING_ARRAY_FIELD_SCHEMA);

private static final Field DDL_TIMESTAMP_FIELD_SCHEMA =
Field.newBuilder("TimestampField", LegacySQLTypeName.TIMESTAMP)
Expand Down Expand Up @@ -364,29 +368,11 @@ public class ITBigQueryTest {
.setMode(Field.Mode.NULLABLE)
.build());

/*
private static final Schema BQ_RESULTSET_EXPECTED_SCHEMA =
Schema.of(
STRING_FIELD_SCHEMA,
BIGNUMERIC_FIELD_SCHEMA,
BOOLEAN_FIELD_SCHEMA,
BYTES_FIELD_SCHEMA,
INTEGER_FIELD_SCHEMA,
TIMESTAMP_FIELD_SCHEMA,
FLOAT_FIELD_SCHEMA,
NUMERIC_FIELD_SCHEMA,
TIME_FIELD_SCHEMA,
DATE_FIELD_SCHEMA,
DATE_TIME_FIELD_SCHEMA,
STRUCT_FIELD_SCHEMA,
INTEGER_ARRAY_FIELD_SCHEMA
);
*/
private static final Schema BQ_RESULTSET_EXPECTED_SCHEMA =
Schema.of(
Field.newBuilder("StringField", LegacySQLTypeName.STRING)
.setMode(Field.Mode.NULLABLE)
.build() ,
.build(),
Field.newBuilder("BigNumericField", LegacySQLTypeName.BIGNUMERIC)
.setMode(Field.Mode.NULLABLE)
.build(),
Expand All @@ -402,31 +388,30 @@ public class ITBigQueryTest {
Field.newBuilder("TimestampField", LegacySQLTypeName.TIMESTAMP)
.setMode(Field.Mode.NULLABLE)
.build(),
Field.newBuilder("FloatField", LegacySQLTypeName.FLOAT)
.setMode(Field.Mode.NULLABLE)
.build(),
Field.newBuilder("NumericField", LegacySQLTypeName.NUMERIC)
.setMode(Field.Mode.NULLABLE)
.build(),
Field.newBuilder("TimeField", LegacySQLTypeName.TIME)
.setMode(Field.Mode.NULLABLE)
.build(),
Field.newBuilder("Date_Field", LegacySQLTypeName.DATE)
Field.newBuilder("FloatField", LegacySQLTypeName.FLOAT)
.setMode(Field.Mode.NULLABLE)
.build(),
Field.newBuilder("Date_Time_Field", LegacySQLTypeName.DATETIME)
Field.newBuilder("NumericField", LegacySQLTypeName.NUMERIC)
.setMode(Field.Mode.NULLABLE)
.build(),
Field.newBuilder("Struct_Field", LegacySQLTypeName.STRING)
.setMode(Field.Mode.NULLABLE)
.build(),
Field.newBuilder("IntegerArrayField", LegacySQLTypeName.DATE)
.setMode(Field.Mode.NULLABLE)
.build()



);
Field.newBuilder("TimeField", LegacySQLTypeName.TIME)
.setMode(Field.Mode.NULLABLE)
.build(),
Field.newBuilder("DateField", LegacySQLTypeName.DATE)
.setMode(Field.Mode.NULLABLE)
.build(),
Field.newBuilder("DateTimeField", LegacySQLTypeName.DATETIME)
.setMode(Field.Mode.NULLABLE)
.build(),
Field.newBuilder("StructField", LegacySQLTypeName.STRING)
.setMode(Field.Mode.NULLABLE)
.build(),
Field.newBuilder("StringArrayField", LegacySQLTypeName.STRING)
.setMode(Field.Mode.NULLABLE)
.build(),
Field.newBuilder("GeographyField", LegacySQLTypeName.GEOGRAPHY)
.setMode(Field.Mode.NULLABLE)
.build());

private static final Schema QUERY_RESULT_SCHEMA_BIGNUMERIC =
Schema.of(
Expand Down Expand Up @@ -481,7 +466,8 @@ public class ITBigQueryTest {
private static final TableId TABLE_ID_DDL = TableId.of(DATASET, "ddl_testing_table");
private static final TableId TABLE_ID_FASTQUERY = TableId.of(DATASET, "fastquery_testing_table");
private static final TableId TABLE_ID_LARGE = TableId.of(DATASET, "large_data_testing_table");
private static final TableId TABLE_ID_FASTQUERY_BQ_RESULTSET = TableId.of(DATASET, "fastquery_testing_bq_resultset");
private static final TableId TABLE_ID_FASTQUERY_BQ_RESULTSET =
TableId.of(DATASET, "fastquery_testing_bq_resultset");
private static final String CSV_CONTENT = "StringValue1\nStringValue2\n";

private static final String JSON_CONTENT =
Expand Down Expand Up @@ -541,34 +527,35 @@ public class ITBigQueryTest {
+ "}";

private static final String JSON_CONTENT_BQ_RESULTSET =
"{"
+ " \"TimestampField\": null,"
+ " \"StringField\": null,"
+ " \"IntegerArrayField\": null,"
+ " \"BooleanField\": null,"
+ " \"BytesField\": null,"
+ " \"RecordField\": {"
+ " \"TimestampField\": null,"
+ " \"StringField\": null,"
+ " \"IntegerArrayField\": null,"
+ " \"BooleanField\": null,"
+ " \"BytesField\": null"
+ " },"
+ " \"IntegerField\": null,"
+ " \"FloatField\": null,"
+ " \"GeographyField\": null,"
+ " \"NumericField\": null,"
+ " \"BigNumericField\": null,"
+ " \"BigNumericField1\": null,"
+ " \"BigNumericField2\": null,"
+ " \"BigNumericField3\": null,"
+ " \"BigNumericField4\": null,"
+ " \"TimeField\": null,"
+ " \"DateField\": null,"
+ " \"DateTimeField\": null,"
+ " \"StructField\": null"
+ "}\n"
+ "{"
"{"
+ " \"TimestampField\": null,"
+ " \"StringField\": null,"
+ " \"IntegerArrayField\": null,"
+ " \"BooleanField\": null,"
+ " \"BytesField\": null,"
+ " \"RecordField\": {"
+ " \"TimestampField\": null,"
+ " \"StringField\": null,"
+ " \"IntegerArrayField\": null,"
+ " \"BooleanField\": null,"
+ " \"BytesField\": null"
+ " },"
+ " \"IntegerField\": null,"
+ " \"FloatField\": null,"
+ " \"GeographyField\": null,"
+ " \"NumericField\": null,"
+ " \"BigNumericField\": null,"
+ " \"BigNumericField1\": null,"
+ " \"BigNumericField2\": null,"
+ " \"BigNumericField3\": null,"
+ " \"BigNumericField4\": null,"
+ " \"TimeField\": null,"
+ " \"DateField\": null,"
+ " \"DateTimeField\": null,"
+ " \"StructField\": null,"
+ " \"StringArrayField\": null"
+ "}\n"
+ "{"
+ " \"TimestampField\": \"2018-08-19 12:11:35.220 UTC\","
+ " \"StringField\": \"StringValue1\","
+ " \"IntegerArrayField\": [\"0\", \"1\"],"
Expand Down Expand Up @@ -597,7 +584,8 @@ public class ITBigQueryTest {
+ " \"TimeField\": \"12:11:35.123456\","
+ " \"DateField\": \"2018-08-19\","
+ " \"DateTimeField\": \"2018-08-19 12:11:35.123456\","
+ " \"StructField\": \"STRUCT('StructVal')\""
+ " \"StructField\": \"STRUCT('StructVal')\","
+ " \"StringArrayField\": [\"one\", \"two\"]"
+ "}";
private static final String JSON_CONTENT_SIMPLE =
"{"
Expand Down Expand Up @@ -651,8 +639,10 @@ public static void beforeClass() throws InterruptedException, IOException {
BlobInfo.newBuilder(BUCKET, LOAD_FILE_LARGE).setContentType("text/plain").build(),
FileSystems.getDefault().getPath("src/test/resources", "QueryTestData.csv"));
storage.create(
BlobInfo.newBuilder(BUCKET, JSON_LOAD_FILE_BQ_RESULTSET).setContentType("application/json").build(),
JSON_CONTENT_BQ_RESULTSET.getBytes(StandardCharsets.UTF_8));
BlobInfo.newBuilder(BUCKET, JSON_LOAD_FILE_BQ_RESULTSET)
.setContentType("application/json")
.build(),
JSON_CONTENT_BQ_RESULTSET.getBytes(StandardCharsets.UTF_8));
DatasetInfo info =
DatasetInfo.newBuilder(DATASET).setDescription(DESCRIPTION).setLabels(LABELS).build();
bigquery.create(info);
Expand Down Expand Up @@ -687,17 +677,19 @@ public static void beforeClass() throws InterruptedException, IOException {
assertNull(jobFastQuery.getStatus().getError());

LoadJobConfiguration configFastQueryBQResultset =
LoadJobConfiguration.newBuilder(
TABLE_ID_FASTQUERY_BQ_RESULTSET, "gs://" + BUCKET + "/" + JSON_LOAD_FILE_BQ_RESULTSET, FormatOptions.json())
.setCreateDisposition(JobInfo.CreateDisposition.CREATE_IF_NEEDED)
.setSchema(BQ_RESULTSET_SCHEMA)
.setLabels(labels)
.build();
LoadJobConfiguration.newBuilder(
TABLE_ID_FASTQUERY_BQ_RESULTSET,
"gs://" + BUCKET + "/" + JSON_LOAD_FILE_BQ_RESULTSET,
FormatOptions.json())
.setCreateDisposition(JobInfo.CreateDisposition.CREATE_IF_NEEDED)
.setSchema(BQ_RESULTSET_SCHEMA)
.setLabels(labels)
.build();
Job jobFastQueryBQResultSet = bigquery.create(JobInfo.of(configFastQueryBQResultset));
jobFastQueryBQResultSet = jobFastQueryBQResultSet.waitFor();
assertNull(jobFastQueryBQResultSet.getStatus().getError());

LoadJobConfiguration configurationDDL =
LoadJobConfiguration configurationDDL =
LoadJobConfiguration.newBuilder(
TABLE_ID_DDL, "gs://" + BUCKET + "/" + JSON_LOAD_FILE_SIMPLE, FormatOptions.json())
.setCreateDisposition(JobInfo.CreateDisposition.CREATE_IF_NEEDED)
Expand Down Expand Up @@ -2148,13 +2140,12 @@ public void testQueryExternalHivePartitioningOptionCustomLayout() throws Interru
@Test
public void testExecuteQuerySinglePageTableRow() throws SQLException {
String query =
"select StringField, BigNumericField, BooleanField, BytesField, IntegerField, TimestampField, FloatField, " +
"NumericField, TimeField, DateField, DateTimeField, StructField, IntegerArrayField from "+ TABLE_ID_FASTQUERY_BQ_RESULTSET.getTable()
"select StringField, BigNumericField, BooleanField, BytesField, IntegerField, TimestampField, FloatField, "
+ "NumericField, TimeField, DateField, DateTimeField, StructField, StringArrayField , GeographyField from "
+ TABLE_ID_FASTQUERY_BQ_RESULTSET.getTable()
+ " order by TimestampField";
ConnectionSettings connectionSettings =
ConnectionSettings.newBuilder()
.setDefaultDataset(DatasetId.of(DATASET))
.build();
ConnectionSettings.newBuilder().setDefaultDataset(DatasetId.of(DATASET)).build();
Connection connection = bigquery.createConnection(connectionSettings);
BigQueryResultSet bigQueryResultSet = connection.executeSelect(query);
ResultSet rs = bigQueryResultSet.getResultSet();
Expand All @@ -2164,23 +2155,6 @@ public void testExecuteQuerySinglePageTableRow() throws SQLException {

assertEquals(3, bigQueryResultSet.getTotalRows());

/* while (rs.next()){
System.out.println(rs.getString("StringField"));
System.out.println(rs.getDouble("BigNumericField"));
System.out.println(rs.getBoolean("BooleanField"));
System.out.println(rs.getBytes("BytesField"));
System.out.println(rs.getInt("IntegerField"));
System.out.println(rs.getTimestamp("TimestampField"));
System.out.println(rs.getDate("DateField"));
System.out.println(rs.getDouble("FloatField"));
System.out.println(rs.getDouble("NumericField"));
System.out.println(rs.getTime("TimeField"));
System.out.println(rs.getString("DateTimeField"));
System.out.println(rs.getString("StructField"));
System.out.println(rs.getString("IntegerArrayField"));
System.out.println("\n\n>\n\n");
}*/

assertTrue(rs.next()); // first row
// checking for the null or 0 column values
assertNull(rs.getString("StringField"));
Expand All @@ -2195,7 +2169,8 @@ public void testExecuteQuerySinglePageTableRow() throws SQLException {
assertNull(rs.getTime("TimeField"));
assertNull(rs.getString("DateTimeField"));
assertNull(rs.getString("StructField"));
assertNull(rs.getString("IntegerArrayField"));
assertNull(rs.getString("StringArrayField"));
assertNull(rs.getString("GeographyField"));

assertTrue(rs.next()); // second row
// second row is non null, comparing the values
Expand All @@ -2205,20 +2180,23 @@ public void testExecuteQuerySinglePageTableRow() throws SQLException {
assertNotNull(rs.getBytes("BytesField"));
assertEquals(1, rs.getInt("IntegerField"));
/*
org.junit.ComparisonFailure:
Expected :2018-08-19 17:41:35.123456
Actual :2018-08-19 17:41:35.22
*/
// assertEquals("2018-08-19 17:41:35.123456", rs.getTimestamp("TimestampField").toString());
assertEquals( java.sql.Date.valueOf("2018-08-19"), rs.getDate("DateField"));
TODO: Check the rounding issue
org.junit.ComparisonFailure:
Expected :2018-08-19 17:41:35.123456
Actual :2018-08-19 17:41:35.22
*/
// assertEquals("2018-08-19 17:41:35.123456",
// rs.getTimestamp("TimestampField").toString());//TODO: Check the rounding issue
assertEquals(java.sql.Date.valueOf("2018-08-19"), rs.getDate("DateField"));
assertTrue(rs.getDouble("FloatField") == 10.1d);
assertTrue(rs.getDouble("NumericField") == 100.0d);
assertEquals(Time.valueOf(LocalTime.of(12, 11, 35, 123456)), rs.getTime("TimeField"));
assertEquals("2018-08-19T12:11:35.123456", rs.getString("DateTimeField"));
assertEquals("STRUCT('StructVal')", rs.getString("StructField"));
assertEquals("0", rs.getString("IntegerArrayField"));
assertEquals("one", rs.getString("StringArrayField"));
assertEquals("POINT(-122.35022 47.649154)", rs.getString("GeographyField"));

stephaniewang526 marked this conversation as resolved.
Show resolved Hide resolved
assertTrue(rs.next()); //third row
assertTrue(rs.next()); // third row
assertFalse(rs.next()); // no 4th row in the table
}

Expand Down