Skip to content

Commit

Permalink
fix(attr-non-space-content-evaluate): Split no attribute and empty at…
Browse files Browse the repository at this point in the history
…tribute message (#2495)
  • Loading branch information
Xiaoyi Chen authored Aug 28, 2020
1 parent 68d9be5 commit 5f822f4
Show file tree
Hide file tree
Showing 9 changed files with 66 additions and 21 deletions.
16 changes: 15 additions & 1 deletion lib/checks/generic/attr-non-space-content-evaluate.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,22 @@ function attrNonSpaceContentEvaluate(node, options = {}, vNode) {
);
}

if (!vNode.hasAttr(options.attribute)) {
this.data({
messageKey: 'noAttr'
});
return false;
}

const attribute = vNode.attr(options.attribute) || '';
return !!sanitize(attribute.trim());
const attributeIsEmpty = !sanitize(attribute.trim());
if (attributeIsEmpty) {
this.data({
messageKey: 'emptyAttr'
});
return false;
}
return true;
}

export default attrNonSpaceContentEvaluate;
5 changes: 4 additions & 1 deletion lib/checks/shared/non-empty-alt.json
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,10 @@
"impact": "critical",
"messages": {
"pass": "Element has a non-empty alt attribute",
"fail": "Element has no alt attribute or the alt attribute is empty"
"fail": {
"noAttr": "Element has no alt attribute",
"emptyAttr": "Element has an empty alt attribute"
}
}
}
}
5 changes: 4 additions & 1 deletion lib/checks/shared/non-empty-placeholder.json
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,10 @@
"impact": "serious",
"messages": {
"pass": "Element has a placeholder attribute",
"fail": "Element has no placeholder attribute or the placeholder attribute is empty"
"fail": {
"noAttr": "Element has no placeholder attribute",
"emptyAttr": "Element has an empty placeholder attribute"
}
}
}
}
5 changes: 4 additions & 1 deletion lib/checks/shared/non-empty-title.json
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,10 @@
"impact": "serious",
"messages": {
"pass": "Element has a title attribute",
"fail": "Element has no title attribute or the title attribute is empty"
"fail": {
"noAttr": "Element has no title attribute",
"emptyAttr": "Element has an empty title attribute"
}
}
}
}
5 changes: 4 additions & 1 deletion lib/checks/shared/non-empty-value.json
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,10 @@
"impact": "critical",
"messages": {
"pass": "Element has a non-empty value attribute",
"fail": "Element has no value attribute or the value attribute is empty"
"fail": {
"noAttr": "Element has no value attribute",
"emptyAttr": "Element has an empty value attribute"
}
}
}
}
13 changes: 9 additions & 4 deletions test/checks/shared/non-empty-alt.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,28 +4,33 @@ describe('non-empty-alt', function() {
var fixture = document.getElementById('fixture');
var checkSetup = axe.testUtils.checkSetup;
var checkEvaluate = axe.testUtils.getCheckEvaluate('non-empty-alt');
var checkContext = axe.testUtils.MockCheckContext();

afterEach(function() {
fixture.innerHTML = '';
checkContext.reset();
});

it('should return true if an alt is present', function() {
var params = checkSetup('<img id="target" alt="woohoo" />');
assert.isTrue(checkEvaluate.apply(null, params));
assert.isTrue(checkEvaluate.apply(checkContext, params));
});

it('should return false if an alt is not present', function() {
var params = checkSetup('<img id="target" />');
assert.isFalse(checkEvaluate.apply(null, params));
assert.isFalse(checkEvaluate.apply(checkContext, params));
assert.equal(checkContext._data.messageKey, 'noAttr');
});

it('should return false if an alt is present, but empty', function() {
var params = checkSetup('<img id="target" alt=" " />');
assert.isFalse(checkEvaluate.apply(null, params));
assert.isFalse(checkEvaluate.apply(checkContext, params));
assert.equal(checkContext._data.messageKey, 'emptyAttr');
});

it('should collapse whitespace', function() {
var params = checkSetup('<img id="target" alt=" \t \n \r \t \t\r\n " />');
assert.isFalse(checkEvaluate.apply(null, params));
assert.isFalse(checkEvaluate.apply(checkContext, params));
assert.equal(checkContext._data.messageKey, 'emptyAttr');
});
});
13 changes: 9 additions & 4 deletions test/checks/shared/non-empty-placeholder.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,34 +4,39 @@ describe('non-empty-placeholder', function() {
var fixture = document.getElementById('fixture');
var checkSetup = axe.testUtils.checkSetup;
var checkEvaluate = axe.testUtils.getCheckEvaluate('non-empty-placeholder');
var checkContext = axe.testUtils.MockCheckContext();

afterEach(function() {
fixture.innerHTML = '';
checkContext.reset();
});

it('should return true if a placeholder is present', function() {
var params = checkSetup('<input id="target" placeholder="woohoo" />');

assert.isTrue(checkEvaluate.apply(null, params));
assert.isTrue(checkEvaluate.apply(checkContext, params));
});

it('should return false if a placeholder is not present', function() {
var params = checkSetup('<input id="target" />');

assert.isFalse(checkEvaluate.apply(null, params));
assert.isFalse(checkEvaluate.apply(checkContext, params));
assert.equal(checkContext._data.messageKey, 'noAttr');
});

it('should return false if a placeholder is present, but empty', function() {
var params = checkSetup('<input id="target" placeholder=" " />');

assert.isFalse(checkEvaluate.apply(null, params));
assert.isFalse(checkEvaluate.apply(checkContext, params));
assert.equal(checkContext._data.messageKey, 'emptyAttr');
});

it('should collapse whitespace', function() {
var params = checkSetup(
'<input id="target" placeholder=" \t \n \r \t \t\r\n " />'
);

assert.isFalse(checkEvaluate.apply(null, params));
assert.isFalse(checkEvaluate.apply(checkContext, params));
assert.equal(checkContext._data.messageKey, 'emptyAttr');
});
});
13 changes: 9 additions & 4 deletions test/checks/shared/non-empty-title.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,34 +4,39 @@ describe('non-empty-title', function() {
var fixture = document.getElementById('fixture');
var checkSetup = axe.testUtils.checkSetup;
var checkEvaluate = axe.testUtils.getCheckEvaluate('non-empty-title');
var checkContext = axe.testUtils.MockCheckContext();

afterEach(function() {
fixture.innerHTML = '';
checkContext.reset();
});

it('should return true if a title is present', function() {
var params = checkSetup('<img id="target" title="woohoo" />');

assert.isTrue(checkEvaluate.apply(null, params));
assert.isTrue(checkEvaluate.apply(checkContext, params));
});

it('should return false if a title is not present', function() {
var params = checkSetup('<img id="target" />');

assert.isFalse(checkEvaluate.apply(null, params));
assert.isFalse(checkEvaluate.apply(checkContext, params));
assert.equal(checkContext._data.messageKey, 'noAttr');
});

it('should return false if a title is present, but empty', function() {
var params = checkSetup('<img id="target" title=" " />');

assert.isFalse(checkEvaluate.apply(null, params));
assert.isFalse(checkEvaluate.apply(checkContext, params));
assert.equal(checkContext._data.messageKey, 'emptyAttr');
});

it('should collapse whitespace', function() {
var params = checkSetup(
'<img id="target" title=" \t \n \r \t \t\r\n " />'
);

assert.isFalse(checkEvaluate.apply(null, params));
assert.isFalse(checkEvaluate.apply(checkContext, params));
assert.equal(checkContext._data.messageKey, 'emptyAttr');
});
});
12 changes: 8 additions & 4 deletions test/checks/shared/non-empty-value.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ describe('non-empty-value', function() {
var fixture = document.getElementById('fixture');
var checkSetup = axe.testUtils.checkSetup;
var checkEvaluate = axe.testUtils.getCheckEvaluate('non-empty-value');
var checkContext = axe.testUtils.MockCheckContext();

afterEach(function() {
fixture.innerHTML = '';
Expand All @@ -12,26 +13,29 @@ describe('non-empty-value', function() {
it('should return true if an value is present', function() {
var params = checkSetup('<input id="target" value="woohoo" />');

assert.isTrue(checkEvaluate.apply(null, params));
assert.isTrue(checkEvaluate.apply(checkContext, params));
});

it('should return false if an value is not present', function() {
var params = checkSetup('<input id="target" />');

assert.isFalse(checkEvaluate.apply(null, params));
assert.isFalse(checkEvaluate.apply(checkContext, params));
assert.equal(checkContext._data.messageKey, 'noAttr');
});

it('should return false if an value is present, but empty', function() {
var params = checkSetup('<input id="target" value=" " />');

assert.isFalse(checkEvaluate.apply(null, params));
assert.isFalse(checkEvaluate.apply(checkContext, params));
assert.equal(checkContext._data.messageKey, 'emptyAttr');
});

it('should collapse whitespace', function() {
var params = checkSetup(
'<input id="target" value=" \t \n \r \t \t\r\n " />'
);

assert.isFalse(checkEvaluate.apply(null, params));
assert.isFalse(checkEvaluate.apply(checkContext, params));
assert.equal(checkContext._data.messageKey, 'emptyAttr');
});
});

0 comments on commit 5f822f4

Please sign in to comment.