karafka-rdkafka 0.20.0-x86_64-linux-musl → 0.21.0.rc1-x86_64-linux-musl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.github/workflows/ci_linux_x86_64_gnu.yml +66 -44
- data/.github/workflows/ci_linux_x86_64_musl.yml +51 -62
- data/.github/workflows/ci_macos_arm64.yml +23 -45
- data/.github/workflows/push_linux_x86_64_gnu.yml +2 -1
- data/.github/workflows/push_linux_x86_64_musl.yml +3 -1
- data/.github/workflows/push_macos_arm64.yml +1 -1
- data/CHANGELOG.md +8 -0
- data/README.md +15 -14
- data/ext/build_common.sh +2 -2
- data/ext/build_linux_x86_64_gnu.sh +5 -5
- data/ext/librdkafka.so +0 -0
- data/karafka-rdkafka.gemspec +0 -25
- data/lib/rdkafka/config.rb +1 -4
- data/lib/rdkafka/version.rb +3 -3
- data/spec/rdkafka/admin_spec.rb +1 -1
- data/spec/rdkafka/config_spec.rb +1 -1
- data/spec/rdkafka/producer_spec.rb +0 -2
- data/spec/spec_helper.rb +1 -3
- metadata +1 -1
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA256:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: 8f2aaf0de0f3156422cd04c67bdcbf5be8902aed5a349d4174ce90e4e78df353
         | 
| 4 | 
            +
              data.tar.gz: 724290e62cf475cfe7a5e8d523229f88f9c213b6ff1696b6da18d5f036e38353
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: 4e27dd4f2bc094484011633c11ce7516c016f42cdd12a35f3105631f94254678147616845bc9078393d21d2253e4ff0e00a48a09b187c9ff7919e12cbb4fa41d
         | 
| 7 | 
            +
              data.tar.gz: 8ca538ad002a7c91150ef3003b4b11119a624a6eca6df66c584f85b9bf0f3a73d17196cf1e79c4fc022636034fdb1346c33584d47570eb9c1a1a13b135c4dabd
         | 
| @@ -1,3 +1,37 @@ | |
| 1 | 
            +
            # CI Strategy: Comprehensive Testing of Build and Precompiled Flows
         | 
| 2 | 
            +
            #
         | 
| 3 | 
            +
            # This workflow tests both compilation-from-source and precompiled binary distribution
         | 
| 4 | 
            +
            # strategies across multiple Ubuntu and Ruby versions to ensure broad compatibility and
         | 
| 5 | 
            +
            # reliability.
         | 
| 6 | 
            +
            #
         | 
| 7 | 
            +
            # WHY WE TEST BOTH UBUNTU 22.04 AND 24.04:
         | 
| 8 | 
            +
            # - Different system library versions (OpenSSL, zlib, libsasl2, libzstd, etc.)
         | 
| 9 | 
            +
            # - Different GCC compiler versions that affect native extension compilation
         | 
| 10 | 
            +
            # - Different glibc versions that can impact binary compatibility
         | 
| 11 | 
            +
            # - Real-world deployment scenarios where users run on various Ubuntu LTS versions
         | 
| 12 | 
            +
            # - Different Ruby versions
         | 
| 13 | 
            +
            #
         | 
| 14 | 
            +
            # COMPILATION FLOW (build_install + specs_install):
         | 
| 15 | 
            +
            # - Tests that librdkafka compiles correctly from source on each Ubuntu version
         | 
| 16 | 
            +
            # - Validates that mini_portile2 can successfully build native dependencies
         | 
| 17 | 
            +
            # - Ensures Ruby native extensions link properly with system libraries
         | 
| 18 | 
            +
            # - Verifies that the same codebase works across different toolchain versions
         | 
| 19 | 
            +
            #
         | 
| 20 | 
            +
            # PRECOMPILED FLOW (build_precompiled + specs_precompiled):
         | 
| 21 | 
            +
            # - Tests our precompiled static libraries work on different Ubuntu versions
         | 
| 22 | 
            +
            # - Validates that statically-linked binaries are truly portable across environments
         | 
| 23 | 
            +
            # - Ensures precompiled libraries don't have unexpected system dependencies
         | 
| 24 | 
            +
            # - Verifies that removing build tools doesn't break precompiled binary usage
         | 
| 25 | 
            +
            #
         | 
| 26 | 
            +
            # ARTIFACT ISOLATION:
         | 
| 27 | 
            +
            # - Each Ubuntu version gets separate artifacts (rdkafka-built-gem-22.04, etc.)
         | 
| 28 | 
            +
            # - Prevents cross-contamination of OS-specific compiled extensions
         | 
| 29 | 
            +
            # - Ensures test accuracy by matching build and test environments
         | 
| 30 | 
            +
            #
         | 
| 31 | 
            +
            # This comprehensive approach catches issues that single-platform testing would miss,
         | 
| 32 | 
            +
            # such as system library incompatibilities, compiler-specific bugs, or static linking
         | 
| 33 | 
            +
            # problems that only manifest on specific Ubuntu versions.
         | 
| 34 | 
            +
             | 
| 1 35 | 
             
            name: CI Linux x86_64 GNU
         | 
| 2 36 |  | 
| 3 37 | 
             
            concurrency:
         | 
| @@ -20,41 +54,8 @@ env: | |
| 20 54 | 
             
              BUNDLE_JOBS: 4
         | 
| 21 55 |  | 
| 22 56 | 
             
            jobs:
         | 
| 23 | 
            -
              build_install:
         | 
| 24 | 
            -
                timeout-minutes: 30
         | 
| 25 | 
            -
                runs-on: ubuntu-latest
         | 
| 26 | 
            -
                steps:
         | 
| 27 | 
            -
                  - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
         | 
| 28 | 
            -
                    with:
         | 
| 29 | 
            -
                      fetch-depth: 0
         | 
| 30 | 
            -
                  - name: Install package dependencies
         | 
| 31 | 
            -
                    run: "[ -e $APT_DEPS ] || sudo apt-get install -y --no-install-recommends $APT_DEPS"
         | 
| 32 | 
            -
                  - name: Set up Ruby
         | 
| 33 | 
            -
                    uses: ruby/setup-ruby@a4effe49ee8ee5b8b5091268c473a4628afb5651 # v1.245.0
         | 
| 34 | 
            -
                    with:
         | 
| 35 | 
            -
                      ruby-version: '3.4'  # Use one Ruby version for building
         | 
| 36 | 
            -
                      bundler-cache: false
         | 
| 37 | 
            -
                  - name: Build gem with mini_portile
         | 
| 38 | 
            -
                    run: |
         | 
| 39 | 
            -
                      set -e
         | 
| 40 | 
            -
                      bundle install
         | 
| 41 | 
            -
                      cd ext && bundle exec rake
         | 
| 42 | 
            -
                      cd ..
         | 
| 43 | 
            -
                  - name: Upload built gem and bundle
         | 
| 44 | 
            -
                    uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2
         | 
| 45 | 
            -
                    with:
         | 
| 46 | 
            -
                      name: rdkafka-built-gem
         | 
| 47 | 
            -
                      path: |
         | 
| 48 | 
            -
                        vendor/bundle/
         | 
| 49 | 
            -
                        .bundle/
         | 
| 50 | 
            -
                        ext/
         | 
| 51 | 
            -
                        lib/
         | 
| 52 | 
            -
                      retention-days: 1
         | 
| 53 | 
            -
             | 
| 54 57 | 
             
              specs_install:
         | 
| 55 58 | 
             
                timeout-minutes: 30
         | 
| 56 | 
            -
                runs-on: ubuntu-latest
         | 
| 57 | 
            -
                needs: build_install
         | 
| 58 59 | 
             
                strategy:
         | 
| 59 60 | 
             
                  fail-fast: false
         | 
| 60 61 | 
             
                  matrix:
         | 
| @@ -65,20 +66,17 @@ jobs: | |
| 65 66 | 
             
                      - '3.2'
         | 
| 66 67 | 
             
                      - '3.1'
         | 
| 67 68 | 
             
                      - 'jruby-10.0'
         | 
| 69 | 
            +
                    ubuntu-version: ['22.04', '24.04']
         | 
| 68 70 | 
             
                    include:
         | 
| 69 71 | 
             
                      - ruby: '3.4'
         | 
| 70 72 | 
             
                        coverage: 'true'
         | 
| 71 73 | 
             
                      - ruby: 'jruby-10.0'
         | 
| 72 74 | 
             
                        continue-on-error: true
         | 
| 75 | 
            +
                runs-on: ubuntu-${{ matrix.ubuntu-version }}
         | 
| 73 76 | 
             
                steps:
         | 
| 74 77 | 
             
                  - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
         | 
| 75 78 | 
             
                    with:
         | 
| 76 79 | 
             
                      fetch-depth: 0
         | 
| 77 | 
            -
                  - name: Download built gem
         | 
| 78 | 
            -
                    uses: actions/download-artifact@d3f86a106a0bac45b974a628896c90dbdf5c8093 # v4.3.0
         | 
| 79 | 
            -
                    with:
         | 
| 80 | 
            -
                      name: rdkafka-built-gem
         | 
| 81 | 
            -
                      path: ./
         | 
| 82 80 | 
             
                  - name: Set up Ruby
         | 
| 83 81 | 
             
                    uses: ruby/setup-ruby@a4effe49ee8ee5b8b5091268c473a4628afb5651 # v1.245.0
         | 
| 84 82 | 
             
                    with:
         | 
| @@ -108,12 +106,17 @@ jobs: | |
| 108 106 | 
             
                        echo "Sleeping 2 seconds..."
         | 
| 109 107 | 
             
                        sleep 2
         | 
| 110 108 | 
             
                      done
         | 
| 111 | 
            -
                  - name: Install  | 
| 109 | 
            +
                  - name: Install dependencies
         | 
| 112 110 | 
             
                    env:
         | 
| 113 111 | 
             
                      RDKAFKA_EXT_PATH: ${{ github.workspace }}/ext
         | 
| 114 112 | 
             
                    run: |
         | 
| 115 113 | 
             
                      # Only install gems that aren't Ruby-version specific
         | 
| 116 114 | 
             
                      bundle install
         | 
| 115 | 
            +
                  - name: Build gem with mini_portile
         | 
| 116 | 
            +
                    run: |
         | 
| 117 | 
            +
                      set -e
         | 
| 118 | 
            +
                      cd ext && bundle exec rake
         | 
| 119 | 
            +
                      cd ..
         | 
| 117 120 | 
             
                  - name: Run all specs
         | 
| 118 121 | 
             
                    env:
         | 
| 119 122 | 
             
                      GITHUB_COVERAGE: ${{matrix.coverage}}
         | 
| @@ -124,7 +127,10 @@ jobs: | |
| 124 127 |  | 
| 125 128 | 
             
              build_precompiled:
         | 
| 126 129 | 
             
                timeout-minutes: 30
         | 
| 127 | 
            -
                 | 
| 130 | 
            +
                # We precompile on older Ubuntu and check compatibility by running specs since we aim to
         | 
| 131 | 
            +
                # release only one precompiled version for all supported Ubuntu versions
         | 
| 132 | 
            +
                # This is why we do not want Renovate to update it automatically
         | 
| 133 | 
            +
                runs-on: ubuntu-22.04 # renovate: ignore
         | 
| 128 134 | 
             
                steps:
         | 
| 129 135 | 
             
                  - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
         | 
| 130 136 | 
             
                    with:
         | 
| @@ -135,15 +141,29 @@ jobs: | |
| 135 141 | 
             
                      sudo apt-get install -y --no-install-recommends \
         | 
| 136 142 | 
             
                        build-essential \
         | 
| 137 143 | 
             
                        gcc \
         | 
| 144 | 
            +
                        g++ \
         | 
| 138 145 | 
             
                        make \
         | 
| 139 | 
            -
                        patch \
         | 
| 140 146 | 
             
                        tar \
         | 
| 147 | 
            +
                        gzip \
         | 
| 141 148 | 
             
                        wget \
         | 
| 149 | 
            +
                        curl \
         | 
| 150 | 
            +
                        file \
         | 
| 151 | 
            +
                        pkg-config \
         | 
| 152 | 
            +
                        autoconf \
         | 
| 153 | 
            +
                        automake \
         | 
| 154 | 
            +
                        libtool \
         | 
| 155 | 
            +
                        python3 \
         | 
| 156 | 
            +
                        git \
         | 
| 142 157 | 
             
                        ca-certificates \
         | 
| 158 | 
            +
                        patch \
         | 
| 143 159 | 
             
                        libsasl2-dev \
         | 
| 144 160 | 
             
                        libssl-dev \
         | 
| 145 161 | 
             
                        zlib1g-dev \
         | 
| 146 | 
            -
                        libzstd-dev
         | 
| 162 | 
            +
                        libzstd-dev \
         | 
| 163 | 
            +
                        bison \
         | 
| 164 | 
            +
                        flex \
         | 
| 165 | 
            +
                        perl \
         | 
| 166 | 
            +
                        binutils-dev
         | 
| 147 167 | 
             
                  - name: Cache build-tmp directory
         | 
| 148 168 | 
             
                    uses: actions/cache@5a3ec84eff668545956fd18022155c47e93e2684 # v4.2.3
         | 
| 149 169 | 
             
                    with:
         | 
| @@ -162,7 +182,6 @@ jobs: | |
| 162 182 |  | 
| 163 183 | 
             
              specs_precompiled:
         | 
| 164 184 | 
             
                timeout-minutes: 30
         | 
| 165 | 
            -
                runs-on: ubuntu-latest
         | 
| 166 185 | 
             
                needs: build_precompiled
         | 
| 167 186 | 
             
                strategy:
         | 
| 168 187 | 
             
                  fail-fast: false
         | 
| @@ -173,9 +192,13 @@ jobs: | |
| 173 192 | 
             
                      - '3.3'
         | 
| 174 193 | 
             
                      - '3.2'
         | 
| 175 194 | 
             
                      - '3.1'
         | 
| 195 | 
            +
                    ubuntu-version: ['22.04', '24.04']
         | 
| 176 196 | 
             
                    include:
         | 
| 177 197 | 
             
                      - ruby: '3.4'
         | 
| 198 | 
            +
                        ubuntu-version: '24.04'
         | 
| 178 199 | 
             
                        coverage: 'true'
         | 
| 200 | 
            +
             | 
| 201 | 
            +
                runs-on: ubuntu-${{ matrix.ubuntu-version }}
         | 
| 179 202 | 
             
                steps:
         | 
| 180 203 | 
             
                  - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
         | 
| 181 204 | 
             
                    with:
         | 
| @@ -199,7 +222,6 @@ jobs: | |
| 199 222 |  | 
| 200 223 | 
             
                      echo "=== Container status ==="
         | 
| 201 224 | 
             
                      docker compose ps kafka
         | 
| 202 | 
            -
             | 
| 203 225 | 
             
                      for i in {1..30}; do
         | 
| 204 226 | 
             
                        echo "=== Attempt $i/30 ==="
         | 
| 205 227 |  | 
| @@ -1,3 +1,26 @@ | |
| 1 | 
            +
            # Why We Build and Run Without Caching Native Extensions
         | 
| 2 | 
            +
            #
         | 
| 3 | 
            +
            # We intentionally compile the native librdkafka library fresh in each test job
         | 
| 4 | 
            +
            # rather than caching or pre-building it for several reasons:
         | 
| 5 | 
            +
            #
         | 
| 6 | 
            +
            # 1. Architecture Compatibility
         | 
| 7 | 
            +
            #    - Pre-built native libraries (.so files) are architecture-specific
         | 
| 8 | 
            +
            #    - Can cause "Exec format error" when build/runtime environments differ
         | 
| 9 | 
            +
            #    - Building in the same container guarantees compatibility
         | 
| 10 | 
            +
            #
         | 
| 11 | 
            +
            # 2. Container Image Variations
         | 
| 12 | 
            +
            #    - Different Ruby Alpine images may have subtle differences in:
         | 
| 13 | 
            +
            #      * Base system libraries, compiler toolchains, musl libc versions
         | 
| 14 | 
            +
            #    - These differences can cause pre-built libraries to fail at runtime
         | 
| 15 | 
            +
            #
         | 
| 16 | 
            +
            # 3. Simplicity and Reliability
         | 
| 17 | 
            +
            #    - Single source of truth: everything builds and runs in same environment
         | 
| 18 | 
            +
            #    - No artifact management complexity or potential upload/download failures
         | 
| 19 | 
            +
            #    - Easier debugging when issues are contained in one job
         | 
| 20 | 
            +
            #
         | 
| 21 | 
            +
            # Trade-offs: Slightly longer CI times (~2-3 min per job) but much more reliable
         | 
| 22 | 
            +
            # than dealing with architecture mismatches and artifact corruption issues.
         | 
| 23 | 
            +
             | 
| 1 24 | 
             
            name: CI Linux x86_64 musl
         | 
| 2 25 |  | 
| 3 26 | 
             
            concurrency:
         | 
| @@ -20,70 +43,39 @@ env: | |
| 20 43 | 
             
              BUNDLE_JOBS: 4
         | 
| 21 44 |  | 
| 22 45 | 
             
            jobs:
         | 
| 23 | 
            -
              build_install:
         | 
| 24 | 
            -
                timeout-minutes: 30
         | 
| 25 | 
            -
                runs-on: ubuntu-latest
         | 
| 26 | 
            -
                container:
         | 
| 27 | 
            -
                  image: alpine:3.22@sha256:4bcff63911fcb4448bd4fdacec207030997caf25e9bea4045fa6c8c44de311d1
         | 
| 28 | 
            -
                steps:
         | 
| 29 | 
            -
                  - name: Install dependencies
         | 
| 30 | 
            -
                    run: |
         | 
| 31 | 
            -
                      apk add --no-cache git curl ca-certificates build-base linux-headers \
         | 
| 32 | 
            -
                        pkgconf perl autoconf automake libtool bison flex file \
         | 
| 33 | 
            -
                        ruby ruby-dev ruby-bundler bash zstd-dev zlib zlib-dev openssl-dev cyrus-sasl-dev
         | 
| 34 | 
            -
                  - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
         | 
| 35 | 
            -
                    with:
         | 
| 36 | 
            -
                      fetch-depth: 0
         | 
| 37 | 
            -
                  - name: Configure git safe directory
         | 
| 38 | 
            -
                    run: git config --global --add safe.directory /__w/karafka-rdkafka/karafka-rdkafka
         | 
| 39 | 
            -
                  - name: Build gem with mini_portile
         | 
| 40 | 
            -
                    run: |
         | 
| 41 | 
            -
                      set -e
         | 
| 42 | 
            -
                      bundle config set --local path 'vendor/bundle'
         | 
| 43 | 
            -
                      bundle install
         | 
| 44 | 
            -
                      cd ext && bundle exec rake
         | 
| 45 | 
            -
                      cd ..
         | 
| 46 | 
            -
                  - name: Upload built gem and bundle
         | 
| 47 | 
            -
                    uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2
         | 
| 48 | 
            -
                    with:
         | 
| 49 | 
            -
                      name: rdkafka-built-gem-musl
         | 
| 50 | 
            -
                      path: |
         | 
| 51 | 
            -
                        vendor/bundle/
         | 
| 52 | 
            -
                        .bundle/
         | 
| 53 | 
            -
                        ext/
         | 
| 54 | 
            -
                        lib/
         | 
| 55 | 
            -
                      retention-days: 1
         | 
| 56 | 
            -
             | 
| 57 46 | 
             
              specs_install:
         | 
| 58 47 | 
             
                timeout-minutes: 30
         | 
| 59 48 | 
             
                runs-on: ubuntu-latest
         | 
| 60 | 
            -
                needs: build_install
         | 
| 61 49 | 
             
                strategy:
         | 
| 62 50 | 
             
                  fail-fast: false
         | 
| 63 51 | 
             
                  matrix:
         | 
| 64 | 
            -
                    ruby:
         | 
| 65 | 
            -
                      - '3.4'
         | 
| 66 | 
            -
                      - '3.3'
         | 
| 67 | 
            -
                      - '3.2'
         | 
| 68 | 
            -
                      - '3.1'
         | 
| 69 52 | 
             
                    include:
         | 
| 53 | 
            +
                      - ruby: '3.1'
         | 
| 54 | 
            +
                        alpine_version: '3.21'
         | 
| 55 | 
            +
                      - ruby: '3.2'
         | 
| 56 | 
            +
                        alpine_version: '3.21'
         | 
| 57 | 
            +
                      - ruby: '3.2'
         | 
| 58 | 
            +
                        alpine_version: '3.22'
         | 
| 59 | 
            +
                      - ruby: '3.3'
         | 
| 60 | 
            +
                        alpine_version: '3.21'
         | 
| 61 | 
            +
                      - ruby: '3.3'
         | 
| 62 | 
            +
                        alpine_version: '3.22'
         | 
| 63 | 
            +
                      - ruby: '3.4'
         | 
| 64 | 
            +
                        alpine_version: '3.21'
         | 
| 65 | 
            +
                        coverage: 'true'
         | 
| 70 66 | 
             
                      - ruby: '3.4'
         | 
| 67 | 
            +
                        alpine_version: '3.22'
         | 
| 71 68 | 
             
                        coverage: 'true'
         | 
| 72 69 | 
             
                steps:
         | 
| 73 70 | 
             
                  - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
         | 
| 74 71 | 
             
                    with:
         | 
| 75 72 | 
             
                      fetch-depth: 0
         | 
| 76 | 
            -
             | 
| 77 | 
            -
                    uses: actions/download-artifact@d3f86a106a0bac45b974a628896c90dbdf5c8093 # v4.3.0
         | 
| 78 | 
            -
                    with:
         | 
| 79 | 
            -
                      name: rdkafka-built-gem-musl
         | 
| 80 | 
            -
                      path: ./
         | 
| 73 | 
            +
             | 
| 81 74 | 
             
                  - name: Start Kafka with Docker Compose
         | 
| 82 75 | 
             
                    run: |
         | 
| 83 76 | 
             
                      docker compose up -d
         | 
| 84 77 | 
             
                      echo "Waiting for Kafka to be ready..."
         | 
| 85 78 | 
             
                      sleep 10
         | 
| 86 | 
            -
             | 
| 87 79 | 
             
                      for i in {1..30}; do
         | 
| 88 80 | 
             
                        if docker compose exec -T kafka kafka-topics --bootstrap-server localhost:9092 --list >/dev/null 2>&1; then
         | 
| 89 81 | 
             
                          echo "Kafka topics command succeeded!"
         | 
| @@ -91,39 +83,36 @@ jobs: | |
| 91 83 | 
             
                        fi
         | 
| 92 84 | 
             
                        sleep 2
         | 
| 93 85 | 
             
                      done
         | 
| 86 | 
            +
             | 
| 94 87 | 
             
                  - name: Run all specs
         | 
| 95 88 | 
             
                    env:
         | 
| 96 89 | 
             
                      GITHUB_COVERAGE: ${{ matrix.coverage }}
         | 
| 97 | 
            -
                      RDKAFKA_EXT_PATH: ${{ github.workspace }}/ext
         | 
| 98 90 | 
             
                    run: |
         | 
| 99 91 | 
             
                      docker run --rm \
         | 
| 100 92 | 
             
                        --network host \
         | 
| 101 93 | 
             
                        -v "${{ github.workspace }}:/workspace" \
         | 
| 102 94 | 
             
                        -w /workspace \
         | 
| 103 95 | 
             
                        -e "GITHUB_COVERAGE=${{ matrix.coverage }}" \
         | 
| 104 | 
            -
                        - | 
| 105 | 
            -
                         | 
| 106 | 
            -
             | 
| 107 | 
            -
                           | 
| 108 | 
            -
                          cyrus-sasl-login \
         | 
| 109 | 
            -
                          cyrus-sasl-crammd5 \
         | 
| 110 | 
            -
                           | 
| 111 | 
            -
                          cyrus-sasl-gssapiv2 \
         | 
| 112 | 
            -
                          cyrus-sasl-scram \
         | 
| 113 | 
            -
                          krb5-libs \
         | 
| 114 | 
            -
                          openssl \
         | 
| 115 | 
            -
                          zlib \
         | 
| 116 | 
            -
                          zlib-dev \
         | 
| 117 | 
            -
                          zstd-libs && \
         | 
| 96 | 
            +
                        ruby:${{ matrix.ruby }}-alpine${{ matrix.alpine_version }} \
         | 
| 97 | 
            +
                        sh -c 'apk add --no-cache git curl ca-certificates build-base linux-headers \
         | 
| 98 | 
            +
                          pkgconf perl autoconf automake libtool bison flex file \
         | 
| 99 | 
            +
                          ruby-dev ruby-bundler bash zstd-dev zlib zlib-dev openssl-dev \
         | 
| 100 | 
            +
                          cyrus-sasl-dev cyrus-sasl cyrus-sasl-login \
         | 
| 101 | 
            +
                          cyrus-sasl-crammd5 cyrus-sasl-digestmd5 cyrus-sasl-gssapiv2 cyrus-sasl-scram \
         | 
| 102 | 
            +
                          krb5-libs openssl zlib zstd-libs && \
         | 
| 118 103 | 
             
                          git config --global --add safe.directory /workspace && \
         | 
| 119 104 | 
             
                          bundle config set --local path vendor/bundle && \
         | 
| 120 105 | 
             
                          bundle install && \
         | 
| 106 | 
            +
                          cd ext && bundle exec rake && \
         | 
| 107 | 
            +
                          cd .. && \
         | 
| 121 108 | 
             
                          bundle exec ruby -S rspec'
         | 
| 109 | 
            +
             | 
| 122 110 | 
             
              build_precompiled:
         | 
| 123 111 | 
             
                timeout-minutes: 45
         | 
| 124 112 | 
             
                runs-on: ubuntu-latest
         | 
| 125 113 | 
             
                container:
         | 
| 126 | 
            -
                   | 
| 114 | 
            +
                  # Similar to GNU, we build on the oldest for ABI compatibility
         | 
| 115 | 
            +
                  image: alpine:3.18@sha256:de0eb0b3f2a47ba1eb89389859a9bd88b28e82f5826b6969ad604979713c2d4f # renovate: ignore
         | 
| 127 116 | 
             
                steps:
         | 
| 128 117 | 
             
                  - name: Install dependencies
         | 
| 129 118 | 
             
                    run: |
         | 
| @@ -22,44 +22,8 @@ env: | |
| 22 22 | 
             
              CONFLUENT_VERSION: "8.0.0"
         | 
| 23 23 |  | 
| 24 24 | 
             
            jobs:
         | 
| 25 | 
            -
              build_install:
         | 
| 26 | 
            -
                timeout-minutes: 30
         | 
| 27 | 
            -
                runs-on: macos-latest
         | 
| 28 | 
            -
                steps:
         | 
| 29 | 
            -
                  - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
         | 
| 30 | 
            -
                    with:
         | 
| 31 | 
            -
                      fetch-depth: 0
         | 
| 32 | 
            -
                  - name: Install Bash 4+ and Kerberos
         | 
| 33 | 
            -
                    run: |
         | 
| 34 | 
            -
                      brew install bash
         | 
| 35 | 
            -
                      brew list krb5 &>/dev/null || brew install krb5
         | 
| 36 | 
            -
                      echo "/opt/homebrew/bin" >> $GITHUB_PATH
         | 
| 37 | 
            -
                  - name: Set up Ruby
         | 
| 38 | 
            -
                    uses: ruby/setup-ruby@a4effe49ee8ee5b8b5091268c473a4628afb5651 # v1.245.0
         | 
| 39 | 
            -
                    with:
         | 
| 40 | 
            -
                      ruby-version: '3.4'  # Use one Ruby version for building
         | 
| 41 | 
            -
                      bundler-cache: false
         | 
| 42 | 
            -
                  - name: Build gem with mini_portile
         | 
| 43 | 
            -
                    run: |
         | 
| 44 | 
            -
                      set -e
         | 
| 45 | 
            -
                      bundle install
         | 
| 46 | 
            -
                      cd ext && bundle exec rake
         | 
| 47 | 
            -
                      cd ..
         | 
| 48 | 
            -
                  - name: Upload built gem and bundle
         | 
| 49 | 
            -
                    uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2
         | 
| 50 | 
            -
                    with:
         | 
| 51 | 
            -
                      name: rdkafka-built-gem-macos
         | 
| 52 | 
            -
                      path: |
         | 
| 53 | 
            -
                        vendor/bundle/
         | 
| 54 | 
            -
                        .bundle/
         | 
| 55 | 
            -
                        ext/
         | 
| 56 | 
            -
                        lib/
         | 
| 57 | 
            -
                      retention-days: 1
         | 
| 58 | 
            -
             | 
| 59 25 | 
             
              specs_install:
         | 
| 60 26 | 
             
                timeout-minutes: 30
         | 
| 61 | 
            -
                runs-on: macos-latest
         | 
| 62 | 
            -
                needs: build_install
         | 
| 63 27 | 
             
                strategy:
         | 
| 64 28 | 
             
                  fail-fast: false
         | 
| 65 29 | 
             
                  matrix:
         | 
| @@ -69,18 +33,21 @@ jobs: | |
| 69 33 | 
             
                      - '3.3'
         | 
| 70 34 | 
             
                      - '3.2'
         | 
| 71 35 | 
             
                      - '3.1'
         | 
| 36 | 
            +
                    macos-version:
         | 
| 37 | 
            +
                      - 'macos-14' # macOS 14 Sonoma (ARM64)
         | 
| 38 | 
            +
                      - 'macos-15' # macOS 15 Sequoia (ARM64)
         | 
| 72 39 | 
             
                    include:
         | 
| 73 40 | 
             
                      - ruby: '3.4'
         | 
| 41 | 
            +
                        macos-version: 'macos-15'
         | 
| 74 42 | 
             
                        coverage: 'true'
         | 
| 43 | 
            +
                    exclude:
         | 
| 44 | 
            +
                      - ruby: '3.5.0-preview1'
         | 
| 45 | 
            +
                        macos-version: 'macos-14'
         | 
| 46 | 
            +
                runs-on: ${{ matrix.macos-version }}
         | 
| 75 47 | 
             
                steps:
         | 
| 76 48 | 
             
                  - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
         | 
| 77 49 | 
             
                    with:
         | 
| 78 50 | 
             
                      fetch-depth: 0
         | 
| 79 | 
            -
                  - name: Download built gem
         | 
| 80 | 
            -
                    uses: actions/download-artifact@d3f86a106a0bac45b974a628896c90dbdf5c8093 # v4.3.0
         | 
| 81 | 
            -
                    with:
         | 
| 82 | 
            -
                      name: rdkafka-built-gem-macos
         | 
| 83 | 
            -
                      path: ./
         | 
| 84 51 | 
             
                  - name: Install Bash 4+ and Kerberos
         | 
| 85 52 | 
             
                    run: |
         | 
| 86 53 | 
             
                      brew install bash
         | 
| @@ -153,12 +120,16 @@ jobs: | |
| 153 120 | 
             
                        [ $i -eq 30 ] && { echo "❌ Kafka failed to start"; exit 1; }
         | 
| 154 121 | 
             
                        sleep 2
         | 
| 155 122 | 
             
                      done
         | 
| 156 | 
            -
                  - name: Install  | 
| 123 | 
            +
                  - name: Install dependencies
         | 
| 157 124 | 
             
                    env:
         | 
| 158 125 | 
             
                      RDKAFKA_EXT_PATH: ${{ github.workspace }}/ext
         | 
| 159 126 | 
             
                    run: |
         | 
| 160 | 
            -
                      # Only install gems that aren't Ruby-version specific
         | 
| 161 127 | 
             
                      bundle install
         | 
| 128 | 
            +
                  - name: Build gem with mini_portile
         | 
| 129 | 
            +
                    run: |
         | 
| 130 | 
            +
                      set -e
         | 
| 131 | 
            +
                      cd ext && bundle exec rake
         | 
| 132 | 
            +
                      cd ..
         | 
| 162 133 | 
             
                  - name: Run all specs
         | 
| 163 134 | 
             
                    env:
         | 
| 164 135 | 
             
                      GITHUB_COVERAGE: ${{matrix.coverage}}
         | 
| @@ -168,7 +139,7 @@ jobs: | |
| 168 139 |  | 
| 169 140 | 
             
              build_precompiled:
         | 
| 170 141 | 
             
                timeout-minutes: 45
         | 
| 171 | 
            -
                runs-on: macos- | 
| 142 | 
            +
                runs-on: macos-14
         | 
| 172 143 | 
             
                steps:
         | 
| 173 144 | 
             
                  - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
         | 
| 174 145 | 
             
                    with:
         | 
| @@ -196,7 +167,6 @@ jobs: | |
| 196 167 |  | 
| 197 168 | 
             
              specs_precompiled:
         | 
| 198 169 | 
             
                timeout-minutes: 30
         | 
| 199 | 
            -
                runs-on: macos-latest
         | 
| 200 170 | 
             
                needs: build_precompiled
         | 
| 201 171 | 
             
                strategy:
         | 
| 202 172 | 
             
                  fail-fast: false
         | 
| @@ -207,9 +177,17 @@ jobs: | |
| 207 177 | 
             
                      - '3.3'
         | 
| 208 178 | 
             
                      - '3.2'
         | 
| 209 179 | 
             
                      - '3.1'
         | 
| 180 | 
            +
                    macos-version:
         | 
| 181 | 
            +
                      - 'macos-14'
         | 
| 182 | 
            +
                      - 'macos-15'
         | 
| 210 183 | 
             
                    include:
         | 
| 211 184 | 
             
                      - ruby: '3.4'
         | 
| 185 | 
            +
                        macos-version: 'macos-15'
         | 
| 212 186 | 
             
                        coverage: 'true'
         | 
| 187 | 
            +
                    exclude:
         | 
| 188 | 
            +
                      - ruby: '3.5.0-preview1'
         | 
| 189 | 
            +
                        macos-version: 'macos-14'
         | 
| 190 | 
            +
                runs-on: ${{ matrix.macos-version }}
         | 
| 213 191 | 
             
                steps:
         | 
| 214 192 | 
             
                  - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
         | 
| 215 193 | 
             
                    with:
         | 
| @@ -16,7 +16,8 @@ jobs: | |
| 16 16 | 
             
              push:
         | 
| 17 17 | 
             
                if: github.repository_owner == 'karafka'
         | 
| 18 18 | 
             
                timeout-minutes: 30
         | 
| 19 | 
            -
                 | 
| 19 | 
            +
                # Same as CI, we build on the oldest possible for ABI compatibility
         | 
| 20 | 
            +
                runs-on: ubuntu-22.04 # renovate: ignore
         | 
| 20 21 | 
             
                environment: deployment
         | 
| 21 22 | 
             
                permissions:
         | 
| 22 23 | 
             
                  contents: write
         | 
| @@ -15,7 +15,8 @@ jobs: | |
| 15 15 | 
             
                runs-on: ubuntu-latest
         | 
| 16 16 | 
             
                environment: deployment
         | 
| 17 17 | 
             
                container:
         | 
| 18 | 
            -
                   | 
| 18 | 
            +
                  # Same as CI, we build on the oldest possible for ABI compatibility
         | 
| 19 | 
            +
                  image: alpine:3.18@sha256:de0eb0b3f2a47ba1eb89389859a9bd88b28e82f5826b6969ad604979713c2d4f # renovate: ignore
         | 
| 19 20 | 
             
                steps:
         | 
| 20 21 | 
             
                  - name: Install dependencies
         | 
| 21 22 | 
             
                    run: |
         | 
| @@ -44,6 +45,7 @@ jobs: | |
| 44 45 | 
             
                      name: librdkafka-precompiled-musl
         | 
| 45 46 | 
             
                      path: ext/
         | 
| 46 47 | 
             
                      retention-days: 1
         | 
| 48 | 
            +
             | 
| 47 49 | 
             
              push:
         | 
| 48 50 | 
             
                if: github.repository_owner == 'karafka'
         | 
| 49 51 | 
             
                timeout-minutes: 30
         | 
    
        data/CHANGELOG.md
    CHANGED
    
    | @@ -1,5 +1,13 @@ | |
| 1 1 | 
             
            # Rdkafka Changelog
         | 
| 2 2 |  | 
| 3 | 
            +
            ## 0.21.0 (Unreleased)
         | 
| 4 | 
            +
            - [Enhancement] Bump librdkafka to 2.11.0
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            ## 0.20.1 (2025-07-17)
         | 
| 7 | 
            +
            - [Enhancement] Drastically increase number of platforms in the integration suite
         | 
| 8 | 
            +
            - [Fix] Support Ubuntu `22.04` and older Alpine precompiled versions
         | 
| 9 | 
            +
            - [Fix] FFI::DynamicLibrary.load_library': Could not open library
         | 
| 10 | 
            +
             | 
| 3 11 | 
             
            ## 0.20.0 (2025-07-17)
         | 
| 4 12 | 
             
            - **[Feature]** Add precompiled `x86_64-linux-gnu` setup.
         | 
| 5 13 | 
             
            - **[Feature]** Add precompiled `x86_64-linux-musl` setup.
         | 
    
        data/README.md
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            # Rdkafka
         | 
| 2 2 |  | 
| 3 | 
            -
            [](https://badge.fury.io/rb/rdkafka)
         | 
| 3 | 
            +
            [](https://github.com/karafka/karafka-rdkafka/actions/workflows/ci_linux_x86_64_gnu.yml)
         | 
| 4 | 
            +
            [](https://badge.fury.io/rb/karafka-rdkafka)
         | 
| 5 5 | 
             
            [](https://slack.karafka.io)
         | 
| 6 6 |  | 
| 7 7 | 
             
            > [!NOTE]
         | 
| @@ -163,15 +163,16 @@ bundle exec rake produce_messages | |
| 163 163 |  | 
| 164 164 | 
             
            | rdkafka-ruby | librdkafka | patches |
         | 
| 165 165 | 
             
            |-|-|-|
         | 
| 166 | 
            -
            | 0. | 
| 167 | 
            -
            | 0. | 
| 168 | 
            -
            | 0. | 
| 169 | 
            -
            | 0. | 
| 170 | 
            -
            | 0.17. | 
| 171 | 
            -
            | 0. | 
| 172 | 
            -
            | 0. | 
| 173 | 
            -
            | 0. | 
| 174 | 
            -
            | 0. | 
| 175 | 
            -
            | 0. | 
| 176 | 
            -
            | 0. | 
| 177 | 
            -
            | 0. | 
| 166 | 
            +
            | 0.21.x (Unreleased) | 2.11.0 (2025-07-03)  | yes |
         | 
| 167 | 
            +
            | 0.20.x (2025-07-17) | 2.8.0  (2025-01-07)  | yes |
         | 
| 168 | 
            +
            | 0.19.x (2025-01-20) | 2.8.0  (2025-01-07)  | yes |
         | 
| 169 | 
            +
            | 0.18.0 (2024-11-26) | 2.6.1  (2024-11-18)  | yes |
         | 
| 170 | 
            +
            | 0.17.4 (2024-09-02) | 2.5.3  (2024-09-02)  | yes |
         | 
| 171 | 
            +
            | 0.17.0 (2024-08-01) | 2.5.0  (2024-07-10)  | yes |
         | 
| 172 | 
            +
            | 0.16.0 (2024-06-13) | 2.4.0  (2024-05-07)  | no  |
         | 
| 173 | 
            +
            | 0.15.0 (2023-12-03) | 2.3.0  (2023-10-25)  | no  |
         | 
| 174 | 
            +
            | 0.14.0 (2023-11-21) | 2.2.0  (2023-07-12)  | no  |
         | 
| 175 | 
            +
            | 0.13.0 (2023-07-24) | 2.0.2  (2023-01-20)  | no  |
         | 
| 176 | 
            +
            | 0.12.0 (2022-06-17) | 1.9.0  (2022-06-16)  | no  |
         | 
| 177 | 
            +
            | 0.11.0 (2021-11-17) | 1.8.2  (2021-10-18)  | no  |
         | 
| 178 | 
            +
            | 0.10.0 (2021-09-07) | 1.5.0  (2020-07-20)  | no  |
         | 
    
        data/ext/build_common.sh
    CHANGED
    
    | @@ -19,7 +19,7 @@ readonly CYRUS_SASL_VERSION="2.1.28" | |
| 19 19 | 
             
            readonly ZLIB_VERSION="1.3.1"
         | 
| 20 20 | 
             
            readonly ZSTD_VERSION="1.5.7"
         | 
| 21 21 | 
             
            readonly KRB5_VERSION="1.21.3"
         | 
| 22 | 
            -
            readonly LIBRDKAFKA_VERSION="2. | 
| 22 | 
            +
            readonly LIBRDKAFKA_VERSION="2.11.0"
         | 
| 23 23 |  | 
| 24 24 | 
             
            # SHA256 checksums for supply chain security
         | 
| 25 25 | 
             
            # Update these when upgrading versions
         | 
| @@ -29,7 +29,7 @@ declare -A CHECKSUMS=( | |
| 29 29 | 
             
                ["zlib-1.3.1.tar.gz"]="9a93b2b7dfdac77ceba5a558a580e74667dd6fede4585b91eefb60f03b72df23"
         | 
| 30 30 | 
             
                ["zstd-${ZSTD_VERSION}.tar.gz"]="eb33e51f49a15e023950cd7825ca74a4a2b43db8354825ac24fc1b7ee09e6fa3"
         | 
| 31 31 | 
             
                ["krb5-${KRB5_VERSION}.tar.gz"]="b7a4cd5ead67fb08b980b21abd150ff7217e85ea320c9ed0c6dadd304840ad35"
         | 
| 32 | 
            -
                ["librdkafka-${LIBRDKAFKA_VERSION}.tar.gz"]=" | 
| 32 | 
            +
                ["librdkafka-${LIBRDKAFKA_VERSION}.tar.gz"]="592a823dc7c09ad4ded1bc8f700da6d4e0c88ffaf267815c6f25e7450b9395ca"
         | 
| 33 33 | 
             
            )
         | 
| 34 34 |  | 
| 35 35 | 
             
            # Colors for output
         | 
| @@ -285,12 +285,12 @@ file librdkafka.so | |
| 285 285 | 
             
            log "Checking dependencies with ldd:"
         | 
| 286 286 | 
             
            ldd librdkafka.so
         | 
| 287 287 |  | 
| 288 | 
            -
            log "Checking for  | 
| 289 | 
            -
             | 
| 290 | 
            -
            if [ -n "$ | 
| 291 | 
            -
                error "Found  | 
| 288 | 
            +
            log "Checking for non-system library dependencies:"
         | 
| 289 | 
            +
            NON_SYSTEM_DEPS=$(ldd librdkafka.so | grep -v -E "(linux-vdso|ld-linux|libc\.so|libpthread\.so|libm\.so|libdl\.so)" || true)
         | 
| 290 | 
            +
            if [ -n "$NON_SYSTEM_DEPS" ]; then
         | 
| 291 | 
            +
                error "Found non-system dependencies: $NON_SYSTEM_DEPS"
         | 
| 292 292 | 
             
            else
         | 
| 293 | 
            -
                log "✅  | 
| 293 | 
            +
                log "✅ Only system dependencies found - library is portable!"
         | 
| 294 294 | 
             
            fi
         | 
| 295 295 |  | 
| 296 296 | 
             
            # Copy to output directory
         | 
    
        data/ext/librdkafka.so
    CHANGED
    
    | Binary file | 
    
        data/karafka-rdkafka.gemspec
    CHANGED
    
    | @@ -40,31 +40,6 @@ Gem::Specification.new do |gem| | |
| 40 40 | 
             
                gem.extensions = %w(ext/Rakefile)
         | 
| 41 41 | 
             
              end
         | 
| 42 42 |  | 
| 43 | 
            -
              if ENV['RUBY_PLATFORM']
         | 
| 44 | 
            -
                gem.platform = ENV['RUBY_PLATFORM']
         | 
| 45 | 
            -
                gem.files = `git ls-files`.split($\)
         | 
| 46 | 
            -
             | 
| 47 | 
            -
                # Do not include the source code for librdkafka as it should be precompiled already per
         | 
| 48 | 
            -
                # platform. Same applies to any possible patches.
         | 
| 49 | 
            -
                gem.files = gem.files.reject do |file|
         | 
| 50 | 
            -
                  file.match?(%r{^dist/librdkafka-.*\.tar\.gz$}) ||
         | 
| 51 | 
            -
                  file.match?(%r{^dist/patches/})
         | 
| 52 | 
            -
                end
         | 
| 53 | 
            -
             | 
| 54 | 
            -
                # Add the compiled extensions that exist (not in git)
         | 
| 55 | 
            -
                if File.exist?('ext/librdkafka.so')
         | 
| 56 | 
            -
                  gem.files << 'ext/librdkafka.so'
         | 
| 57 | 
            -
                end
         | 
| 58 | 
            -
             | 
| 59 | 
            -
                if File.exist?('ext/librdkafka.dylib')
         | 
| 60 | 
            -
                  gem.files << 'ext/librdkafka.dylib'
         | 
| 61 | 
            -
                end
         | 
| 62 | 
            -
              else
         | 
| 63 | 
            -
                gem.platform = Gem::Platform::RUBY
         | 
| 64 | 
            -
                gem.files = `git ls-files`.split($\)
         | 
| 65 | 
            -
                gem.extensions = %w(ext/Rakefile)
         | 
| 66 | 
            -
              end
         | 
| 67 | 
            -
             | 
| 68 43 | 
             
              gem.add_dependency 'ffi', '~> 1.15'
         | 
| 69 44 | 
             
              gem.add_dependency 'logger'
         | 
| 70 45 | 
             
              gem.add_dependency 'mini_portile2', '~> 2.6'
         | 
    
        data/lib/rdkafka/config.rb
    CHANGED
    
    | @@ -129,10 +129,7 @@ module Rdkafka | |
| 129 129 | 
             
                end
         | 
| 130 130 |  | 
| 131 131 | 
             
                # Default config that can be overwritten.
         | 
| 132 | 
            -
                DEFAULT_CONFIG = {
         | 
| 133 | 
            -
                  # Request api version so advanced features work
         | 
| 134 | 
            -
                  :"api.version.request" => true
         | 
| 135 | 
            -
                }.freeze
         | 
| 132 | 
            +
                DEFAULT_CONFIG = {}.freeze
         | 
| 136 133 |  | 
| 137 134 | 
             
                # Required config that cannot be overwritten.
         | 
| 138 135 | 
             
                REQUIRED_CONFIG = {
         | 
    
        data/lib/rdkafka/version.rb
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            # frozen_string_literal: true
         | 
| 2 2 |  | 
| 3 3 | 
             
            module Rdkafka
         | 
| 4 | 
            -
              VERSION = "0. | 
| 5 | 
            -
              LIBRDKAFKA_VERSION = "2. | 
| 6 | 
            -
              LIBRDKAFKA_SOURCE_SHA256 = " | 
| 4 | 
            +
              VERSION = "0.21.0.rc1"
         | 
| 5 | 
            +
              LIBRDKAFKA_VERSION = "2.11.0"
         | 
| 6 | 
            +
              LIBRDKAFKA_SOURCE_SHA256 = "592a823dc7c09ad4ded1bc8f700da6d4e0c88ffaf267815c6f25e7450b9395ca"
         | 
| 7 7 | 
             
            end
         | 
    
        data/spec/rdkafka/admin_spec.rb
    CHANGED
    
    | @@ -34,7 +34,7 @@ describe Rdkafka::Admin do | |
| 34 34 | 
             
              describe '#describe_errors' do
         | 
| 35 35 | 
             
                let(:errors) { admin.class.describe_errors }
         | 
| 36 36 |  | 
| 37 | 
            -
                it { expect(errors.size).to eq( | 
| 37 | 
            +
                it { expect(errors.size).to eq(172) }
         | 
| 38 38 | 
             
                it { expect(errors[-184]).to eq(code: -184, description: 'Local: Queue full', name: '_QUEUE_FULL') }
         | 
| 39 39 | 
             
                it { expect(errors[21]).to eq(code: 21, description: 'Broker: Invalid required acks value', name: 'INVALID_REQUIRED_ACKS') }
         | 
| 40 40 | 
             
              end
         | 
    
        data/spec/rdkafka/config_spec.rb
    CHANGED
    
    | @@ -159,7 +159,7 @@ describe Rdkafka::Config do | |
| 159 159 |  | 
| 160 160 | 
             
                it "should use default configuration" do
         | 
| 161 161 | 
             
                  config = Rdkafka::Config.new
         | 
| 162 | 
            -
                  expect(config[:"api.version.request"]).to eq  | 
| 162 | 
            +
                  expect(config[:"api.version.request"]).to eq nil
         | 
| 163 163 | 
             
                end
         | 
| 164 164 |  | 
| 165 165 | 
             
                it "should create a consumer with valid config" do
         | 
| @@ -263,8 +263,6 @@ describe Rdkafka::Producer do | |
| 263 263 | 
             
                expect(message.partition).to eq 1
         | 
| 264 264 | 
             
                expect(message.payload).to eq "payload"
         | 
| 265 265 | 
             
                expect(message.key).to eq "key"
         | 
| 266 | 
            -
                # Since api.version.request is on by default we will get
         | 
| 267 | 
            -
                # the message creation timestamp if it's not set.
         | 
| 268 266 | 
             
                expect(message.timestamp).to be_within(10).of(Time.now)
         | 
| 269 267 | 
             
              end
         | 
| 270 268 |  | 
    
        data/spec/spec_helper.rb
    CHANGED
    
    | @@ -15,9 +15,7 @@ require "securerandom" | |
| 15 15 |  | 
| 16 16 | 
             
            def rdkafka_base_config
         | 
| 17 17 | 
             
              {
         | 
| 18 | 
            -
                :" | 
| 19 | 
            -
                :"broker.version.fallback" => "1.0",
         | 
| 20 | 
            -
                :"bootstrap.servers" => "127.0.0.1:9092",
         | 
| 18 | 
            +
                :"bootstrap.servers" => "localhost:9092",
         | 
| 21 19 | 
             
                # Display statistics and refresh often just to cover those in specs
         | 
| 22 20 | 
             
                :'statistics.interval.ms' => 1_000,
         | 
| 23 21 | 
             
                :'topic.metadata.refresh.interval.ms' => 1_000
         |