2017-05-22 03:23:50 +02:00
|
|
|
require "lock_file"
|
2017-02-20 22:43:09 +01:00
|
|
|
|
2017-05-22 03:23:50 +02:00
|
|
|
describe LockFile do
|
2017-02-20 22:43:09 +01:00
|
|
|
subject { described_class.new("foo") }
|
|
|
|
|
|
|
|
describe "#lock" do
|
|
|
|
it "does not raise an error when already locked" do
|
|
|
|
subject.lock
|
|
|
|
|
|
|
|
expect { subject.lock }.not_to raise_error
|
|
|
|
end
|
|
|
|
|
|
|
|
it "raises an error if a lock already exists" do
|
|
|
|
subject.lock
|
|
|
|
|
|
|
|
expect {
|
|
|
|
described_class.new("foo").lock
|
|
|
|
}.to raise_error(OperationInProgressError)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "#unlock" do
|
|
|
|
it "does not raise an error when already unlocked" do
|
|
|
|
expect { subject.unlock }.not_to raise_error
|
|
|
|
end
|
|
|
|
|
2017-05-22 03:23:50 +02:00
|
|
|
it "unlocks when locked" do
|
2017-02-20 22:43:09 +01:00
|
|
|
subject.lock
|
|
|
|
subject.unlock
|
|
|
|
|
|
|
|
expect { described_class.new("foo").lock }.not_to raise_error
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|