147 lines
5.7 KiB
JavaScript
147 lines
5.7 KiB
JavaScript
/* Any copyright is dedicated to the Public Domain.
|
|
http://creativecommons.org/publicdomain/zero/1.0/ */
|
|
|
|
function run_test() {
|
|
/**
|
|
* Extracts a MAR and makes sure each file matches the reference files.
|
|
*
|
|
* @param marFileName The name of the MAR file to extract
|
|
* @param files The files that the extracted MAR should contain
|
|
*/
|
|
function extract_and_compare(marFileName, files) {
|
|
// Get the MAR file that we will be extracting
|
|
let mar = do_get_file("data/" + marFileName);
|
|
|
|
// Get the path that we will extract to
|
|
let outDir = tempDir.clone();
|
|
outDir.append("out");
|
|
Assert.ok(!outDir.exists());
|
|
outDir.create(Ci.nsIFile.DIRECTORY_TYPE, 0o777);
|
|
|
|
// Get the ref files and the files that will be extracted.
|
|
let outFiles = [];
|
|
let refFiles = [];
|
|
for (let i = 0; i < files.length; i++) {
|
|
let outFile = outDir.clone();
|
|
outFile.append(files[i]);
|
|
Assert.ok(!outFile.exists());
|
|
|
|
outFiles.push(outFile);
|
|
refFiles.push(do_get_file("data/" + files[i]));
|
|
}
|
|
|
|
// Extract the MAR contents to ./out dir and verify 0 for success.
|
|
Assert.equal(extractMAR(mar, outDir), 0);
|
|
|
|
// Compare to make sure the extracted files are the same.
|
|
for (let i = 0; i < files.length; i++) {
|
|
Assert.ok(outFiles[i].exists());
|
|
let refFileData = getBinaryFileData(refFiles[i]);
|
|
let outFileData = getBinaryFileData(outFiles[i]);
|
|
compareBinaryData(refFileData, outFileData);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Attempts to extract a MAR and expects a failure
|
|
*
|
|
* @param marFileName The name of the MAR file to extract
|
|
*/
|
|
function extract_and_fail(marFileName) {
|
|
// Get the MAR file that we will be extracting
|
|
let mar = do_get_file("data/" + marFileName);
|
|
|
|
// Get the path that we will extract to
|
|
let outDir = tempDir.clone();
|
|
outDir.append("out");
|
|
Assert.ok(!outDir.exists());
|
|
outDir.create(Ci.nsIFile.DIRECTORY_TYPE, 0o777);
|
|
|
|
// Extract the MAR contents to ./out dir and verify -1 (255 from the
|
|
// nsIprocess) for failure
|
|
Assert.equal(extractMAR(mar, outDir), 1);
|
|
}
|
|
|
|
// Define the unit tests to run.
|
|
let tests = {
|
|
// Test extracting a MAR file with a 0 byte file.
|
|
test_zero_sized: function _test_zero_sized() {
|
|
return extract_and_compare("0_sized.mar", ["0_sized_file"]);
|
|
},
|
|
// Test extracting a MAR file with a 1 byte file.
|
|
test_one_byte: function _test_one_byte() {
|
|
return extract_and_compare("1_byte.mar", ["1_byte_file"]);
|
|
},
|
|
// Test extracting a MAR file with binary data.
|
|
test_binary_data: function _test_binary_data() {
|
|
return extract_and_compare("binary_data.mar", ["binary_data_file"]);
|
|
},
|
|
// Test extracting a MAR without a product information block (PIB) which
|
|
// contains binary data.
|
|
test_no_pib: function _test_no_pib() {
|
|
return extract_and_compare("no_pib.mar", ["binary_data_file"]);
|
|
},
|
|
// Test extracting a MAR without a product information block (PIB) that is
|
|
// signed and which contains binary data.
|
|
test_no_pib_signed: function _test_no_pib_signed() {
|
|
return extract_and_compare("signed_no_pib.mar", ["binary_data_file"]);
|
|
},
|
|
// Test extracting a MAR with a product information block (PIB) that is
|
|
// signed and which contains binary data.
|
|
test_pib_signed: function _test_pib_signed() {
|
|
return extract_and_compare("signed_pib.mar", ["binary_data_file"]);
|
|
},
|
|
// Test extracting a MAR file with multiple files inside of it.
|
|
test_multiple_file: function _test_multiple_file() {
|
|
return extract_and_compare("multiple_file.mar", [
|
|
"0_sized_file",
|
|
"1_byte_file",
|
|
"binary_data_file",
|
|
]);
|
|
},
|
|
// Test collision detection where file A + B are the same offset
|
|
test_collision_same_offset: function test_collision_same_offset() {
|
|
return extract_and_fail("manipulated_same_offset.mar");
|
|
},
|
|
// Test collision detection where file A's indexes are a subset of file B's
|
|
test_collision_is_contained: function test_collision_is_contained() {
|
|
return extract_and_fail("manipulated_is_container.mar");
|
|
},
|
|
// Test collision detection where file B's indexes are a subset of file A's
|
|
test_collision_contained_by: function test_collision_contained_by() {
|
|
return extract_and_fail("manipulated_is_contained.mar");
|
|
},
|
|
// Test collision detection where file A ends in file B's indexes
|
|
test_collision_a_onto_b: function test_collision_a_onto_b() {
|
|
return extract_and_fail("manipulated_frontend_collision.mar");
|
|
},
|
|
// Test collision detection where file B ends in file A's indexes
|
|
test_collsion_b_onto_a: function test_collsion_b_onto_a() {
|
|
return extract_and_fail("manipulated_backend_collision.mar");
|
|
},
|
|
// Test collision detection where file C shares indexes with both file A & B
|
|
test_collision_multiple: function test_collision_multiple() {
|
|
return extract_and_fail("manipulated_multiple_collision.mar");
|
|
},
|
|
// Test collision detection where A is the last file in the list
|
|
test_collision_last: function test_collision_multiple_last() {
|
|
return extract_and_fail("manipulated_multiple_collision_last.mar");
|
|
},
|
|
// Test collision detection where A is the first file in the list
|
|
test_collision_first: function test_collision_multiple_first() {
|
|
return extract_and_fail("manipulated_multiple_collision_first.mar");
|
|
},
|
|
// Between each test make sure the out directory and its subfiles do
|
|
// not exist.
|
|
cleanup_per_test: function _cleanup_per_test() {
|
|
let outDir = tempDir.clone();
|
|
outDir.append("out");
|
|
if (outDir.exists()) {
|
|
outDir.remove(true);
|
|
}
|
|
},
|
|
};
|
|
|
|
// Run all the tests
|
|
Assert.equal(run_tests(tests), Object.keys(tests).length - 1);
|
|
}
|