Sha256: df353fa0b10207288306d273e1a09e5136320d8d9ea3860c93e6eac625342acc

Contents?: true

Size: 1.35 KB

Versions: 1

Compression:

Stored size: 1.35 KB

Contents

# Test arbitrary beaker versions without modifying test code

In order to adjust the beaker version used without commiting a change to a Gemfile,
we at Puppet often use a method in our code that changes the dependency based on the
existence of ENV variables in the shell that beaker is executing from. The code
itself looks like this:

```ruby

def location_for(place, fake_version = nil)
  if place =~ /^(git[:@][^#]*)#(.*)/
    [fake_version, { :git => $1, :branch => $2, :require => false }].compact
  elsif place =~ /^file:\/\/(.*)/
    ['>= 0', { :path => File.expand_path($1), :require => false }]
  else
    [place, { :require => false }]
  end
end

```

Once this method definition is in place in the Gemfile, we can call it in a gem command, like
this:

```ruby

gem 'beaker', *location_for(ENV['BEAKER_VERSION'] || '~> 2.0')
```

## Example BEAKER_VERSIONs

### git locations

```
git@github.com:puppetlabs/beaker.git#master
git://github.com/puppetlabs/beaker.git#master
```

### file locations
```
file://../relative/path/to/beaker
```
By adjusting the shell environment that beaker is running in, we can modify what version of
beaker is installed by bundler on your test coordinator without modifying any of the test
code. This strategy can be used for any gem dependency, and is often used when testing
[beaker libraries](../concepts/beaker_libraries.md) at Puppet.

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
beaker-3.35.0 docs/how_to/test_arbitrary_beaker_versions.md