toolkit/webapps/tests/test_packaged.xul
author Gregory Szorc <gps@mozilla.com>
Tue, 24 Feb 2015 15:16:54 -0800
changeset 245746 6d143a910f5ecf67d9dec302087aa20777ec6772
parent 210595 400b8c7a7f0157290be1064f7ae1f3df459f936b
child 289155 852042d67f3892293b52a0b251173c9dd5cf818f
permissions -rw-r--r--
Bug 1132771 - Add Files to moz.build with ability to define Bugzilla component The Files sub-context allows us to attach metadata to files based on pattern matching rules. Patterns are matched against files in a last-write-wins fashion. The sub-context defines the BUG_COMPONENT variable, which is a 2-tuple (actually a named tuple) defining the Bugzilla product and component for files. There are no consumers yet. But an eventual use case will be to suggest a bug component for a patch/commit. Another will be to automatically suggest a bug component for a failing test.

<?xml version="1.0"?>
<?xml-stylesheet type="text/css" href="chrome://global/skin"?>
<?xml-stylesheet type="text/css" href="/tests/SimpleTest/test.css"?>
<!--
https://bugzilla.mozilla.org/show_bug.cgi?id=898647
-->
<window title="Mozilla Bug 898647"
        xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">
  <script type="application/javascript"
          src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js"></script>
  <script type="application/javascript" src="head.js"/>

  <!-- test results are displayed in the html:body -->
  <body xmlns="http://www.w3.org/1999/xhtml">
  <a href="https://bugzilla.mozilla.org/show_bug.cgi?id=898647"
     target="_blank">Mozilla Bug 898647</a>
  </body>

<script type="application/javascript">
<![CDATA[

/** Test for Bug 898647 **/

"use strict";

SimpleTest.waitForExplicitFinish();

Cu.import("resource://gre/modules/Services.jsm");
Cu.import("resource://gre/modules/NativeApp.jsm");
Cu.import("resource://gre/modules/WebappOSUtils.jsm");

let zipPath = OS.Path.join(OS.Constants.Path.profileDir, "sample.zip");

let manifest = {
  name: "Sample packaged app",
  version: "0.1a",
  size: 777,
  package_path: "/sample.zip",
};

let app = {
  name: "Sample packaged app",
  manifestURL: "http://example.com/sample.manifest",
  manifest: manifest,
  updateManifest: manifest,
  origin: "http://example.com/",
  categories: [],
  installOrigin: "http://example.com/",
  receipts: [],
  installTime: Date.now(),
};

let testAppInfo = new TestAppInfo(app, true);

let runTest = Task.async(function*() {
  // Get to a clean state before the test
  yield testAppInfo.cleanup();

  SimpleTest.registerCleanupFunction(() => testAppInfo.cleanup());

  setDryRunPref();

  let zipFile = yield OS.File.open(zipPath, { create: true });
  yield zipFile.close();

  let nativeApp = new NativeApp(app, manifest, app.categories);
  ok(nativeApp, "NativeApp object created");

  info("Test update for an application that isn't installed");
  try {
    yield nativeApp.prepareUpdate(app, manifest, zipPath);
    ok(false, "Didn't thrown");
  } catch (ex) {
    is(ex, "The application isn't installed", "Exception thrown");
  }

  testAppInfo.profileDir = nativeApp.createProfile();
  ok(testAppInfo.profileDir && testAppInfo.profileDir.exists(), "Profile directory created");
  ok((yield OS.File.exists(testAppInfo.profilesIni)), "profiles.ini file created");

  // On Mac build servers, we don't have enough privileges to write to /Applications,
  // so we install apps in a user-owned directory.
  if (MAC) {
    yield setMacRootInstallDir(OS.Path.join(OS.Constants.Path.homeDir, "Applications"));
  }

  // Install application
  info("Test installation");
  yield nativeApp.install(app, manifest, zipPath);
  while (!WebappOSUtils.isLaunchable(app)) {
    yield wait(1000);
  }
  ok(true, "App launchable");
  ok((yield checkFiles(testAppInfo.installedFiles)), "Files correctly written");
  is(WebappOSUtils.getInstallPath(app), testAppInfo.installPath, "getInstallPath == installPath");

  let stat = yield OS.File.stat(testAppInfo.installPath);
  let installTime = stat.lastModificationDate;

  // Wait one second, otherwise the last modification date is the same.
  yield wait(1000);

  // Reinstall application
  info("Test reinstallation");

  zipFile = yield OS.File.open(zipPath, { create: true });
  yield zipFile.close();

  yield nativeApp.install(app, manifest, zipPath);
  while (!WebappOSUtils.isLaunchable(app)) {
    yield wait(1000);
  }
  ok(true, "App launchable");
  ok((yield checkFiles(testAppInfo.installedFiles)), "Installation not corrupted");
  ok((yield checkFiles(testAppInfo.tempUpdatedFiles)), "Files correctly written in the update subdirectory");

  yield nativeApp.applyUpdate(app);
  while (!WebappOSUtils.isLaunchable(app)) {
    yield wait(1000);
  }
  ok(true, "App launchable");

  if (MAC) {
    stat = yield OS.File.stat(testAppInfo.webappINI);
    is(stat.unixMode, 0o644, "Configuration file permissions correct");
  } else if (LINUX) {
    stat = yield OS.File.stat(testAppInfo.desktopINI);
    is(stat.unixMode, 0o744, "Configuration file permissions correct");
  }

  ok((yield checkFiles(testAppInfo.installedFiles)), "Installation not corrupted");
  ok(!(yield OS.File.exists(OS.Path.join(testAppInfo.installPath, "update"))), "Update directory removed");
  ok((yield checkDateHigherThan(testAppInfo.updatedFiles, installTime)), "Modification date higher");

  stat = yield OS.File.stat(testAppInfo.installPath);
  installTime = stat.lastModificationDate;

  // Wait one second, otherwise the last modification date is the same.
  yield wait(1000);

  // Update application
  info("Test update");

  zipFile = yield OS.File.open(zipPath, { create: true });
  yield zipFile.close();

  yield nativeApp.prepareUpdate(app, manifest, zipPath);
  while (!WebappOSUtils.isLaunchable(app)) {
    yield wait(1000);
  }
  ok(true, "App launchable");
  ok((yield checkFiles(testAppInfo.installedFiles)), "Installation not corrupted");
  ok((yield checkFiles(testAppInfo.tempUpdatedFiles)), "Files correctly written in the update subdirectory");

  yield nativeApp.applyUpdate(app);
  while (!WebappOSUtils.isLaunchable(app)) {
    yield wait(1000);
  }
  ok(true, "App launchable");
  ok((yield checkFiles(testAppInfo.installedFiles)), "Installation not corrupted");
  ok(!(yield OS.File.exists(OS.Path.join(testAppInfo.installPath, "update"))), "Update directory removed");
  ok((yield checkDateHigherThan(testAppInfo.updatedFiles, installTime)), "Modification date higher");

  SimpleTest.finish();
});

runTest().catch((e) => {
  ok(false, "Error during test: " + e);
  SimpleTest.finish();
});

]]>
</script>
</window>