Update timestamp of parent directories on DELETE requests (fixes #10)

This commit is contained in:
galfert 2012-10-07 19:02:25 +02:00
parent 8b2bd53d49
commit c542350185
2 changed files with 27 additions and 2 deletions

View File

@ -83,7 +83,8 @@ module RemoteStorage
def delete_data(user, directory, key)
riak_response = data_bucket.delete("#{user}:#{directory}:#{key}")
delete_empty_directory_objects(user, directory)
timestamp = Time.now.to_i
delete_or_update_directory_objects(user, directory, timestamp)
halt riak_response[:code]
rescue ::Riak::HTTPFailedRequest
@ -200,7 +201,7 @@ module RemoteStorage
directory_object.store
end
def delete_empty_directory_objects(user, directory)
def delete_or_update_directory_objects(user, directory, timestamp)
parent_directories = directory.split("/")
while parent_directories.any?
@ -211,6 +212,8 @@ module RemoteStorage
if existing_files.empty? && existing_subdirectories.empty?
directory_bucket.delete "#{user}:#{parent_directory}"
else
update_directory_object(user, parent_directory, timestamp)
end
parent_directories.pop
@ -218,6 +221,8 @@ module RemoteStorage
if directory_entries(user, "").empty? && sub_directories(user, "").empty?
directory_bucket.delete "#{user}:"
else
update_directory_object(user, "", timestamp)
end
end

View File

@ -276,6 +276,26 @@ describe "Directories" do
directory_bucket.get("jimmy:tasks").wont_be_nil
directory_bucket.get("jimmy:").wont_be_nil
end
describe "timestamps" do
before do
@old_timestamp = 2.seconds.ago.to_i
["tasks/home", "tasks", ""].each do |dir|
directory = directory_bucket.get("jimmy:#{dir}")
directory.data = @old_timestamp.to_s
directory.store
end
end
it "updates the timestamp for the parent directories" do
delete "/jimmy/tasks/home/trash"
directory_bucket.get("jimmy:tasks/home").data.to_i.must_be :>, @old_timestamp
directory_bucket.get("jimmy:tasks").data.to_i.must_be :>, @old_timestamp
directory_bucket.get("jimmy:").data.to_i.must_be :>, @old_timestamp
end
end
end
end