Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Shopify/theme-check
The Ultimate Shopify Theme Linter
https://github.com/Shopify/theme-check
linter liquid static-code-analysis
Last synced: 2 months ago
JSON representation
The Ultimate Shopify Theme Linter
- Host: GitHub
- URL: https://github.com/Shopify/theme-check
- Owner: Shopify
- License: other
- Created: 2020-11-25T15:22:58.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2024-04-11T15:52:13.000Z (9 months ago)
- Last Synced: 2024-04-14T09:45:34.108Z (9 months ago)
- Topics: linter, liquid, static-code-analysis
- Language: Ruby
- Size: 3.49 MB
- Stars: 329
- Watchers: 255
- Forks: 92
- Open Issues: 100
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-shopify - Shopify Theme Check - The Ultimate Shopify Theme Linter. (Tools / Command Line Tools)
README
> **Warning**
>
> This project has been absorbed by and moved to [Shopify/theme-tools](https://github.com/Shopify/theme-tools).# Theme Check ✅ - A linter for Themes
Think RuboCop, or eslint, but for Shopify themes.
Theme Check is a command line tool that helps you follow Shopify Themes & Liquid best practices by analyzing the Liquid & JSON inside your theme.
Theme Check is also available [inside some code editors](https://github.com/Shopify/theme-check/wiki).
![](docs/preview.png)
## Supported Checks
Theme Check currently checks for the following:
✅ Liquid syntax errors
✅ JSON syntax errors
✅ Missing snippet & section templates
✅ Unused `{% assign ... %}`
✅ Unused snippet templates
✅ Template length
✅ Deprecated tags
✅ Unknown tags
✅ Unknown filters
✅ Missing `{{ content_for_* }}` in `theme.liquid`
✅ Excessive nesting of snippets
✅ Missing or extra spaces inside `{% ... %}` and `{{ ... }}`
✅ Missing default locale file
✅ Unmatching translation keys in locale files
✅ Using unknown translation keys in `{{ 'missing_key' | t }}`
✅ Using several `{% ... %}` instead of `{% liquid ... %}`
✅ Undefined [objects](https://shopify.dev/docs/themes/liquid/reference/objects)
✅ Deprecated filters
✅ Missing `theme-check-enable` commentAs well as checks that prevent easy to spot performance problems:
✅ Use of [parser-blocking](/docs/checks/parser_blocking_javascript.md) JavaScript
✅ [Use of non-Shopify domains for assets](/docs/checks/remote_asset.md)
✅ [Missing width and height attributes on `img` tags](/docs/checks/img_width_and_height.md)
✅ [Too much JavaScript](/docs/checks/asset_size_javascript.md)
✅ [Too much CSS](/docs/checks/asset_size_css.md)For detailed descriptions and configuration options, [take a look at the complete list.](/docs/checks/)
With more to come! Suggestions welcome ([create an issue](https://github.com/Shopify/theme-check/issues)).
## Requirements
- Ruby 2.7+
## Installation
Theme Check is available through Homebrew _or_ RubyGems.
**Homebrew**
You’ll need to run `brew tap` first to add Shopify’s third-party repositories to Homebrew.
```sh
brew tap shopify/shopify
brew install theme-check
```**RubyGems**
```sh
gem install theme-check
```## Usage
```
theme-check /path/to/your/theme# or from /path/to/your/theme
theme-check
```Run `theme-check --help` to get full usage.
## Configuration
Add a `.theme-check.yml` file at the root of your theme to configure:
```yaml
# If your theme is not using the supported directory structure, provide the root path
# where to find the `templates/`, `sections/`, `snippets/` directories as they would
# be uploaded to Shopify.
root: dist# It is possible to extend theme-check with custom checks
require:
- ./path/to/my_custom_check.rbTemplateLength:
# Disable some checks
enabled: false
# Or configure options
max_length: 300
# Or ignore certain paths
ignore:
- snippets/icon-*
# Or change the severity (error|suggestion|style)
severity: suggestion# Enable a custom check
MyCustomCheck
enabled: true
```See [config/default.yml](config/default.yml) for available options & defaults.
## Disable checks with comments
Use Liquid comments to disable and re-enable all checks for a section of your template:
```liquid
{% # theme-check-disable %}
{% assign x = 1 %}
{% # theme-check-enable %}
```Disable a specific check by including it in the comment:
```liquid
{% # theme-check-disable UnusedAssign %}
{% assign x = 1 %}
{% # theme-check-enable UnusedAssign %}
```Disable multiple checks by including them as a comma-separated list:
```liquid
{% # theme-check-disable UnusedAssign,SpaceInsideBraces %}
{%assign x = 1%}
{% # theme-check-enable UnusedAssign,SpaceInsideBraces %}
```Disable checks for the _entire document_ by placing the comment on the first line:
```liquid
{% # theme-check-disable SpaceInsideBraces %}
{%assign x = 1%}
```## Exit Code and `--fail-level`
Use the `--fail-level` (default: `error`) flag to configure the exit code of theme-check. Useful in CI scenarios.
Example:
```
# Make CI fail on styles warnings, suggestions, and errors
theme-check --fail-level style path_to_theme# Make CI fail on suggestions, and errors
theme-check --fail-level suggestion path_to_theme# Make CI fail on errors
theme-check path_to_theme
```There are three fail levels:
- `error`
- `suggestion`
- `style`Exit code meanings:
- 0: Success!
- 1: Your code doesn't pass the checks
- 2: There's a bug in theme-checkIf you would like to change the severity of a check, you can do so with the `severity` attribute. Example:
```yaml
DeprecateLazysizes:
enabled: true
severity: error
```## Language Server Configurations
- `themeCheck.checkOnOpen` (default: `true`) makes it so theme check runs on file open.
- `themeCheck.checkOnChange` (default: `true`) makes it so theme check runs on file change.
- `themeCheck.checkOnSave` (default: `true`) makes it so theme check runs on file save.
- `themeCheck.onlySingleFileChecks` (default: `false`) makes it so we only check the opened files and disable "whole theme" checks (e.g. UnusedSnippet, TranslationKeyExists)⚠️ **Note:** Quickfixes only work on a freshly checked file. If any of those configurations are turned off, you will need to rerun theme-check in order to apply quickfixes.
In VS Code, these can be set directly in your `settings.json`.
## Contributing
For guidance on contributing, refer to this [doc](/CONTRIBUTING)