diff -r 000000000000 -r 6474c204b198 security/manager/ssl/tests/unit/test_signed_apps-marketplace.js --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/security/manager/ssl/tests/unit/test_signed_apps-marketplace.js Wed Dec 31 06:09:35 2014 +0100 @@ -0,0 +1,43 @@ +"use strict"; + +const isB2G = ("@mozilla.org/b2g-process-global;1" in Cc); + + +do_get_profile(); // must be called before getting nsIX509CertDB +const certdb = Cc["@mozilla.org/security/x509certdb;1"].getService(Ci.nsIX509CertDB); + +function run_test() { + run_next_test(); +} + +function check_open_result(name, expectedRv) { + return function openSignedAppFileCallback(rv, aZipReader, aSignerCert) { + do_print("openSignedAppFileCallback called for " + name); + do_check_eq(rv, expectedRv); + do_check_eq(aZipReader != null, Components.isSuccessCode(expectedRv)); + do_check_eq(aSignerCert != null, Components.isSuccessCode(expectedRv)); + run_next_test(); + }; +} + +function original_app_path(test_name) { + return do_get_file("test_signed_apps/" + test_name + ".zip", false); +} + +// Test that we no longer trust the test root cert that was originally used +// during development of B2G 1.0. +add_test(function () { + certdb.openSignedAppFileAsync( + Ci.nsIX509CertDB.AppMarketplaceProdPublicRoot, + original_app_path("test-privileged-app-test-1.0"), + check_open_result("test-privileged-app-test-1.0", + getXPCOMStatusFromNSS(SEC_ERROR_UNKNOWN_ISSUER))); +}); + +// Test that we trust the root cert used by by the Firefox Marketplace. +add_test(function () { + certdb.openSignedAppFileAsync( + Ci.nsIX509CertDB.AppMarketplaceProdPublicRoot, + original_app_path("privileged-app-test-1.0"), + check_open_result("privileged-app-test-1.0", Cr.NS_OK)); +});