From f269c7900c47716c6947ace1cd97b2fac0a69f25 Mon Sep 17 00:00:00 2001 From: Jonathan Boiser Date: Thu, 12 Jul 2018 15:00:27 -0700 Subject: [PATCH] feat: support linting in vue single-file components with scss --- .circleci/config.yml | 2 +- .travis.yml | 2 +- appveyor.yml | 2 +- circle.yml | 14 ++++++++++++++ lib/index.js | 3 ++- spec/fixtures/vue/.stylelintrc | 5 +++++ spec/fixtures/vue/badSCSS.vue | 9 +++++++++ spec/fixtures/vue/goodSCSS.vue | 11 +++++++++++ spec/linter-stylelint-spec.js | 26 ++++++++++++++++++++++++++ 9 files changed, 70 insertions(+), 4 deletions(-) create mode 100644 circle.yml create mode 100644 spec/fixtures/vue/.stylelintrc create mode 100644 spec/fixtures/vue/badSCSS.vue create mode 100644 spec/fixtures/vue/goodSCSS.vue diff --git a/.circleci/config.yml b/.circleci/config.yml index 6e188972..5e919c85 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -7,7 +7,7 @@ defaults: &defaults environment: # Pre-install the required language file as package activation doesn't wait # for the installation to complete. - APM_TEST_PACKAGES: "language-postcss" + APM_TEST_PACKAGES: "language-postcss language-vue" steps: # Restore project state - attach_workspace: diff --git a/.travis.yml b/.travis.yml index d66d3b14..4fcec7d4 100644 --- a/.travis.yml +++ b/.travis.yml @@ -8,7 +8,7 @@ env: global: # Pre-install the required language file as package activation doesn't wait # for the installation to complete. - - APM_TEST_PACKAGES="language-postcss" + - APM_TEST_PACKAGES="language-postcss language-vue" jobs: include: diff --git a/appveyor.yml b/appveyor.yml index 8298df37..7bfced62 100644 --- a/appveyor.yml +++ b/appveyor.yml @@ -1,6 +1,6 @@ ### Project specific config ### environment: - APM_TEST_PACKAGES: language-postcss + APM_TEST_PACKAGES: language-postcss language-vue matrix: - ATOM_CHANNEL: stable diff --git a/circle.yml b/circle.yml new file mode 100644 index 00000000..166624dc --- /dev/null +++ b/circle.yml @@ -0,0 +1,14 @@ +dependencies: + override: + - curl -s -O https://raw.githubusercontent.com/atom/ci/master/build-package.sh + - chmod u+x build-package.sh + +test: + override: + - ./build-package.sh + +machine: + environment: + # Pre-install the required language file as package activation doesn't wait + # for the installation to complete. + APM_TEST_PACKAGES: "language-postcss language-vue" diff --git a/lib/index.js b/lib/index.js index 766e5bc5..b782e328 100644 --- a/lib/index.js +++ b/lib/index.js @@ -89,7 +89,8 @@ export default { 'source.less', 'source.css.less', 'source.css.postcss', - 'source.css.postcss.sugarss' + 'source.css.postcss.sugarss', + 'source.css.scss.embedded.html' ]; }, diff --git a/spec/fixtures/vue/.stylelintrc b/spec/fixtures/vue/.stylelintrc new file mode 100644 index 00000000..0eb6e7c4 --- /dev/null +++ b/spec/fixtures/vue/.stylelintrc @@ -0,0 +1,5 @@ +{ + "rules": { + "block-no-empty": true + } +} diff --git a/spec/fixtures/vue/badSCSS.vue b/spec/fixtures/vue/badSCSS.vue new file mode 100644 index 00000000..f2cd1b2e --- /dev/null +++ b/spec/fixtures/vue/badSCSS.vue @@ -0,0 +1,9 @@ + + + + + + + diff --git a/spec/fixtures/vue/goodSCSS.vue b/spec/fixtures/vue/goodSCSS.vue new file mode 100644 index 00000000..fdd7b009 --- /dev/null +++ b/spec/fixtures/vue/goodSCSS.vue @@ -0,0 +1,11 @@ + + + + + + + diff --git a/spec/linter-stylelint-spec.js b/spec/linter-stylelint-spec.js index b1353bd5..83c404a1 100644 --- a/spec/linter-stylelint-spec.js +++ b/spec/linter-stylelint-spec.js @@ -328,4 +328,30 @@ describe('The stylelint provider for Linter', () => { rimraf.sync(tempDir); }); }); + + describe('works with Vue Single File Components', () => { + const goodVueSCSS = path.join(fixtures, 'vue', 'goodSCSS.vue'); + const badVueSCSS = path.join(fixtures, 'vue', 'badSCSS.vue'); + + beforeEach(async () => { + await atom.packages.activatePackage('language-vue'); + }); + + it('shows lint messages when found', async () => { + const editor = await atom.workspace.open(badVueSCSS); + const messages = await lint(editor); + + expect(messages[0].severity).toBe('error'); + expect(messages[0].excerpt).toBe(blockNoEmpty); + expect(messages[0].url).toBe(blockNoEmptyUrl); + expect(messages[0].location.file).toBe(badVueSCSS); + expect(messages[0].location.position).toEqual([[7, 2], [7, 4]]); + }); + + it('finds nothing wrong with a valid file', async () => { + const editor = await atom.workspace.open(goodVueSCSS); + const messages = await lint(editor); + expect(messages.length).toBe(0); + }); + }); });