A GitHub action that evaluates projects with Stylelint and comments the evaluation outcome on the student's pull request.
dist/index.js
to execute this action, so this repo has a git hook pre-commit
that automatically runs npm run pack
and add to commit the changes made at dist/index.js
to apply any changes.
Install the dependencies
$ npm install
Run the tests ✔️
$ npm test
GitHub Actions will run the entry point from the action.yml. Packaging assembles the code into one file that can be checked in to Git, enabling fast and reliable execution and preventing the need to check in node_modules.
Actions are run from GitHub repos. Packaging the action will create a packaged action in the dist folder.
Run package
npm run pack
Since the packaged index.js is run from the dist folder.
git add dist
This action accepts the following configuration parameters via with:
-
token
Required
The GitHub token to use for making API requests.
-
pr_number
Required
Pull Request number that dispatched the workflow.
steps:
- uses: actions/setup-node@v1.4.4
with:
node-version: '12'
- name: Static code analysis step
uses: betrybe/stylelint-linter-action@v1
with:
token: ${{ secrets.GITHUB_TOKEN }}
pr_number: ${{ github.event.inputs.pr_number }}
Check the latest version to use here.
This GitHub Action run the command:
npx stylelint **/*.css --config .stylelintrc.json --formatter json --ignore-disables --allow-empty-input
In order for the action to comment the Stylelint
analysis on the pull request, you must:
-
Add
Stylelint
into your project's dependencies. -
Configure the
Stylelint
analysis exclusively via.stylelintrc.json
.
In order to add Stylelint
into your project you must add Stylelint
and its standard configuration
as a dev
dependency:
npm install stylelint stylelint-config-standard --save-dev
If you have multiple projects to be evaluated with Stylelint
in the repository, you must add Stylelint
to each project. Beware that each project must have the same Stylelint
version, in order to ensure that all projects are being evaluated under the same conditions (i.e., the same Stylelint
version).
In order to configure the Stylelint
analysis for your project, you must create a .stylelintrc.json
file at the root of your project. Therefore, beware of the following:
-
There cannot be present
Stylelint
configurations in thepackage.json
of the project; -
There cannot be present inline configurations.
Here follows an example for .stylelintrc.json
:
{
"extends": "stylelint-config-standard",
"rules": {
"block-no-empty": null,
"selector-pseudo-class-no-unknown": [
true,
{
"ignorePseudoClasses": ["global"]
}
],
"identation": [
2,
{
"except": ["value"],
"severity": "warning"
}
]
}
}
If you have multiple projects to be evaluated with Stylelint
in the repository, you must do the following:
- Create a
.stylelintrc.json
file at the root of each project. There cannot be present a.stylelintrc.json
at the root of the repository;
You can use plugins in the configuration file .stylelintrc.json
. However, beware to follow the instructions as stated in the plugin's documentation and install all dependencies associated with the plugin. There cannot be any warning raised by npm
stating uninstalled plugin dependencies when installing a project; otherwise you will have an incomplete Stylelint
analysis environment.
For more information related to configuring Stylelint
with .stylelintrc.json
, read its guide.
Users shouldn't consume the action from master since that would be latest code and actions can break compatibility between major versions.
Checking to the v1 release branch
$ git checkout -b v1
$ git commit -a -m "v1 release"
$ git push origin v1
Your action is now published! 🚀
See the versioning documentation
You can now consume the action by referencing the v1 branch
uses: betrybe/stylelint-linter-action@v1
See the actions tab for runs of this action! 🚀