chromium/tools/perf/page_sets/system_health/story_tags.py

# Copyright 2017 The Chromium Authors
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.

import collections
import re


Tag = collections.namedtuple('Tag', ['name', 'description'])


# Below are tags that describe various aspect of system health stories.
# A story can have multiple tags. All the tags should be noun.

ACCESSIBILITY = Tag(
    'accessibility', 'Story tests performance when accessibility is enabled.')
AUDIO_PLAYBACK = Tag(
    'audio_playback', 'Story has audio playing.')
CANVAS_ANIMATION = Tag(
    'canvas_animation', 'Story has animations that are implemented using '
    'html5 canvas.')
CSS_ANIMATION = Tag(
    'css_animation', 'Story has animations that are implemented using CSS.')
EXTENSION = Tag(
    'extension', 'Story has browser with extension installed.')
HEALTH_CHECK = Tag(  # See go/health_check_stories for details.
    'health_check', 'Story belongs to a collection chosen to have a wide '
    'coverage but low running time.')
IMAGES = Tag(
    'images', 'Story has sites with heavy uses of images.')
INFINITE_SCROLL = Tag('infinite_scroll', 'Story has infinite scroll action.')
INTERNATIONAL = Tag(
    'international', 'Story has navigations to websites with content in non '
    'English languages.')
EMERGING_MARKET = Tag(
    'emerging_market', 'Story has significant usage in emerging markets with '
    'low-end mobile devices and slow network connections.')
JAVASCRIPT_HEAVY = Tag(
    'javascript_heavy', 'Story has navigations to websites with heavy usages '
    'of JavaScript. The story uses 20Mb+ memory for javascript and local '
    'run with "v8" category enabled also shows the trace has js slices across '
    'the whole run.')
KEYBOARD_INPUT = Tag(
    'keyboard_input', 'Story does keyboard input.')
SCROLL = Tag(
    'scroll', 'Story has scroll gestures & scroll animation.')
PINCH_ZOOM = Tag(
    'pinch_zoom', 'Story has pinch zoom gestures & pinch zoom animation.')
TABS_SWITCHING = Tag(
    'tabs_switching', 'Story has multi tabs and tabs switching action.')
VIDEO_PLAYBACK = Tag(
    'video_playback', 'Story has video playing.')
WEBASSEMBLY = Tag('wasm', 'Story with heavy usages of WebAssembly')
WEBGL = Tag(
    'webgl', 'Story has sites with heavy uses of WebGL.')
WEB_STORAGE = Tag(
    'web_storage', 'Story has sites with heavy uses of Web storage.')

# Tags by year.
YEAR_2016 = Tag('2016', 'Story was created or updated in 2016.')
YEAR_2017 = Tag('2017', 'Story was created or updated in 2017.')
YEAR_2018 = Tag('2018', 'Story was created or updated in 2018.')
YEAR_2019 = Tag('2019', 'Story was created or updated in 2019.')
YEAR_2020 = Tag('2020', 'Story was created or updated in 2020.')
YEAR_2021 = Tag('2021', 'Story was created or updated in 2021.')
YEAR_2023 = Tag('2023', 'Story was created or updated in 2023.')


def _ExtractAllTags():
  all_tag_names = set()
  all_tags = set()
  # Collect all the tags defined in this module. Also assert that there is no
  # duplicate tag names.
  for obj in globals().values():
    if isinstance(obj, Tag):
      all_tags.add(obj)
      assert obj.name not in all_tag_names, 'Duplicate tag name: %s' % obj.name
      all_tag_names.add(obj.name)
  return all_tags

def _ExtractYearTags():
  year_tags = set()
  pattern = re.compile('^[0-9]{4}$')
  for obj in globals().values():
    if isinstance(obj, Tag) and pattern.match(obj.name):
      year_tags.add(obj)
  return year_tags

ALL_TAGS = _ExtractAllTags()
YEAR_TAGS = _ExtractYearTags()