8 changed files with 169 additions and 21 deletions
@ -0,0 +1,46 @@
|
||||
disable_build_globally |
||||
====================== |
||||
|
||||
Disable the given build group for all future ``Squib::Deck`` runs. |
||||
|
||||
Essentially a convenience method for setting the ``SQUIB_BUILD`` environment variable. See :doc:`/build_groups` for ways to use this effectively. |
||||
|
||||
This is a member of the ``Squib`` module, so you must run it like this:: |
||||
|
||||
Squib.disable_build_globally :pdf |
||||
|
||||
The intended purpose of this method is to be able to alter the environment from other build scripts, such as a Rakefile. |
||||
|
||||
Required Arguments |
||||
------------------ |
||||
|
||||
build_group_name |
||||
|
||||
the name of the build group to disable. Convention is to use a Ruby symbol. |
||||
|
||||
|
||||
Examples |
||||
-------- |
||||
|
||||
Can be used to disable a group, overriding setting the environment variable at the command line:: |
||||
|
||||
Squib.enable_build_globally :pdf |
||||
Squib.disable_build_globally :pdf |
||||
|
||||
Squib::Deck.new do |
||||
build :pdf do |
||||
save_pdf #does not get run regardless of incoming environment |
||||
end |
||||
end |
||||
|
||||
But gets overridden by an individual ``Squib::Deck`` programmatically enabling a build via :doc:`/dsl/enable_build`:: |
||||
|
||||
Squib.enable_build_globally :pdf |
||||
Squib.disable_build_globally :pdf |
||||
|
||||
Squib::Deck.new do |
||||
enable_build :pdf |
||||
build :pdf do |
||||
save_pdf # this will be run no matter what |
||||
end |
||||
end |
||||
@ -0,0 +1,44 @@
|
||||
disable_build_globally |
||||
====================== |
||||
|
||||
Enagle the given build group for all future ``Squib::Deck`` runs. |
||||
|
||||
Essentially a convenience method for setting the ``SQUIB_BUILD`` environment variable. See :doc:`/build_groups` for ways to use this effectively. |
||||
|
||||
This is a member of the ``Squib`` module, so you must run it like this:: |
||||
|
||||
Squib.enable_build_globally :pdf |
||||
|
||||
The intended purpose of this method is to be able to alter the environment from other build scripts, such as a Rakefile. |
||||
|
||||
Required Arguments |
||||
------------------ |
||||
|
||||
build_group_name |
||||
|
||||
the name of the build group to enable. Convention is to use a Ruby symbol. |
||||
|
||||
|
||||
Examples |
||||
-------- |
||||
|
||||
Can be used to enable a group, overriding setting the environment variable at the command line:: |
||||
|
||||
Squib.enable_build_globally :pdf |
||||
|
||||
Squib::Deck.new do |
||||
build :pdf do |
||||
save_pdf # this runs regardless of incoming environment |
||||
end |
||||
end |
||||
|
||||
But gets overridden by an individual ``Squib::Deck`` programmatically enabling a build via :doc:`/dsl/enable_build`:: |
||||
|
||||
Squib.enable_build_globally :pdf |
||||
|
||||
Squib::Deck.new do |
||||
disable_build :pdf |
||||
build :pdf do |
||||
save_pdf # this will NOT be run no matter what |
||||
end |
||||
end |
||||
@ -0,0 +1,49 @@
|
||||
require 'spec_helper' |
||||
require 'squib' |
||||
|
||||
describe :build_group do |
||||
|
||||
context '#enable_build_globally' do |
||||
before(:each) { ENV['SQUIB_BUILD'] = '' } |
||||
|
||||
it 'enables one group via ENV' do |
||||
Squib.enable_build_globally 'foo' |
||||
expect(ENV['SQUIB_BUILD']).to eq 'foo' |
||||
end |
||||
|
||||
it 'enables two groups via ENV' do |
||||
Squib.enable_build_globally 'foo' |
||||
Squib.enable_build_globally 'bar' |
||||
expect(ENV['SQUIB_BUILD']).to eq 'foo,bar' |
||||
end |
||||
|
||||
it 'uniqs the groups' do |
||||
Squib.enable_build_globally 'foo' |
||||
Squib.enable_build_globally 'bar' |
||||
Squib.enable_build_globally 'bar' |
||||
expect(ENV['SQUIB_BUILD']).to eq 'foo,bar' |
||||
end |
||||
|
||||
it 'handles symbols' do |
||||
Squib.enable_build_globally :foo |
||||
expect(ENV['SQUIB_BUILD']).to eq 'foo' |
||||
end |
||||
|
||||
end |
||||
|
||||
context '#disable_build_globally' do |
||||
before(:each) { ENV['SQUIB_BUILD'] = 'foo,bar' } |
||||
|
||||
it 'can be disabled globally via ENV' do |
||||
Squib.disable_build_globally 'bar' |
||||
expect(ENV['SQUIB_BUILD']).to eq 'foo' |
||||
end |
||||
|
||||
it 'handles symbols' do |
||||
Squib.disable_build_globally :bar |
||||
expect(ENV['SQUIB_BUILD']).to eq 'foo' |
||||
end |
||||
end |
||||
|
||||
|
||||
end |
||||
Loading…
Reference in new issue