Skip to content
This repository has been archived by the owner on Jan 17, 2023. It is now read-only.

Latest commit

 

History

History
647 lines (403 loc) · 18.3 KB

reference.md

File metadata and controls

647 lines (403 loc) · 18.3 KB

👈 Back to README

Experiment content is managed with a series of YAML files in the content-src directory. At build time, the YAML is converted to JSON, which the website loads at runtime.

New experiments

To make a new experiment:

  1. Copy the template.yaml file below into ./content-src/experiments
  2. Rename your file to match the eventual slug of your experiment eg tab-center.yaml
  3. You'll need a place to put image assets for your experiment. Make a new directory './frontend/src/images/experiments' to match the name of your YAML file
  4. In the directory you've created, mkdir details social avatars tour icon. You'll put various image assets into these folders.
  5. As you add images, please compress them. You can do this with an app or command line tool.
  6. Populate the content as appropriate, using the reference to help.

Localization

An experiment's YAML file is considered to contain the canonical localization for English. This content must be extracted & compiled into an FTL file. That file is monitored by Pontoon, and strings are translated by volunteer localizers.

To manually extract strings for Pontoon, run the command npm run l10n:extract. If you have a dev server running via npm start, this should happen automatically when you change YAML files. In either case, the FTL file should not be edited manually.

Note: any experiments set to dev: true will be skipped during extraction so as to not add strings to the translation files as they're likely still actively changing and should not be reviewed by localizers.

Be sure to include changes to locales/en-US/experiments.ftl in your pull requests with changed content. The npm run l10n:check command will be run in CircleCI to help ensure any string changes have been picked up - uncommitted string changes will cause the test run to fail.

If a new field is added to the experiment YAML - and it needs to be localized - that field must be also added to the list of LOCALIZABLE_FIELDS in frontend/tasks/util.js.

If the content of a string changes sufficiently that translations of it should be invalidated:

  1. Make sure that this change needs to be done. We rely on volunteer localizers,
  2. If at all possible, wait to make the change until the beginning of a sprint to give localizers time to translate the new string before the next deployment.
  3. Add a new field to the YAML titled <fieldname>_l10nsuffix, set to a short string contextualizing the change.

For example: if we decide to rename the "Activity Streams" experiment to "Activity Stream", the following YAML:

title: 'Activity Streams'

Would be changed to this:

title: 'Activity Stream'
title_l10nsuffix: 'singular'

This change will turn the l10n-id from activitystreamTitle to activitystreamTitleSingular, treating it as an entirely new string and invalidating all existing translations.

This also works for nested properties:

contributors:
  -
      display_name: 'Jared Hirsch'
      title: 'Staff Engineer'
      title_l10nsuffix: 'staff'

Reference

The following YAML fields are available to content authors:

id

A unique numeric ID for the experiment. This is being incremented sequentially, so check previous experiments to determine what this value should be. Required.

id: 0

slug

A slugified version of the title, used to generate URLs. Required.

slug: 'experiment-name'

title

The name of the experiment. Localized, required.

title: 'Experiment Name'

subtitle

A subtitle for the experiment, generally used for attribution of an experiment to a partner. Localized, optional.

subtitle: 'Powered by a yellow submarine'

Example use of subtitle

order

The order in which the experiment will appear. Lower numbers appear first. Required.

order: 0

is_featured

Determines whether the experiment will be featured on the home page.

Featured experiments must include a video_url as well.

Optional.

is_featured: false

description

A short description of the experiment, used for search engines, social media shares, and in the experiment card. Localized, required, HTML not allowed.

description: >
  Lorem ipsum dolor sit amet, consectetur adipisicing elit. Ipsum cum ad deserunt
  iusto possimus. Fugiat odit corrupti cumque.

Example Twitter share with description

platform

A list of platforms on which this experiment is available - one or more of addon, web, ios, android.

When ios is included an ios_url is also required. When android is included an android_url is also required. When web is included a web_url is also required.

platform: ['addon', 'ios']

web_url

If the experiment is on web platform, this is the URL to which the details page links.

web_url: 'https://example.com/some-web-experiment'

ios_url

URL to the iOS app store page for the app. Required when platform includes ios.

android_url

URL to the Google Play store page for the app. Required when platform includes android.

basket_msg_id

The message id send to basket for sending mobile app store link to device

warning

A warning message to let users know when an experiment is going to have conflicts with a specific version.

warning: >
  Firefox is changing fast. Tab Center may have bugs in Firefox 55 and
  will be disabled completely in Firefox 56+.

Example use of warning

introduction

A short introduction of the experiment, displayed on top of the experiment detail page. Required, localized, HTML required.

introduction: >
  <p>Lorem ipsum dolor sit amet.</p>
  <p>Consectetur adipisicing elit.</p>

Example use of introduction

news_updates

An object describing a news update for an experiment. May link to a blog post.

news_updates:
  -
    slug: min-vid-update-1
    title: My Update title
    link: 'https://blog.mozilla.org/testpilot/example'
    created: '2017-06-01T12:00:00Z'
    published: '2017-06-02T12:00:00Z'
    image: 'images/link/to/image.jpg' # optional
    major: true # optional
    dev: false
    content: >
      Example content goes here

see also:General news updates

Example use of news_updates

video_url

If there's a YouTube video for the experiment use this field. Note that this should be the embed URL rather than the sharing URL

video_url: 'video_url: https://www.youtube.com/embed/lDv68xYHFXM'

Example share on embed code

image_twitter

A representative image to be used when being shared on Twitter. Should be a 560x300 JPG. Required.

image_twitter: '/static/images/experiments/experiment-name/twitter.jpg'

Example share on Twitter with image

image_facebook

A representative image to be used when being shared on Facebook. Should be a 1200x630 JPG. Required.

image_facebook: /static/images/experiments/experiment-name/facebook.jpg

Example share on Facebook with image

thumbnail

The root absolute path to where the image will be served. Should be a 192x192 PNG with 24-bit transparency, using only white. Required.

thumbnail: '/static/images/experiments/experiment-name/thumbnail.png'

Example thumbnail

gradient_start

The upper-left color of the gradient displayed in front of the thumbnail image. Required.

gradient_start: '#111111'

Example thumbnail

gradient_stop

The bottom-right color of the gradient displayed behind the thumbnail image. Required.

gradient_stop: '#222222'

Example thumbnail

xpi_url

The URL to the Test Pilot-hosted XPI file. Required.

xpi_url: 'https://testpilot.firefox.com/files/experiment-name/latest'

addon_id

The add-on ID from the experiment manifest. Required.

addon_id: '[email protected]'

created

UTM-formatted date indicating the official launch of the experiment. Used to calculate labels like "Just launched". Required.

created: '2016-01-01T00:00:00.000000Z'

Modified

UTM-formatted date indicating the last major modification to your experiment. This adds a star to your experiment's card.

modified: '2016-01-01T00:00:00.000000Z'

completed

UTM-formatted date indicating the time the experiment will be retired. Used to calculate labels like "Ending Soon". Optional. Note: should include timezone to ensure experiment completes at the same time everywhere.

completed: '2016-01-01T00:00:00.000000Z'

uninstalled

UTM-formatted date indicating the time the experiment will be automatically uninstalled.

uninstalled: '2016-01-01T00:00:00.000000Z'

launch_date

UTM-formatted date indicating the time at which the experiment should be displayed in production. Use this to time experiment launches with marketing campaigns. Optional.

launch_date: '2016-01-01T00:00:00.000000Z'

changelog_url

The URL to the experiment's changelog. Displayed in the sidebar. Required.

changelog_url: 'https://www.github.com/mozilla/experiment-name/blob/master/docs/changelog.md'

Example usage of changelog URL

contribute_url

The URL to the code repository for the experiment. Displayed in the sidebar. Required.

contribute_url: 'https://www.github.com/mozilla/experiment-name'

Example usage of contribute URL

bug_report_url

The URL to the experiment's issue tracker. Displayed in the sidebar. Required.

bug_report_url: 'https://www.github.com/mozilla/experiment-name/issues'

Example usage of bug report URL

discourse_url

The URL to the experiment's Discourse forum. Displayed in the sidebar. Required.

discourse_url: 'https://discourse.mozilla-community.org/c/test-pilot/experiment-name'

Example usage of Discourse URL

privacy_notice_url

The URL to the experiment's metrics documentation. Displayed beneath the measurement disclaimer. Required.

privacy_notice_url: 'https://www.github.com/mozilla/experiment-name/blob/master/docs/metrics.md'

Example usage of privacy notice URL

details

An array of one or more image + caption pairs, listed on the experiment detail page. Each one should contain:

  • headline - Bold text to display at the beginning of the caption. Optional, HTML not allowed.
  • image - The URL to the image. Should be 1280px wide and 720-1080px tall. Required.
  • copy - A caption for the image. Localized, required, HTML not allowed.
details:
  -
    headline: 'Lorem ipsum'
    image: /static/images/experiments/experiment-name/details-1.jpg
    copy: >
      dolor sit amet, consectetur adipisicing elit. Ipsum cum ad deserunt
      iusto possimus. Fugiat odit corrupti cumq ue.

Example detail image

contributors

An array of one or more contributors to the experiment, listed on the experiment detail page. Each one should contain:

  • display_name - The contributor's name. Required.
  • title - The contributor's title. Localized, optional.
  • avatar - The URL to an avatar for the contributor. Should be 64x64. Required.
contributors:
  -
    display_name: 'Tom Pizza'
    title: 'Taco Engineer'
    avatar: /static/images/experiments/experiment-name/burrito.png

Example contributor

contributors_extra

If your experiment non-enumerable legacy contributions, use this field to call them out. Optional. Localized.

contributors_extra: >
    This experiment is based on Firefox Tracking Protection technology built by Mozilla employees
    and contributors over the past several years.

Example Contrib Extra

contributors_extra_url

If your experiment contains a contributors_extra section, you can optionally pass in a URL for a learn more link.

contributors_extra: 'https://example.com'

tour_steps

An array of one or more steps to a tour presented to users after installing the experiment. Each one should contain:

  • image - The URL to an image. Should be 1280x720. Required.
  • copy - A caption for the image. Should be wrapped in <p> tags. Localized, required, HTML allowed.
tour_steps:
  -
    image: /static/images/experiments/experiment-name/tour-1.jpg
    copy: >
      <p>Lorem ipsum dolor sit amet.</p>

Example tour step

measurements

A description of the measurements collected by the experiment. Displayed in the sidebar in an unordered list. Localized, required, HTML allowed.

measurements:
  - >
    Lorem ipsum dolor sit amet, consectetur adipisicing elit. Quibusdam atque accusamus,
    suscipit, nam commodi excepturi error modi. Laborum eum, quae, alias facere,
    cupiditate vitae praesentium eveniet unde totam, architecto molestiae?
  - >
    Lorem ipsum dolor sit amet, consectetur adipisicing elit. Quibusdam atque accusamus,
    suscipit, nam commodi excepturi error modi. Laborum eum, quae, alias facere,
    cupiditate vitae praesentium eveniet unde totam, architecto molestiae?

Example measurements section

pre_feedback_image

If the experiment collects feedback directly, a modal window similar to the experiment tour is shown before the user goes to the feedback form. This is the image shown when that happens.

Should be 1280x720. Optional, required if pre_feedback_copy is set.

pre_feedback_image: /static/images/experiments/experiment-name/pre-feedback.jpg

Example pre-feedback prompt

pre_feedback_copy

If the experiment collects feedback directly, a modal window similar to the experiment tour is shown before the user goes to the feedback form. This is the caption of the image in that prompt.

Should be wrapped in <p> tags. Localized, optional, required if pre_feedback_image is set, HTML allowed.

pre_feedback_copy: >
  <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Quibusdam atque accusamus,
    suscipit, nam commodi excepturi error modi.</p>

Example pre-feedback prompt

graduation_url

When an experiment graduates, a link to the provided graduation_url will be shown on the experiment details page.

If an experiment has graduated but no graduation_url is provided, a message is shown stating that a graduation report is coming soon.

graduation_url: http://example.com/graduation-report

eol_warning

When your experiment is ending, add this field to indicate to users what will happen next.

Localized, required when you add a completed field.

eol_warning: 'Lorem ipsum dolor sit amet, consectetur adipisicing elit.'

EOL Warning

min_release

The minimum version of Firefox with which this experiment is compatible. If the user is browsing with a version lower than this number, an incompatibility notice is displayed. Optional.

min_release: 99

Warning shown to users with incompatible versions of Firefox

max_release

The maximum version of Firefox with which this experiment is compatible. If the user is browsing with a version higher than this number, an incompatibility notice is displayed. Optional.

max_release: 2084

Warning shown to users with incompatible versions of Firefox

incompatible

A hash of add-ons incompatible with the experiment, mapping add-on ID to its name. If the user has one of these installed and enabled, a warning is displayed to them. Optional.

incompatible:
  '@fake-incompatible': 'Fake Incompatible Add-on Name'

Warning shown to users with incompatible add-ons installed and enabled

locales

An array of locales without region codes in which the experiment is localized. If defined and the user's first language preference is not in this list, a warning is displayed. Optional.

locales:
  - 'en'

Warning shown to users viewing an experiment not localized in their top language preference

locale_blocklist

An array of locales without region codes from which the experiment should be hidden. If defined and the user's first language preference is not in this list, the experiment will be hidden on the site. Optional.

locale_blocklist:
  - 'de'

locale_grantlist

An array of locales without region codes in which the experiment should be allowed. If defined and the user's first language preference is in the list, the experiment will be available on the site. Optional.

locale_grantlist:
  - 'de'

dev

A Boolean indicating whether this experiment should only appear in a dev environment, i.e. for testing or active development. Required.

dev: false

Note: experiments set to dev: true are intentionally skipped during localization string export.

testpilot_options

A set of options for configuring TestPilot features for this experiment.

Enabling / disabling the rating feedback prompt is the only option right now. Valid values are enabled or disabled. Defaults to enabled.

testpilot_options:
  ratings: enabled

General News Updates

General news updates about TestPilot can be added in content/news_updates.yaml. These will show up on the /experiments page in reverse chronological order along with the experiment updates.

# News updates for Test Pilot in general expressed as a YAML list
 -
   slug: general-update-1
   title: Example title
   link: https://blog.mozilla.org/testpilot/example
   created: '2017-06-01T12:00:00Z'
   published: '2017-06-02T12:00:00Z'
   image: 'images/link/to/image.jpg' # optional
   major: true # optional
   content: >
     Example content goes here

Example general news update