npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@lokalise/playwright-reporters

v1.8.1

Published

This is a collection of reporters to use with our Playwright test frameworks.

Downloads

1,074

Readme

Lokalise Playwright Reporters

This is a collection of reporters to use with our Playwright test frameworks.

Key Features

  • Retry reporter: Provides an easy way to retry failed tests on Jenkins or locally.
  • Analytics reporter: Uploads test results and browser usage to ElasticSearch for further analysis.

Getting Started

  • Add the package to your project:
npm install @lokalise/playwright-reporters
  • Add the reporters to your Playwright configuration:
import { defineAnalyticsReporterConfig, defineRetryReporterConfig } from '@lokalise/playwright-reporters';

export default defineConfig({
  ...
  reporters: [
    ['retry', defineRetryReporterConfig({ maxRetryCount: 2, isPREnv: false })],
    ['analytics', defineAnalyticsReporterConfig({
        flakyTestIndex: 'flaky_tests_0001',
        failedTestIndex: 'non_passing_tests_0001',
        testRunIndex: 'test_run_0001',
        browserUsageIndex: 'browser_usage_0001',
        elasticUrl: 'http://elasticUrl',
        elasticToken: 'elasticToken',
        currentBuildId: 'buildId',
        debug: true,
        dryRun: false,
        prenvId: 'develop',
        product: 'product',
      })],
  ],
  ...
});

Steps Duration Reporter

This reporter aggregates the duration of each discrete test step and reports their total duration at the end of the test run. The reporter uses the custom Playwright Reporter implementation to collect the step durations. Follow the steps in the official Playwright documentation to add the custom reporter to your test suite.

Usage

Once the reporter is enabled, it will output a JSON file ./reporters/results/steps.json containing the duration of each step in the test suite.

Test Similarity Reporter

This reporter calculates the similarity between tests based on the test steps. The reporter does not use the custom Playwright Reporter implementation. Instead, it takes the simplified reporter from the undocumented timeline reporter.

Usage

  1. Run the test suite with the timeline reporter enabled. This will generate a JSON file ./reporters/results/timeline.json
  2. Run the similarity reporter with the following command: npx ts-node reporters/testSimilarity.ts
  3. After analysing the results, the reporter will output a JSON file ./reporters/results/distance.json containing the similarity between tests based on the test steps.

Output

The report has the following format:

[
	{
		"title": "Title of the test being compared",
		"relatedTests": [
			["Title of the first related test", 0],
			["Title of the second related test", 50]
		]
	}
]

The relatedTests array contains the title of the related test and the distance score. The similarity percentage is calculated based on the Levenshtein distance between the test steps. The lower the distance, the higher the similarity between the tests.

Husky

By default, pre-commit hook will run npm run lint:fix. Feel free to remove that if it's undesirable or add your own pre-commit commands.

Check out husky docs for more info.

commitlint

You can use npm run commit to interactively construct correct commit messsage.

Check out commitlint docs for examples of how to customise.

Release actions

The following token needs to be set in the Github repo for the prerelease and release Github Actions to work:

  • secrets.NPM_TOKEN (need this to publish on NPM)

When performing a release, make sure to follow our conventional commit approach, as described in contribution documentation.

License

This project is APACHE, VERSION 2.0 licensed, see LICENSE.md for details.