Skip to content

Commit e2634ee

Browse files
authored
Merge pull request #155 from hiroyuki-sato/topic/newer-jruby
First porting to Embulk 0.11.0
2 parents ba74c7f + 4519c26 commit e2634ee

File tree

6 files changed

+33
-39
lines changed

6 files changed

+33
-39
lines changed

.github/workflows/check.yml

Lines changed: 7 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,10 @@ jobs:
77
# pull_request: run only when the PR is submitted from a forked repository, not within this repository.
88
if: github.event_name == 'push' || github.event.pull_request.head.repo.full_name != github.repository
99
strategy:
10+
matrix:
11+
jruby_version:
12+
- 9.3.10.0
13+
- 9.4.2.0
1014
fail-fast: false
1115
steps:
1216
- uses: actions/checkout@v3
@@ -17,17 +21,13 @@ jobs:
1721
distribution: "temurin"
1822
- uses: ruby/setup-ruby@v1
1923
with:
20-
ruby-version: 'jruby-9.1.17.0' # 9.1.15.0 doesn't available in setup-ruby@v1
24+
ruby-version: 'jruby-${{ matrix.jruby_version }}'
2125
bundler-cache: true
2226
- name: show ruby version
2327
run: ruby -v
24-
# Gem::LoadError: You have already activated rake 10.4.2,
25-
# but your Gemfile requires rake 13.0.6.
26-
- name: gem install rake -v 13.0.6
27-
run: gem install rake -v 13.0.6
2828
- name: bundle install
2929
run: bundle install
30-
- name: install embulk
31-
run: "curl -L -o embulk.jar https://github.com/embulk/embulk/releases/download/v0.8.39/embulk-0.8.39.jar"
30+
- name: install embulk.jar
31+
run: "curl -L -o embulk.jar https://github.com/embulk/embulk/releases/download/v0.10.49/embulk-0.10.49.jar"
3232
- name: rake test
3333
run: bundle exec env RUBYOPT="-r ./embulk.jar" rake test

Gemfile

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,8 +1,7 @@
11
source 'https://rubygems.org/'
22

33
gemspec
4-
gem 'embulk', '< 0.10'
5-
gem 'liquid', '= 4.0.0' # the version included in embulk.jar
4+
gem 'embulk', '> 0.10.0'
65
gem 'embulk-parser-none'
76
gem 'embulk-parser-jsonl'
87
gem 'pry-nav'

embulk-output-bigquery.gemspec

Lines changed: 6 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -14,18 +14,13 @@ Gem::Specification.new do |spec|
1414
spec.test_files = spec.files.grep(%r{^(test|spec)/})
1515
spec.require_paths = ["lib"]
1616

17-
# TODO
18-
# signet 0.12.0 and google-api-client 0.33.0 require >= Ruby 2.4.
19-
# Embulk 0.9 use JRuby 9.1.X.Y and it's compatible with Ruby 2.3.
20-
# So, force install signet < 0.12 and google-api-client < 0.33.0
21-
# Also, representable version >= 3.1.0 requires Ruby version >= 2.4
22-
spec.add_dependency 'signet', '~> 0.7', '< 0.12.0'
23-
spec.add_dependency 'google-api-client','< 0.33.0'
17+
# the latest version
18+
spec.add_dependency 'google-api-client','= 0.53.0'
2419
spec.add_dependency 'time_with_zone'
25-
spec.add_dependency "representable", ['~> 3.0.0', '< 3.1']
26-
# faraday 1.1.0 require >= Ruby 2.4.
27-
# googleauth 0.9.0 requires faraday ~> 0.12
28-
spec.add_dependency "faraday", '~> 0.12'
20+
spec.add_dependency 'thwait'
21+
# activesupport require Ruby >= 2.7.0
22+
# jruby-9.3.0.0 is MRI 2.6 compatible
23+
spec.add_dependency 'activesupport', "< 7.0"
2924

3025
spec.add_development_dependency 'bundler', ['>= 1.10.6']
3126
spec.add_development_dependency 'rake', ['>= 10.0']

lib/embulk/output/bigquery/bigquery_client.rb

Lines changed: 5 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -121,7 +121,7 @@ def load_from_gcs(object_uris, table)
121121
opts = {}
122122

123123
Embulk.logger.debug { "embulk-output-bigquery: insert_job(#{@project}, #{body}, #{opts})" }
124-
response = with_network_retry { client.insert_job(@project, body, opts) }
124+
response = with_network_retry { client.insert_job(@project, body, **opts) }
125125
unless @task['is_skip_job_result_check']
126126
response = wait_load('Load', response)
127127
end
@@ -222,7 +222,7 @@ def load(path, table, write_disposition: 'WRITE_APPEND')
222222
# },
223223
}
224224
Embulk.logger.debug { "embulk-output-bigquery: insert_job(#{@project}, #{body}, #{opts})" }
225-
response = with_network_retry { client.insert_job(@project, body, opts) }
225+
response = with_network_retry { client.insert_job(@project, body, **opts) }
226226
if @task['is_skip_job_result_check']
227227
response
228228
else
@@ -278,7 +278,7 @@ def copy(source_table, destination_table, destination_dataset = nil, write_dispo
278278

279279
opts = {}
280280
Embulk.logger.debug { "embulk-output-bigquery: insert_job(#{@project}, #{body}, #{opts})" }
281-
response = with_network_retry { client.insert_job(@project, body, opts) }
281+
response = with_network_retry { client.insert_job(@project, body, **opts) }
282282
wait_load('Copy', response)
283283
rescue Google::Apis::ServerError, Google::Apis::ClientError, Google::Apis::AuthorizationError => e
284284
response = {status_code: e.status_code, message: e.message, error_class: e.class}
@@ -372,7 +372,7 @@ def create_dataset(dataset = nil, reference: nil)
372372
end
373373
opts = {}
374374
Embulk.logger.debug { "embulk-output-bigquery: insert_dataset(#{@project}, #{dataset}, #{@location_for_log}, #{body}, #{opts})" }
375-
with_network_retry { client.insert_dataset(@project, body, opts) }
375+
with_network_retry { client.insert_dataset(@project, body, **opts) }
376376
rescue Google::Apis::ServerError, Google::Apis::ClientError, Google::Apis::AuthorizationError => e
377377
if e.status_code == 409 && /Already Exists:/ =~ e.message
378378
# ignore 'Already Exists' error
@@ -447,7 +447,7 @@ def create_table_if_not_exists(table, dataset: nil, options: nil)
447447

448448
opts = {}
449449
Embulk.logger.debug { "embulk-output-bigquery: insert_table(#{@project}, #{dataset}, #{@location_for_log}, #{body}, #{opts})" }
450-
with_network_retry { client.insert_table(@project, dataset, body, opts) }
450+
with_network_retry { client.insert_table(@project, dataset, body, **opts) }
451451
rescue Google::Apis::ServerError, Google::Apis::ClientError, Google::Apis::AuthorizationError => e
452452
if e.status_code == 409 && /Already Exists:/ =~ e.message
453453
# ignore 'Already Exists' error

test/helper.rb

Lines changed: 7 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -4,14 +4,14 @@
44
require 'test/unit'
55
require 'test/unit/rr'
66

7+
# Embulk 0.10.x introduced new bootstrap mechanism.
8+
# https://github.com/embulk/embulk/blob/641f35fec064cca7b1a7314d634a4b64ef8637f1/embulk-ruby/test/vanilla/run-test.rb#L8-L13
9+
static_initializer = Java::org.embulk.EmbulkDependencyClassLoader.staticInitializer().useSelfContainedJarFiles()
10+
static_initializer.java_send :initialize
11+
12+
require 'embulk/java/bootstrap'
713
require 'embulk'
8-
begin
9-
# Embulk ~> 0.8.x
10-
Embulk.setup
11-
rescue NotImplementedError, NoMethodError, NameError
12-
# Embulk ~> 0.9.x
13-
require 'embulk/java/bootstrap'
14-
end
14+
1515
Embulk.logger = Embulk::Logger.new('/dev/null')
1616

1717
APP_ROOT = File.expand_path('../', __dir__)

test/test_transaction.rb

Lines changed: 7 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -109,7 +109,7 @@ def test_replace
109109
task = Bigquery.configure(config, schema, processor_count)
110110
any_instance_of(BigqueryClient) do |obj|
111111
mock(obj).get_dataset(config['dataset'])
112-
mock(obj).create_table_if_not_exists(config['temp_table'], {:options=>{"expiration_time"=>nil}})
112+
mock(obj).create_table_if_not_exists(config['temp_table'], options: {"expiration_time"=>nil})
113113
mock(obj).create_table_if_not_exists(config['table'])
114114
mock(obj).copy(config['temp_table'], config['table'], write_disposition: 'WRITE_TRUNCATE')
115115
mock(obj).delete_table(config['temp_table'])
@@ -122,7 +122,7 @@ def test_replace_with_partitioning
122122
task = Bigquery.configure(config, schema, processor_count)
123123
any_instance_of(BigqueryClient) do |obj|
124124
mock(obj).get_dataset(config['dataset'])
125-
mock(obj).create_table_if_not_exists(config['temp_table'],{:options=>{"expiration_time"=>nil}})
125+
mock(obj).create_table_if_not_exists(config['temp_table'], options: {"expiration_time"=>nil})
126126
mock(obj).create_table_if_not_exists(config['table'])
127127
mock(obj).copy(config['temp_table'], config['table'], write_disposition: 'WRITE_TRUNCATE')
128128
mock(obj).delete_table(config['temp_table'])
@@ -138,7 +138,7 @@ def test_replace_backup
138138
any_instance_of(BigqueryClient) do |obj|
139139
mock(obj).get_dataset(config['dataset'])
140140
mock(obj).get_dataset(config['dataset_old'])
141-
mock(obj).create_table_if_not_exists(config['temp_table'], {:options=>{"expiration_time"=>nil}})
141+
mock(obj).create_table_if_not_exists(config['temp_table'], options: {"expiration_time"=>nil})
142142
mock(obj).create_table_if_not_exists(config['table'])
143143
mock(obj).create_table_if_not_exists(config['table_old'], dataset: config['dataset_old'])
144144

@@ -158,7 +158,7 @@ def test_replace_backup_auto_create_dataset
158158
mock(obj).create_dataset(config['dataset'])
159159
mock(obj).create_dataset(config['dataset_old'], reference: config['dataset'])
160160
mock(obj).create_table_if_not_exists(config['table'])
161-
mock(obj).create_table_if_not_exists(config['temp_table'],{:options=>{"expiration_time"=>nil}})
161+
mock(obj).create_table_if_not_exists(config['temp_table'], options: {"expiration_time"=>nil})
162162
mock(obj).create_table_if_not_exists(config['table_old'], dataset: config['dataset_old'])
163163

164164
mock(obj).get_table_or_partition(config['table'])
@@ -176,7 +176,7 @@ def test_replace_backup_with_partitioning
176176
any_instance_of(BigqueryClient) do |obj|
177177
mock(obj).get_dataset(config['dataset'])
178178
mock(obj).get_dataset(config['dataset_old'])
179-
mock(obj).create_table_if_not_exists(config['temp_table'],{:options=>{"expiration_time"=>nil}})
179+
mock(obj).create_table_if_not_exists(config['temp_table'], options: {"expiration_time"=>nil})
180180
mock(obj).create_table_if_not_exists(config['table'])
181181
mock(obj).create_table_if_not_exists(config['table_old'], dataset: config['dataset_old'])
182182

@@ -196,7 +196,7 @@ def test_append
196196
task = Bigquery.configure(config, schema, processor_count)
197197
any_instance_of(BigqueryClient) do |obj|
198198
mock(obj).get_dataset(config['dataset'])
199-
mock(obj).create_table_if_not_exists(config['temp_table'], {:options=>{"expiration_time"=>nil}})
199+
mock(obj).create_table_if_not_exists(config['temp_table'], options: {"expiration_time"=>nil})
200200
mock(obj).create_table_if_not_exists(config['table'])
201201
mock(obj).copy(config['temp_table'], config['table'], write_disposition: 'WRITE_APPEND')
202202
mock(obj).delete_table(config['temp_table'])
@@ -209,7 +209,7 @@ def test_append_with_partitioning
209209
task = Bigquery.configure(config, schema, processor_count)
210210
any_instance_of(BigqueryClient) do |obj|
211211
mock(obj).get_dataset(config['dataset'])
212-
mock(obj).create_table_if_not_exists(config['temp_table'], {:options=>{"expiration_time"=>nil}})
212+
mock(obj).create_table_if_not_exists(config['temp_table'], options: {"expiration_time"=>nil})
213213
mock(obj).create_table_if_not_exists(config['table'])
214214
mock(obj).copy(config['temp_table'], config['table'], write_disposition: 'WRITE_APPEND')
215215
mock(obj).delete_table(config['temp_table'])

0 commit comments

Comments
 (0)