83 lines
2.0 KiB
Ruby
83 lines
2.0 KiB
Ruby
module Producer::Core
|
|
shared_examples 'test' do
|
|
include TestEnvHelpers
|
|
|
|
let(:arguments) { [:some, :arguments] }
|
|
subject(:test) { described_class.new(env, *arguments) }
|
|
|
|
describe '#initialize' do
|
|
it 'assigns the env' do
|
|
expect(test.env).to be env
|
|
end
|
|
|
|
it 'assigns the arguments' do
|
|
expect(test.arguments).to eq arguments
|
|
end
|
|
|
|
it 'assigns negated as false by default' do
|
|
expect(test).not_to be_negated
|
|
end
|
|
|
|
context 'when negated option is true' do
|
|
subject(:test) { described_class.new(env, *arguments, negated: true) }
|
|
|
|
it 'assigns negated as true' do
|
|
expect(test).to be_negated
|
|
end
|
|
end
|
|
end
|
|
|
|
describe '#remote' do
|
|
it 'returns env remote' do
|
|
expect(test.remote).to be test.env.remote
|
|
end
|
|
end
|
|
|
|
describe '#fs' do
|
|
it 'returns env remote fs' do
|
|
expect(test.fs).to be test.env.remote.fs
|
|
end
|
|
end
|
|
|
|
describe '#negated?' do
|
|
it 'returns false' do
|
|
expect(test.negated?).to be false
|
|
end
|
|
|
|
context 'when test is negated' do
|
|
subject(:test) { described_class.new(env, *arguments, negated: true) }
|
|
|
|
it 'returns true' do
|
|
expect(test.negated?).to be true
|
|
end
|
|
end
|
|
end
|
|
|
|
describe '#pass?' do
|
|
it 'returns true when #verify is true' do
|
|
allow(test).to receive(:verify) { true }
|
|
expect(test.pass?).to be true
|
|
end
|
|
|
|
it 'returns false when #verify is false' do
|
|
allow(test).to receive(:verify) { false }
|
|
expect(test.pass?).to be false
|
|
end
|
|
|
|
context 'when test is negated' do
|
|
subject(:test) { described_class.new(env, *arguments, negated: true) }
|
|
|
|
it 'returns false when #verify is true' do
|
|
allow(test).to receive(:verify) { true }
|
|
expect(test.pass?).to be false
|
|
end
|
|
|
|
it 'returns true when #verify is false' do
|
|
allow(test).to receive(:verify) { false }
|
|
expect(test.pass?).to be true
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|