Skip to content

Commit

Permalink
fix: Regenerate v0.20.0 protos (#1498)
Browse files Browse the repository at this point in the history
* fix: Regenerate v0.20.0 protos

This change does a few things:

1. Adds a guide for maintainers to update protos
2. Updates the rake task to regenerate code from protos using a clean directory.
   1. This ensures any changes upstream that _deletes_ protos are applied to this repo
3. Updates the rake task to fast fail when it encounters an error, e.g. protoc is not installed

* squash: LINTERS

* squash: I swear officer the space was there
  • Loading branch information
arielvalentin authored Jul 27, 2023
1 parent 1159ec0 commit 8e4da19
Show file tree
Hide file tree
Showing 6 changed files with 66 additions and 218 deletions.
53 changes: 51 additions & 2 deletions exporter/otlp/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -16,15 +16,17 @@ Generally, *libraries* that produce telemetry data should avoid depending direct

### Supported protocol version

This gem supports the [v0.4.0 release](https://github.com/open-telemetry/opentelemetry-proto/releases/tag/v0.4.0) of OTLP.
This gem supports the [v0.20.0 release][otel-proto-release] of OTLP.

## How do I get started?

Install the gem using:

```
```console

gem install opentelemetry-sdk
gem install opentelemetry-exporter-otlp

```

Or, if you use [bundler][bundler-home], include `opentelemetry-sdk` in your `Gemfile`.
Expand Down Expand Up @@ -93,6 +95,48 @@ The OpenTelemetry Ruby gems are maintained by the OpenTelemetry-Ruby special int

The `opentelemetry-exporter-otlp` gem is distributed under the Apache 2.0 license. See [LICENSE][license-github] for more information.

## Working with Proto Definitions

The OTel community maintains a [repository with protobuf definitions][otel-proto-github] that language and collector implementors use to generate code.

Maintainers are expected to keep up to date with the latest version of protos. This guide will provide you with step-by-step instructions on updating the OTLP Exporter gem with the latest definitions.

### System Requirements

- [`git` 2.41+][git-install]
- [`protoc` 22.5][protoc-install]
- [Ruby 3+][ruby-downloads]

> :warning: `protoc 23.x` *changes the Ruby code generator to emit a serialized proto instead of a DSL.* <https://protobuf.dev/news/2023-04-20/>. Please ensure you use `protoc` version `22.x` in order to ensure we remain compatible with versions of protobuf prior to `google-protobuf` gem `3.18`.
### Upgrade Proto Definitions

**Update the target otel-proto version in the `Rakefile` that matches a release `tag` in the proto repo, e.g.**

```ruby
# Rakefile

# https://github.com/open-telemetry/opentelemetry-proto/tree/v0.20.0
PROTO_VERSION = `v0.20.0`
```

**Generate the Ruby source files using `rake`:**

```console

$> bundle exec rake protobuf:generate

```

**Run tests and fix any errors:**

```console

$> bundle exec rake test

```

**Commit the chnages and open a PR!**

[opentelemetry-collector-home]: https://opentelemetry.io/docs/collector/about/
[opentelemetry-home]: https://opentelemetry.io
Expand All @@ -103,3 +147,8 @@ The `opentelemetry-exporter-otlp` gem is distributed under the Apache 2.0 licens
[ruby-sig]: https://github.com/open-telemetry/community#ruby-sig
[community-meetings]: https://github.com/open-telemetry/community#community-meetings
[discussions-url]: https://github.com/open-telemetry/opentelemetry-ruby/discussions
[git-install]: https://git-scm.com/book/en/v2/Getting-Started-Installing-Git
[protoc-install]: https://github.com/protocolbuffers/protobuf/releases/tag/v22.5
[ruby-downloads]: https://www.ruby-lang.org/en/downloads/
[otel-proto-github]: https://github.com/open-telemetry/opentelemetry-proto
[otel-proto-release]: https://github.com/open-telemetry/opentelemetry-proto/releases/tag/v0.20.0
32 changes: 15 additions & 17 deletions exporter/otlp/Rakefile
Original file line number Diff line number Diff line change
Expand Up @@ -29,23 +29,21 @@ else
task default: %i[test rubocop yard]
end

# https://github.com/open-telemetry/opentelemetry-proto/tree/v0.20.0
PROTO_VERSION = 'v0.20.0'
PROTOBUF_FILES = [
'collector/logs/v1/logs_service.proto',
'collector/metrics/v1/metrics_service.proto',
'collector/trace/v1/trace_service.proto',
'common/v1/common.proto',
'logs/v1/logs.proto',
'metrics/v1/metrics.proto',
'resource/v1/resource.proto',
'trace/v1/trace.proto',
'trace/v1/trace_config.proto'
].freeze

task :update_protobuf do
system("git clone -b #{PROTO_VERSION} https://github.com/open-telemetry/opentelemetry-proto")
PROTOBUF_FILES.each do |file|
system("protoc --ruby_out=lib/ --proto_path=opentelemetry-proto opentelemetry/proto/#{file}")

namespace :protobuf do
task :clean do
FileUtils.rm_rf('lib/opentelemetry/proto')
FileUtils.rm_rf('opentelemetry-proto')
end

desc "Generate Ruby Source files from OTel Proto Version #{PROTO_VERSION}"
task generate: [:clean] do
system("git clone -b #{PROTO_VERSION} https://github.com/open-telemetry/opentelemetry-proto", exception: true)
Dir['opentelemetry-proto/opentelemetry/proto/**/*.proto'].each do |file|
system("protoc --ruby_out=lib/ --proto_path=opentelemetry-proto #{file.gsub('opentelemetry-proto/', '')}", exception: true)
end
FileUtils.rm_rf('opentelemetry-proto')
end
system('rm -rf opentelemetry-proto')
end

This file was deleted.

This file was deleted.

This file was deleted.

49 changes: 0 additions & 49 deletions exporter/otlp/lib/opentelemetry/proto/trace/v1/trace_config_pb.rb

This file was deleted.

0 comments on commit 8e4da19

Please sign in to comment.