From 6ab58f5e532f960b77d66f846703c99080528199 Mon Sep 17 00:00:00 2001 From: Ben Griffith Date: Fri, 11 Sep 2015 22:27:41 +0100 Subject: [PATCH 1/2] Enhance no-duplicate-properties rule to allow exceptions --- lib/rules/no-duplicate-properties.js | 20 ++++++++++++-------- tests/rules/no-duplicate-properties.js | 19 ++++++++++++++++--- tests/sass/no-duplicate-properties.scss | 5 +++++ 3 files changed, 33 insertions(+), 11 deletions(-) diff --git a/lib/rules/no-duplicate-properties.js b/lib/rules/no-duplicate-properties.js index 01ff5a6f..9b194941 100644 --- a/lib/rules/no-duplicate-properties.js +++ b/lib/rules/no-duplicate-properties.js @@ -4,7 +4,9 @@ var helpers = require('../helpers'); module.exports = { 'name': 'no-duplicate-properties', - 'defaults': {}, + 'defaults': { + 'exclude': [] + }, 'detect': function (ast, parser) { var result = []; @@ -26,13 +28,15 @@ module.exports = { properties.push(property); } else { - result = helpers.addUnique(result, { - 'ruleId': parser.rule.name, - 'line': item.start.line, - 'column': item.start.column, - 'message': 'Duplicate properties are not allowed within a block', - 'severity': parser.severity - }); + if (parser.options.exclude.indexOf(property) === -1) { + result = helpers.addUnique(result, { + 'ruleId': parser.rule.name, + 'line': item.start.line, + 'column': item.start.column, + 'message': 'Duplicate properties are not allowed within a block', + 'severity': parser.severity + }); + } } }); }); diff --git a/tests/rules/no-duplicate-properties.js b/tests/rules/no-duplicate-properties.js index 8dee48d7..afd41348 100644 --- a/tests/rules/no-duplicate-properties.js +++ b/tests/rules/no-duplicate-properties.js @@ -5,12 +5,25 @@ var lint = require('./_lint'); var file = lint.file('no-duplicate-properties.scss'); describe('no duplicate properties', function () { - ////////////////////////////// - // Duplicate Property - ////////////////////////////// it('enforce', function (done) { lint.test(file, { 'no-duplicate-properties': 1 + }, function (data) { + lint.assert.equal(4, data.warningCount); + done(); + }); + }); + + it('enforce - [exclude: background]', function (done) { + lint.test(file, { + 'no-duplicate-properties': [ + 1, + { + 'exclude': [ + 'background' + ] + } + ] }, function (data) { lint.assert.equal(3, data.warningCount); done(); diff --git a/tests/sass/no-duplicate-properties.scss b/tests/sass/no-duplicate-properties.scss index ef3ee192..0e0d1672 100644 --- a/tests/sass/no-duplicate-properties.scss +++ b/tests/sass/no-duplicate-properties.scss @@ -15,3 +15,8 @@ display: none; } } + +.qux { + background: rgb(200, 54, 54); + background: rgba(200, 54, 54, 0.5); +} From b232ad7c262127e841dcb30846924ac964a0f372 Mon Sep 17 00:00:00 2001 From: Ben Griffith Date: Sat, 12 Sep 2015 13:48:25 +0100 Subject: [PATCH 2/2] :memo: Add new exclude feature to docs --- docs/rules/no-duplicate-properties.md | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/docs/rules/no-duplicate-properties.md b/docs/rules/no-duplicate-properties.md index 3bffb85a..707d73f2 100644 --- a/docs/rules/no-duplicate-properties.md +++ b/docs/rules/no-duplicate-properties.md @@ -2,6 +2,11 @@ Rule `no-duplicate-properties` will enforce that duplicate properties are not allowed within the same block. +## Options + +* `exclude`: `[array of property names to be excluded from this rule]` (defaults to empty array `[]`) + + ## Examples When enabled, the following are disallowed: