[
https://issues.apache.org/jira/browse/AVRO-3203?focusedWorklogId=650003&page=com.atlassian.jira.plugin.system.issuetabpanels:worklog-tabpanel#worklog-650003
]
ASF GitHub Bot logged work on AVRO-3203:
----------------------------------------
Author: ASF GitHub Bot
Created on: 13/Sep/21 13:09
Start Date: 13/Sep/21 13:09
Worklog Time Spent: 10m
Work Description: RyanSkraba commented on pull request #1330:
URL: https://github.com/apache/avro/pull/1330#issuecomment-918173657
Thanks so much for the fix!
When I rebase this on master, I get errors with both `./build.sh test` and
`./build.sh dist` -- has something changed with the ubuntu 20.04 base image?
## ./build.sh test:
```
+ cd lang/ruby
+ rake generate_interop
rake aborted!
LoadError: cannot load such file -- echoe
/home/rskraba/avro/lang/ruby/Rakefile:19:in `<top (required)>'
/usr/share/rubygems-integration/all/gems/rake-13.0.1/exe/rake:27:in `<top
(required)>'
(See full trace by running task with --trace)
```
## ./build.sh dist:
```
~/avro/lang/ruby$ ./build.sh dist
Successfully installed bundler-1.17.3
1 gem installed
Not using rbenv
Using rake 13.0.6
Using allison 2.0.3
Using ast 2.4.2
Using bundler 2.1.2
Using rdoc 6.3.2
Using json_pure 2.5.1
Using rubyforge 2.0.4
Using echoe 4.6.6
Using memory_profiler 1.0.0
Using multi_json 1.15.0
Using parallel 1.21.0
Using parser 3.0.2.0
Using power_assert 2.0.1
Using rainbow 3.0.0
Using regexp_parser 2.1.1
Using rexml 3.2.5
Using rubocop-ast 1.11.0
Using ruby-progressbar 1.11.0
Using unicode-display_width 2.0.0
Using rubocop 1.20.0
Using snappy 0.2.0
Using test-unit 3.4.6
Using webrick 1.7.0
Using zstd-ruby 1.5.0.0
Bundle complete! 11 Gemfile dependencies, 24 gems now installed.
Use `bundle info [gemname]` to see where a bundled gem is installed.
mkdir -p pkg
Gemspec generated
mkdir -p pkg/avro-1.11.0.pre1
rm -f pkg/avro-1.11.0.pre1/CHANGELOG
ln CHANGELOG pkg/avro-1.11.0.pre1/CHANGELOG
rm -f pkg/avro-1.11.0.pre1/LICENSE
ln LICENSE pkg/avro-1.11.0.pre1/LICENSE
rm -f pkg/avro-1.11.0.pre1/Manifest
ln Manifest pkg/avro-1.11.0.pre1/Manifest
rm -f pkg/avro-1.11.0.pre1/NOTICE
ln NOTICE pkg/avro-1.11.0.pre1/NOTICE
rm -f pkg/avro-1.11.0.pre1/Rakefile
ln Rakefile pkg/avro-1.11.0.pre1/Rakefile
rm -f pkg/avro-1.11.0.pre1/avro.gemspec
ln avro.gemspec pkg/avro-1.11.0.pre1/avro.gemspec
mkdir -p pkg/avro-1.11.0.pre1/interop
rm -f pkg/avro-1.11.0.pre1/interop/test_interop.rb
ln interop/test_interop.rb pkg/avro-1.11.0.pre1/interop/test_interop.rb
mkdir -p pkg/avro-1.11.0.pre1/lib
rm -f pkg/avro-1.11.0.pre1/lib/avro.rb
ln lib/avro.rb pkg/avro-1.11.0.pre1/lib/avro.rb
mkdir -p pkg/avro-1.11.0.pre1/lib/avro
rm -f pkg/avro-1.11.0.pre1/lib/avro/VERSION.txt
ln lib/avro/VERSION.txt pkg/avro-1.11.0.pre1/lib/avro/VERSION.txt
rm -f pkg/avro-1.11.0.pre1/lib/avro/data_file.rb
ln lib/avro/data_file.rb pkg/avro-1.11.0.pre1/lib/avro/data_file.rb
rm -f pkg/avro-1.11.0.pre1/lib/avro/io.rb
ln lib/avro/io.rb pkg/avro-1.11.0.pre1/lib/avro/io.rb
rm -f pkg/avro-1.11.0.pre1/lib/avro/ipc.rb
ln lib/avro/ipc.rb pkg/avro-1.11.0.pre1/lib/avro/ipc.rb
rm -f pkg/avro-1.11.0.pre1/lib/avro/logical_types.rb
ln lib/avro/logical_types.rb pkg/avro-1.11.0.pre1/lib/avro/logical_types.rb
rm -f pkg/avro-1.11.0.pre1/lib/avro/protocol.rb
ln lib/avro/protocol.rb pkg/avro-1.11.0.pre1/lib/avro/protocol.rb
rm -f pkg/avro-1.11.0.pre1/lib/avro/schema.rb
ln lib/avro/schema.rb pkg/avro-1.11.0.pre1/lib/avro/schema.rb
rm -f pkg/avro-1.11.0.pre1/lib/avro/schema_compatibility.rb
ln lib/avro/schema_compatibility.rb
pkg/avro-1.11.0.pre1/lib/avro/schema_compatibility.rb
rm -f pkg/avro-1.11.0.pre1/lib/avro/schema_normalization.rb
ln lib/avro/schema_normalization.rb
pkg/avro-1.11.0.pre1/lib/avro/schema_normalization.rb
rm -f pkg/avro-1.11.0.pre1/lib/avro/schema_validator.rb
ln lib/avro/schema_validator.rb
pkg/avro-1.11.0.pre1/lib/avro/schema_validator.rb
mkdir -p pkg/avro-1.11.0.pre1/test
rm -f pkg/avro-1.11.0.pre1/test/case_finder.rb
ln test/case_finder.rb pkg/avro-1.11.0.pre1/test/case_finder.rb
rm -f pkg/avro-1.11.0.pre1/test/random_data.rb
ln test/random_data.rb pkg/avro-1.11.0.pre1/test/random_data.rb
rm -f pkg/avro-1.11.0.pre1/test/sample_ipc_client.rb
ln test/sample_ipc_client.rb pkg/avro-1.11.0.pre1/test/sample_ipc_client.rb
rm -f pkg/avro-1.11.0.pre1/test/sample_ipc_http_client.rb
ln test/sample_ipc_http_client.rb
pkg/avro-1.11.0.pre1/test/sample_ipc_http_client.rb
rm -f pkg/avro-1.11.0.pre1/test/sample_ipc_http_server.rb
ln test/sample_ipc_http_server.rb
pkg/avro-1.11.0.pre1/test/sample_ipc_http_server.rb
rm -f pkg/avro-1.11.0.pre1/test/sample_ipc_server.rb
ln test/sample_ipc_server.rb pkg/avro-1.11.0.pre1/test/sample_ipc_server.rb
rm -f pkg/avro-1.11.0.pre1/test/test_datafile.rb
ln test/test_datafile.rb pkg/avro-1.11.0.pre1/test/test_datafile.rb
rm -f pkg/avro-1.11.0.pre1/test/test_fingerprints.rb
ln test/test_fingerprints.rb pkg/avro-1.11.0.pre1/test/test_fingerprints.rb
rm -f pkg/avro-1.11.0.pre1/test/test_help.rb
ln test/test_help.rb pkg/avro-1.11.0.pre1/test/test_help.rb
rm -f pkg/avro-1.11.0.pre1/test/test_io.rb
ln test/test_io.rb pkg/avro-1.11.0.pre1/test/test_io.rb
rm -f pkg/avro-1.11.0.pre1/test/test_logical_types.rb
ln test/test_logical_types.rb pkg/avro-1.11.0.pre1/test/test_logical_types.rb
rm -f pkg/avro-1.11.0.pre1/test/test_protocol.rb
ln test/test_protocol.rb pkg/avro-1.11.0.pre1/test/test_protocol.rb
rm -f pkg/avro-1.11.0.pre1/test/test_schema.rb
ln test/test_schema.rb pkg/avro-1.11.0.pre1/test/test_schema.rb
rm -f pkg/avro-1.11.0.pre1/test/test_schema_compatibility.rb
ln test/test_schema_compatibility.rb
pkg/avro-1.11.0.pre1/test/test_schema_compatibility.rb
rm -f pkg/avro-1.11.0.pre1/test/test_schema_normalization.rb
ln test/test_schema_normalization.rb
pkg/avro-1.11.0.pre1/test/test_schema_normalization.rb
rm -f pkg/avro-1.11.0.pre1/test/test_schema_validator.rb
ln test/test_schema_validator.rb
pkg/avro-1.11.0.pre1/test/test_schema_validator.rb
rm -f pkg/avro-1.11.0.pre1/test/test_socket_transport.rb
ln test/test_socket_transport.rb
pkg/avro-1.11.0.pre1/test/test_socket_transport.rb
rm -f pkg/avro-1.11.0.pre1/test/tool.rb
ln test/tool.rb pkg/avro-1.11.0.pre1/test/tool.rb
cd pkg/avro-1.11.0.pre1
rake aborted!
ArgumentError: wrong number of arguments (given 2, expected 0)
/home/rskraba/avro/lang/ruby/.gem/gems/echoe-4.6.6/lib/echoe/rubygems.rb:10:in
`validate'
/home/rskraba/avro/lang/ruby/.gem/gems/rake-13.0.6/exe/rake:27:in `<top
(required)>'
Tasks: TOP => dist => gem => pkg/avro-1.11.0.pre1.gem
(See full trace by running task with --trace)
```
--
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.
To unsubscribe, e-mail: [email protected]
For queries about this service, please contact Infrastructure at:
[email protected]
Issue Time Tracking
-------------------
Worklog Id: (was: 650003)
Time Spent: 20m (was: 10m)
> Fix the Ruby distribution build to work
> ---------------------------------------
>
> Key: AVRO-3203
> URL: https://issues.apache.org/jira/browse/AVRO-3203
> Project: Apache Avro
> Issue Type: Bug
> Components: build, ruby
> Reporter: Kengo Seki
> Assignee: Kengo Seki
> Priority: Major
> Labels: pull-request-available
> Time Spent: 20m
> Remaining Estimate: 0h
>
> Currently, building the Ruby distribution in the Docker container fails as
> follows.
> {code:java}
> $ ./build.sh docker
> $ cd lang/ruby
> $ ./build.sh clean dist
> ...
> rake aborted!
> ArgumentError: wrong number of arguments (given 2, expected 0)
> /home/sekikn/avro/lang/ruby/.gem/gems/echoe-4.6.6/lib/echoe/rubygems.rb:10:in
> `validate'
> /home/sekikn/avro/lang/ruby/.gem/gems/rake-13.0.6/exe/rake:27:in `<top
> (required)>'
> Tasks: TOP => dist => gem => pkg/avro-1.11.0.pre1.gem
> (See full trace by running task with --trace)
> {code}
> This is because Ruby 2.7 is used in the Docker container and its rubygems
> library version is 3.1.2.
> [rubygems have changed the semantics of its validate function from
> v3.x|https://github.com/rubygems/rubygems/commit/3966078e62c6b048cd8d2435b9399a9688c6f8f1#diff-8f51ef27aa7c1bf289ef010df42fb4a5f0635d0149776e57bc86985c98bc6480L262-R264],
> and echoe doesn't seem to be compatible with that change.
> We should replace echoe with something simliar since it has not been
> maintained for several years, but it looks a bit tough to me, so I propose an
> easy workaround that building gem with the {{gem build}} command directly
> instead of via bundler, and using echoe only to generate avro.gemspec.
--
This message was sent by Atlassian Jira
(v8.3.4#803005)