free_mutant/spec/unit/mutant/mutation_spec.rb
Markus Schirp 70b4230399 Drop Subject#public?
* A relict from the days where test selection depended on this
  information
* Kill mutations in Mutation#insert, also very old code.
2015-10-31 01:27:57 +00:00

76 lines
1.7 KiB
Ruby

RSpec.describe Mutant::Mutation do
class TestMutation < Mutant::Mutation
SYMBOL = 'test'.freeze
end
let(:object) { TestMutation.new(mutation_subject, Mutant::AST::Nodes::N_NIL) }
let(:context) { instance_double(Mutant::Context) }
let(:mutation_subject) do
instance_double(
Mutant::Subject,
identification: 'subject',
context: context,
source: 'original'
)
end
let(:test_a) { instance_double(Mutant::Test) }
let(:test_b) { instance_double(Mutant::Test) }
describe '#insert' do
subject { object.insert }
let(:root_node) { s(:foo) }
before do
expect(context).to receive(:root)
.with(object.node)
.and_return(root_node)
expect(mutation_subject).to receive(:prepare)
.ordered
.and_return(mutation_subject)
expect(Mutant::Loader::Eval).to receive(:call)
.ordered
.with(root_node, mutation_subject)
.and_return(Mutant::Loader::Eval)
end
it_should_behave_like 'a command method'
end
describe '#code' do
subject { object.code }
it { should eql('8771a') }
it_should_behave_like 'an idempotent method'
end
describe '#original_source' do
subject { object.original_source }
it { should eql('original') }
it_should_behave_like 'an idempotent method'
end
describe '#source' do
subject { object.source }
it { should eql('nil') }
it_should_behave_like 'an idempotent method'
end
describe '#identification' do
subject { object.identification }
it { should eql('test:subject:8771a') }
it_should_behave_like 'an idempotent method'
end
end