Вышел бенчмарк для измерения скорости отклика веб-приложений Speedometer 3.0 от Mozilla, Google, Microsoft и Apple

11 марта 2024 года состоялся релиз бенчмарка для измерения скорости отклика веб-приложений в различных браузерах Speedometer 3.0. Работу над этим проектом вели разработчики Mozilla, Google, Microsoft и Apple.

Ключевой задачей бенчмарка Speedometer 3.0 является оценка задержек при симуляции работы пользователя с типовыми веб-приложениями.

Speedometer оценивает задержки при симуляции активности пользователя в веб-приложениях. Для теста предлагается воспроизвести стандартные для обычной деятельности действия, по результатам которых сервис начисляет приложению баллы.

Разработка Speedometer 3 велась совместно тремя компаниями, создавшими самые популярные браузерные движки: WebKit (Apple), Blink (Google) и Quantum (Mozilla). Компании были намерены «добиться совместного понимания работы веб-приложений и повысить производительность браузера так, чтобы помочь пользователям».

Google планировала, чтобы третья версия теста «включала все репрезентативные современные рабочие нагрузки». Mozilla заявила, что «пришло время обновить сервис, поскольку Интернет сильно изменился с момента последнего крупного выпуска».

Согласно данным OpenNET, в Speedometer 3.0 осуществлён переход на применение новых выпусков фреймворков Angular, Backbone, jQuery, Lit, Preact, React, React+Redux, Svelte и Vue. Задействованы современные шаблоны проектирования сайтов и веб-приложений, например, использование Webpack, Web Components и новых методов работы с DOM. Добавлены тесты для оценки производительности отрисовки при помощи элемента Canvas, генерации SVG, обработки сложных CSS, работы с очень большими деревьями DOM и использования методов, применяемых при редактировании контента в режиме WYSIWYG и при работе с новостными сайтами.

В инструментарии для запуска тестов расширен спектр операций в браузере, учитываемых при измерении реакции на действие пользователя, например, измеряется не только время выполнения кода, но и время отрисовки и асинхронного выполнения задач. Для разработчиков браузеров подготовлены инструменты для анализа результатов выполнения тестов, профилирования и изменения параметров тестов. Предоставлена возможность создания собственных сложных сценариев запуска тестов.

Эталонные тесты, используемые в Speedometer 3.0 для оценки производительности, включают в себя:

добавление, заполнение и удаление 100 заметок с использованием менеджера задач TodoMVC, реализованного в вариантах на базе разных web-фреймворков, методов работы с DOM и версий стандарта ECMAScript. Например, запускаются варианты TodoMVC на базе фреймворков React, Angular, Vue, jQuery, WebComponents, Backbone, Preact, Svelte и Lit, а также варианты, использующие расширенные возможности, появившиеся в спецификациях ECMAScript 5 и ECMAScript 6;

редактирование текста с разметкой в режиме WYSIWYG с использованием редакторов кода CodeMirror и TipTap;

взаимодействие с диаграммами, оформленными через элемент canvas или сгенерированными в формате SVG при помощи библиотек Observable Plot, chart.js и react-stockcharts;

навигацию по страницам и взаимодействие с контентом на типовых новостных сайтах, на которых используются web-фреймворки Next.js и Nuxt.

Сервис Speedometer вышел в 2014 году, в 2018 свет увидело первое крупное обновление, версия 2.0. Первая версия Speedometer измеряла скорость отклика приложений на базе фреймворков Ember, Backbone, AngularJS, jQuery, Flight и одной из первых версий React. В Speedometer 2.0 появилась возможность оценки Preact и Inferno, а также полноценной версии React и Redux.

Исходный код проекта Speedometer опубликован на GitHub под лицензией BSD. С 2022 года проект разрабатывается в соответствии с новой моделью управления, подразумевающей совместное принятие решений с достижением консенсуса. Репозиторий проекта открыт для участия любых заинтересованных лиц и продвижения своих идей и исправлений.

Источник: habr.com

0 0 голоса
Рейтинг новости
0
0
Подписаться
Уведомить о
0 комментариев
Межтекстовые Отзывы
Посмотреть все комментарии