Unlink implementation and tests.
This commit is contained in:
parent
717bbc25c1
commit
e690ed5292
|
@ -6388,7 +6388,6 @@ define('src/file-system',['require','lodash','when','src/path','src/path','src/p
|
||||||
var oldDirectoryData;
|
var oldDirectoryData;
|
||||||
var newDirectoryNode;
|
var newDirectoryNode;
|
||||||
var newDirectoryData;
|
var newDirectoryData;
|
||||||
var directoryEntry;
|
|
||||||
var fileNode;
|
var fileNode;
|
||||||
|
|
||||||
find_node(objectStore, oldParentPath, read_old_directory_data);
|
find_node(objectStore, oldParentPath, read_old_directory_data);
|
||||||
|
@ -6442,16 +6441,51 @@ define('src/file-system',['require','lodash','when','src/path','src/path','src/p
|
||||||
if(error) {
|
if(error) {
|
||||||
callback(error);
|
callback(error);
|
||||||
} else {
|
} else {
|
||||||
read_object(objectStore, newDirectoryData[newname].id, read_file_node);
|
read_object(objectStore, newDirectoryData[newname].id, update_file_node);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function read_file_node(error, result) {
|
function update_file_node(error, result) {
|
||||||
if(error) {
|
if(error) {
|
||||||
callback(error);
|
callback(error);
|
||||||
} else {
|
} else {
|
||||||
directoryEntry = result;
|
fileNode = result;
|
||||||
read_object(objectStore, directoryEntry.id, update_file_node);
|
fileNode.nlinks += 1
|
||||||
|
write_object(objectStore, fileNode, fileNode.id, callback);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
function unlink_node(objectStore, path, callback) {
|
||||||
|
path = normalize(path);
|
||||||
|
name = basename(path);
|
||||||
|
parentPath = dirname(path);
|
||||||
|
|
||||||
|
var directoryNode;
|
||||||
|
var directoryData;
|
||||||
|
var fileNode;
|
||||||
|
|
||||||
|
find_node(objectStore, parentPath, read_directory_data);
|
||||||
|
|
||||||
|
function read_directory_data(error, result) {
|
||||||
|
if(error) {
|
||||||
|
callback(error);
|
||||||
|
} else {
|
||||||
|
directoryNode = result;
|
||||||
|
read_object(objectStore, directoryNode.data, check_if_file_exists);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
function check_if_file_exists(error, result) {
|
||||||
|
if(error) {
|
||||||
|
callback(error);
|
||||||
|
} else {
|
||||||
|
directoryData = result;
|
||||||
|
if(!_(directoryData).has(name)) {
|
||||||
|
callback(new ENoEntry('a component of the path does not name an existing file'));
|
||||||
|
} else {
|
||||||
|
read_object(objectStore, directoryData[name].id, update_file_node);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -6460,10 +6494,31 @@ define('src/file-system',['require','lodash','when','src/path','src/path','src/p
|
||||||
callback(error);
|
callback(error);
|
||||||
} else {
|
} else {
|
||||||
fileNode = result;
|
fileNode = result;
|
||||||
fileNode.nlinks += 1
|
fileNode.nlinks -= 1;
|
||||||
write_object(objectStore, fileNode, directoryEntry.id, callback);
|
if(fileNode.nlinks < 1) {
|
||||||
|
delete_object(objectStore, fileNode.id, delete_file_data);
|
||||||
|
} else {
|
||||||
|
write_object(objectStore, fileNode, fileNode.id, update_directory_data);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
function delete_file_data(error) {
|
||||||
|
if(error) {
|
||||||
|
callback(error);
|
||||||
|
} else {
|
||||||
|
delete_object(objectStore, fileNode.data, update_directory_data);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
function update_directory_data(error) {
|
||||||
|
if(error) {
|
||||||
|
callback(error);
|
||||||
|
} else {
|
||||||
|
delete directoryData[name];
|
||||||
|
write_object(objectStore, directoryData, directoryNode.data, callback);
|
||||||
|
}
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -37,9 +37,9 @@ fs.open('/myfile', 'w+', function(error, fd) {
|
||||||
fs.link('/myfile', '/myotherfile', function(error) {
|
fs.link('/myfile', '/myotherfile', function(error) {
|
||||||
if(error) throw error;
|
if(error) throw error;
|
||||||
console.log('linked');
|
console.log('linked');
|
||||||
fs.stat('/myfile', function(error, stats) {
|
fs.unlink('/myfile', function(error) {
|
||||||
if(error) throw error;
|
if(error) throw error;
|
||||||
console.log(stats);
|
console.log('unlinked');
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -588,7 +588,6 @@ define(function(require) {
|
||||||
var oldDirectoryData;
|
var oldDirectoryData;
|
||||||
var newDirectoryNode;
|
var newDirectoryNode;
|
||||||
var newDirectoryData;
|
var newDirectoryData;
|
||||||
var directoryEntry;
|
|
||||||
var fileNode;
|
var fileNode;
|
||||||
|
|
||||||
find_node(objectStore, oldParentPath, read_old_directory_data);
|
find_node(objectStore, oldParentPath, read_old_directory_data);
|
||||||
|
@ -642,16 +641,51 @@ define(function(require) {
|
||||||
if(error) {
|
if(error) {
|
||||||
callback(error);
|
callback(error);
|
||||||
} else {
|
} else {
|
||||||
read_object(objectStore, newDirectoryData[newname].id, read_file_node);
|
read_object(objectStore, newDirectoryData[newname].id, update_file_node);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function read_file_node(error, result) {
|
function update_file_node(error, result) {
|
||||||
if(error) {
|
if(error) {
|
||||||
callback(error);
|
callback(error);
|
||||||
} else {
|
} else {
|
||||||
directoryEntry = result;
|
fileNode = result;
|
||||||
read_object(objectStore, directoryEntry.id, update_file_node);
|
fileNode.nlinks += 1
|
||||||
|
write_object(objectStore, fileNode, fileNode.id, callback);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
function unlink_node(objectStore, path, callback) {
|
||||||
|
path = normalize(path);
|
||||||
|
name = basename(path);
|
||||||
|
parentPath = dirname(path);
|
||||||
|
|
||||||
|
var directoryNode;
|
||||||
|
var directoryData;
|
||||||
|
var fileNode;
|
||||||
|
|
||||||
|
find_node(objectStore, parentPath, read_directory_data);
|
||||||
|
|
||||||
|
function read_directory_data(error, result) {
|
||||||
|
if(error) {
|
||||||
|
callback(error);
|
||||||
|
} else {
|
||||||
|
directoryNode = result;
|
||||||
|
read_object(objectStore, directoryNode.data, check_if_file_exists);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
function check_if_file_exists(error, result) {
|
||||||
|
if(error) {
|
||||||
|
callback(error);
|
||||||
|
} else {
|
||||||
|
directoryData = result;
|
||||||
|
if(!_(directoryData).has(name)) {
|
||||||
|
callback(new ENoEntry('a component of the path does not name an existing file'));
|
||||||
|
} else {
|
||||||
|
read_object(objectStore, directoryData[name].id, update_file_node);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -660,10 +694,31 @@ define(function(require) {
|
||||||
callback(error);
|
callback(error);
|
||||||
} else {
|
} else {
|
||||||
fileNode = result;
|
fileNode = result;
|
||||||
fileNode.nlinks += 1
|
fileNode.nlinks -= 1;
|
||||||
write_object(objectStore, fileNode, directoryEntry.id, callback);
|
if(fileNode.nlinks < 1) {
|
||||||
|
delete_object(objectStore, fileNode.id, delete_file_data);
|
||||||
|
} else {
|
||||||
|
write_object(objectStore, fileNode, fileNode.id, update_directory_data);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
function delete_file_data(error) {
|
||||||
|
if(error) {
|
||||||
|
callback(error);
|
||||||
|
} else {
|
||||||
|
delete_object(objectStore, fileNode.data, update_directory_data);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
function update_directory_data(error) {
|
||||||
|
if(error) {
|
||||||
|
callback(error);
|
||||||
|
} else {
|
||||||
|
delete directoryData[name];
|
||||||
|
write_object(objectStore, directoryData, directoryNode.data, callback);
|
||||||
|
}
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -810,4 +810,50 @@ describe('fs.unlink', function() {
|
||||||
it('should be a function', function() {
|
it('should be a function', function() {
|
||||||
expect(typeof this.fs.unlink).toEqual('function');
|
expect(typeof this.fs.unlink).toEqual('function');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('should remove a link to an existing file', function() {
|
||||||
|
var complete1 = false;
|
||||||
|
var complete2 = false;
|
||||||
|
var _error, _stats;
|
||||||
|
var that = this;
|
||||||
|
|
||||||
|
that.fs.open('/myfile', 'w+', function(error, result) {
|
||||||
|
if(error) throw error;
|
||||||
|
|
||||||
|
var fd = result;
|
||||||
|
that.fs.close(fd, function(error) {
|
||||||
|
if(error) throw error;
|
||||||
|
|
||||||
|
that.fs.link('/myfile', '/myotherfile', function(error) {
|
||||||
|
if(error) throw error;
|
||||||
|
|
||||||
|
that.fs.unlink('/myfile', function(error) {
|
||||||
|
if(error) throw error;
|
||||||
|
|
||||||
|
that.fs.stat('/myfile', function(error, result) {
|
||||||
|
_error = error;
|
||||||
|
complete1 = true;
|
||||||
|
});
|
||||||
|
|
||||||
|
that.fs.stat('/myotherfile', function(error, result) {
|
||||||
|
if(error) throw error;
|
||||||
|
|
||||||
|
_stats = result;
|
||||||
|
complete2 = true;
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
waitsFor(function() {
|
||||||
|
return complete1 && complete2;
|
||||||
|
}, 'test to complete', DEFAULT_TIMEOUT);
|
||||||
|
|
||||||
|
runs(function() {
|
||||||
|
expect(_error).toBeDefined();
|
||||||
|
expect(_error).toBeDefined();
|
||||||
|
expect(_stats.nlinks).toEqual(1);
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
Loading…
Reference in New Issue