Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/m3au/playwright-eslint-prettier-setup


https://github.com/m3au/playwright-eslint-prettier-setup

Last synced: 11 days ago
JSON representation

Awesome Lists containing this project

README

        

# @meowsos/playwright-eslint-prettier-setup

![npm (scoped)](https://img.shields.io/npm/v/@meowsos/playwright-eslint-prettier-setup) ![License](https://img.shields.io/npm/l/@meowsos/playwright-eslint-prettier-setup) ![GitHub issues](https://img.shields.io/github/issues/meowso/playwright-hero) ![GitHub stars](https://img.shields.io/github/stars/meowso/meowsos-playwright-setup) ![GitHub pull requests](https://img.shields.io/github/issues-pr/meowso/playwright-hero) ![GitHub last commit](https://img.shields.io/github/last-commit/meowso/playwright-hero)

![Meow](https://bit.ly/fcc-running-cats)

## Description

Modern [ESLint](https://www.npmjs.com/package/eslint) + [Prettier](https://www.npmjs.com/package/prettier) setup for [Playwright](https://www.npmjs.com/package/playwright) Typescript projects, with [SonarJS](https://www.npmjs.com/package/eslint-plugin-sonarjs) and [ESLint Unicorn](https://www.npmjs.com/package/eslint-plugin-unicorn) plugins.

It tries to be very agnostic while at the same time use all available, very opinionated tools from the community, to enforce and automate code quality standards and conventions.

This mono-repo was inspire in this wonderful article [here](https://blog.logrocket.com/reduce-effort-shared-eslint-prettier-configs/) and aims to be a plug-and-play solution for Playwright only code repositories.

- [@meowsos/playwright-eslint-prettier-setup](#meowsosplaywright-eslint-prettier-setup)
- [Description](#description)
- [Requirements](#requirements)
- [Usage](#usage)
- [Recommended Extensions](#recommended-extensions)
- [Contributing](#contributing)

---

## Requirements

Before using this package, you need to have a [playwright project](https://www.npmjs.com/package/playwright) in your repository; if you haven't, thy this code:

```bash
npm init playwright@latest new-project
```

And it needs to have a **tsconfig.json** file in the root folder; if you haven't got one, try:

```bash
npx tsc --init
```

## Usage

1. Install the package as a dev dependency:

```bash
npm i -D @meowsos/eslint-config @meowsos/prettier-config
```

2. Add the following to your `package.json`: (The rules here are just an example on how to override them if you wish, don't add them.)

```json
{
"scripts": {
"lint": "eslint . --ext .ts",
"lint:fix": "eslint . --ext .ts --fix",
"format": "prettier --write .",
"format:check": "prettier --check ."
},
"prettier": "@meowsos/prettier-config",
"eslintConfig": {
"extends": "@meowsos/eslint-config",
"rules": {
"playwright/expect-expect": 0,
"playwright/no-networkidle": 0,
"playwright/no-skipped-test": 0,
"playwright/valid-title": 0,
"unicorn/no-nested-ternary": "off"
}
}
}
```

3. Create a `.eslintignore` file in the root of your project with the following:

```txt
.vscode/
node_modules/
test-results/
reports/
```

4. Create a `.prettierignore` file in the root of your project with the following:

```txt
node_modules/
reports/
test-results/
.bash_history
*.lock
```

5. Create a `.vscode/settings.json` file in the root of your project with the following:

```json
{
"editor.defaultFormatter": "esbenp.prettier-vscode",
"editor.formatOnSave": true,
"editor.codeActionsOnSave": {
"source.fixAll.eslint": true
}
}
```

## Recommended Extensions

We recommend the following extensions for VSCode, which will be automatically suggested to be installed if you add the following setup.

Create a `.vscode/extensions.json` file in the root of your project with the following:

```json
{
"recommendations": [
"dbaeumer.vscode-eslint",
"esbenp.prettier-vscode",
"ms-playwright.playwright",
"ryanrosello-og.playwright-vscode-trace-viewer",
"yoavbls.pretty-ts-errors"
]
}
```

## Contributing

See [CONTRIBUTING.md](CONTRIBUTING.md) for contribution guidelines.