browser/experiments/test/xpcshell/test_cache.js

Wed, 31 Dec 2014 06:09:35 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Wed, 31 Dec 2014 06:09:35 +0100
changeset 0
6474c204b198
permissions
-rw-r--r--

Cloned upstream origin tor-browser at tor-browser-31.3.0esr-4.5-1-build1
revision ID fc1c9ff7c1b2defdbc039f12214767608f46423f for hacking purpose.

     1 /* Any copyright is dedicated to the Public Domain.
     2  * http://creativecommons.org/publicdomain/zero/1.0/ */
     4 "use strict";
     6 Cu.import("resource://testing-common/httpd.js");
     7 XPCOMUtils.defineLazyModuleGetter(this, "Experiments",
     8   "resource:///modules/experiments/Experiments.jsm");
    10 const FILE_MANIFEST            = "experiments.manifest";
    11 const MANIFEST_HANDLER         = "manifests/handler";
    13 const SEC_IN_ONE_DAY  = 24 * 60 * 60;
    14 const MS_IN_ONE_DAY   = SEC_IN_ONE_DAY * 1000;
    16 let gProfileDir          = null;
    17 let gHttpServer          = null;
    18 let gHttpRoot            = null;
    19 let gDataRoot            = null;
    20 let gReporter            = null;
    21 let gPolicy              = null;
    22 let gManifestObject      = null;
    23 let gManifestHandlerURI  = null;
    24 let gTimerScheduleOffset = -1;
    26 function run_test() {
    27   run_next_test();
    28 }
    30 add_task(function* test_setup() {
    31   loadAddonManager();
    32   gProfileDir = do_get_profile();
    33   yield removeCacheFile();
    35   gHttpServer = new HttpServer();
    36   gHttpServer.start(-1);
    37   let port = gHttpServer.identity.primaryPort;
    38   gHttpRoot = "http://localhost:" + port + "/";
    39   gDataRoot = gHttpRoot + "data/";
    40   gManifestHandlerURI = gHttpRoot + MANIFEST_HANDLER;
    41   gHttpServer.registerDirectory("/data/", do_get_cwd());
    42   gHttpServer.registerPathHandler("/" + MANIFEST_HANDLER, (request, response) => {
    43     response.setStatusLine(null, 200, "OK");
    44     response.write(JSON.stringify(gManifestObject));
    45     response.processAsync();
    46     response.finish();
    47   });
    48   do_register_cleanup(() => gHttpServer.stop(() => {}));
    50   disableCertificateChecks();
    52   Services.prefs.setBoolPref(PREF_EXPERIMENTS_ENABLED, true);
    53   Services.prefs.setIntPref(PREF_LOGGING_LEVEL, 0);
    54   Services.prefs.setBoolPref(PREF_LOGGING_DUMP, true);
    55   Services.prefs.setCharPref(PREF_MANIFEST_URI, gManifestHandlerURI);
    56   Services.prefs.setIntPref(PREF_FETCHINTERVAL, 0);
    58   gReporter = yield getReporter("json_payload_simple");
    59   yield gReporter.collectMeasurements();
    60   let payload = yield gReporter.getJSONPayload(true);
    61   do_register_cleanup(() => gReporter._shutdown());
    63   gPolicy = new Experiments.Policy();
    64   patchPolicy(gPolicy, {
    65     updatechannel: () => "nightly",
    66     healthReportPayload: () => {},
    67     oneshotTimer: (callback, timeout, thisObj, name) => gTimerScheduleOffset = timeout,
    68   });
    69 });
    71 function checkExperimentListsEqual(list, list2) {
    72   Assert.equal(list.length, list2.length, "Lists should have the same length.")
    74   for (let i=0; i<list.length; ++i) {
    75     for (let k of Object.keys(list[i])) {
    76       Assert.equal(list[i][k], list2[i][k],
    77                    "Field '" + k + "' should match for list entry " + i + ".");
    78     }
    79   }
    80 }
    82 function checkExperimentSerializations(experimentEntryIterator) {
    83   for (let experiment of experimentEntryIterator) {
    84     let experiment2 = new Experiments.ExperimentEntry(gPolicy);
    85     let jsonStr = JSON.stringify(experiment.toJSON());
    86     Assert.ok(experiment2.initFromCacheData(JSON.parse(jsonStr)),
    87               "Should have initialized successfully from JSON serialization.");
    88     Assert.equal(JSON.stringify(experiment), JSON.stringify(experiment2),
    89                  "Object stringifications should match.");
    90   }
    91 }
    93 // Set up an experiments instance and check if it is properly restored from cache.
    95 add_task(function* test_cache() {
    96   // The manifest data we test with.
    98   gManifestObject = {
    99     "version": 1,
   100     experiments: [
   101       {
   102         id:               EXPERIMENT1_ID,
   103         xpiURL:           gDataRoot + EXPERIMENT1_XPI_NAME,
   104         xpiHash:          EXPERIMENT1_XPI_SHA1,
   105         maxActiveSeconds: 10 * SEC_IN_ONE_DAY,
   106         appName:          ["XPCShell"],
   107         channel:          ["nightly"],
   108       },
   109       {
   110         id:               EXPERIMENT2_ID,
   111         xpiURL:           gDataRoot + EXPERIMENT2_XPI_NAME,
   112         xpiHash:          EXPERIMENT2_XPI_SHA1,
   113         maxActiveSeconds: 10 * SEC_IN_ONE_DAY,
   114         appName:          ["XPCShell"],
   115         channel:          ["nightly"],
   116       },
   117       {
   118         id:               EXPERIMENT3_ID,
   119         xpiURL:           "https://inval.id/foo.xpi",
   120         xpiHash:          "sha1:0000000000000000000000000000000000000000",
   121         maxActiveSeconds: 10 * SEC_IN_ONE_DAY,
   122         appName:          ["XPCShell"],
   123         channel:          ["nightly"],
   124       },
   125     ],
   126   };
   128   // Setup dates for the experiments.
   130   let baseDate   = new Date(2014, 5, 1, 12);
   131   let startDates = [];
   132   let endDates   = [];
   134   for (let i=0; i<gManifestObject.experiments.length; ++i) {
   135     let experiment = gManifestObject.experiments[i];
   136     startDates.push(futureDate(baseDate, (50 + (150 * i)) * MS_IN_ONE_DAY));
   137     endDates  .push(futureDate(startDates[i], 50 * MS_IN_ONE_DAY));
   138     experiment.startTime = dateToSeconds(startDates[i]);
   139     experiment.endTime   = dateToSeconds(endDates[i]);
   140   }
   142   // Data to compare the result of Experiments.getExperiments() against.
   144   let experimentListData = [
   145     {
   146       id: EXPERIMENT2_ID,
   147       name: "Test experiment 2",
   148       description: "And yet another experiment that experiments experimentally.",
   149     },
   150     {
   151       id: EXPERIMENT1_ID,
   152       name: EXPERIMENT1_NAME,
   153       description: "Yet another experiment that experiments experimentally.",
   154     },
   155   ];
   157   // Trigger update & re-init, clock set to before any activation.
   159   let now = baseDate;
   160   defineNow(gPolicy, now);
   162   let experiments = new Experiments.Experiments(gPolicy);
   163   yield experiments.updateManifest();
   164   let list = yield experiments.getExperiments();
   165   Assert.equal(list.length, 0, "Experiment list should be empty.");
   166   checkExperimentSerializations(experiments._experiments.values());
   168   yield experiments.uninit();
   169   experiments = new Experiments.Experiments(gPolicy);
   171   yield experiments._run();
   172   list = yield experiments.getExperiments();
   173   Assert.equal(list.length, 0, "Experiment list should be empty.");
   174   checkExperimentSerializations(experiments._experiments.values());
   176   // Re-init, clock set for experiment 1 to start.
   178   now = futureDate(startDates[0], 5 * MS_IN_ONE_DAY);
   179   defineNow(gPolicy, now);
   181   yield experiments.uninit();
   182   experiments = new Experiments.Experiments(gPolicy);
   183   yield experiments._run();
   185   list = yield experiments.getExperiments();
   186   Assert.equal(list.length, 1, "Experiment list should have 1 entry now.");
   188   experimentListData[1].active = true;
   189   experimentListData[1].endDate = now.getTime() + 10 * MS_IN_ONE_DAY;
   190   checkExperimentListsEqual(experimentListData.slice(1), list);
   191   checkExperimentSerializations(experiments._experiments.values());
   193   let branch = yield experiments.getExperimentBranch(EXPERIMENT1_ID);
   194   Assert.strictEqual(branch, null);
   196   yield experiments.setExperimentBranch(EXPERIMENT1_ID, "testbranch");
   197   branch = yield experiments.getExperimentBranch(EXPERIMENT1_ID);
   198   Assert.strictEqual(branch, "testbranch");
   200   // Re-init, clock set for experiment 1 to stop.
   202   now = futureDate(now, 20 * MS_IN_ONE_DAY);
   203   defineNow(gPolicy, now);
   205   yield experiments.uninit();
   206   experiments = new Experiments.Experiments(gPolicy);
   207   yield experiments._run();
   209   list = yield experiments.getExperiments();
   210   Assert.equal(list.length, 1, "Experiment list should have 1 entry.");
   212   experimentListData[1].active = false;
   213   experimentListData[1].endDate = now.getTime();
   214   checkExperimentListsEqual(experimentListData.slice(1), list);
   215   checkExperimentSerializations(experiments._experiments.values());
   217   branch = yield experiments.getExperimentBranch(EXPERIMENT1_ID);
   218   Assert.strictEqual(branch, "testbranch");
   220   // Re-init, clock set for experiment 2 to start.
   222   now = futureDate(startDates[1], 20 * MS_IN_ONE_DAY);
   223   defineNow(gPolicy, now);
   225   yield experiments.uninit();
   226   experiments = new Experiments.Experiments(gPolicy);
   227   yield experiments._run();
   229   list = yield experiments.getExperiments();
   230   Assert.equal(list.length, 2, "Experiment list should have 2 entries.");
   232   experimentListData[0].active = true;
   233   experimentListData[0].endDate = now.getTime() + 10 * MS_IN_ONE_DAY;
   234   checkExperimentListsEqual(experimentListData, list);
   235   checkExperimentSerializations(experiments._experiments.values());
   237   // Re-init, clock set for experiment 2 to stop.
   239   now = futureDate(now, 20 * MS_IN_ONE_DAY);
   240   defineNow(gPolicy, now);
   242   yield experiments.uninit();
   243   experiments = new Experiments.Experiments(gPolicy);
   244   yield experiments._run();
   246   list = yield experiments.getExperiments();
   247   Assert.equal(list.length, 2, "Experiment list should have 2 entries.");
   249   experimentListData[0].active = false;
   250   experimentListData[0].endDate = now.getTime();
   251   checkExperimentListsEqual(experimentListData, list);
   252   checkExperimentSerializations(experiments._experiments.values());
   254   // Cleanup.
   256   yield experiments._toggleExperimentsEnabled(false);
   257   yield experiments.uninit();
   258   yield removeCacheFile();
   259 });

mercurial