Region

Firefox monitors the users region in order to show relevant local search engines and content. The region is tracked in 2 properties:

  • Region.current - The most recent location we detected for the user.

  • Region.home - Where we consider the users home location.

These are tracked separately as to avoid updating the users experience repeatedly as they travel for example. In general callers should use Region.home.

Region Updating

Firefox uses a location service that is provided by Mozilla. Firefox will attempt to check for region on first run of a new profile and every 7 days thereafter. If an update check fails, then the update will be retried after an hour for a maximum of three times.

If the user is detected in a current region that is not their home region for a continuous period (current 2 weeks) then their home region will be updated.

Testing

To set the users region for testing you can use:

let {Region} = ChromeUtils.importESModule("resource://gre/modules/Region.sys.mjs");
Region._setHomeRegion("US", false)

Setting the second parameter (notify) to true will send an notification that the region has changed and trigger a reload of search engines and other content.

Updating test_Region_geocoding.js data

Note: The geocoding feature is not turned on by default.

The test data used in this test is generated by running the MLS geocoding service locally:

Follow the Ichnaea location development guide @ https://ichnaea.readthedocs.io/en/latest/local_dev.html.

Make a list of test locations in a CSV format, for example:

23.7818724,38.0531587
23.7728138,38.0572369
1.6780180,48.5973431
1.7034801,48.5979913
1.6978640,48.5919751

You can use the MLS raw data files to get a large sample @ https://location.services.mozilla.com/downloads

Save a script to run the geocoding in ichnaea/ichnaea

import geocode
geocoder = geocode.Geocoder()

f = open("mls.csv", "r")
r = open("mls-lookup-results.csv", "a")

for x in f:
  [lat, long] = x.strip().split(",")
  region = geocoder.region(lat, long)
  r.write("%s\n" % region)

Run the script

$ make shell
$ cd ichnaea
$ python run.py

If you want to commit the new test data ~500 seems to be a reasonable number of data points to test before running into issues with the test length.