bbc/bbc-a11y

Doctype not validating correctly

murkas opened this issue · 4 comments

Summary

When running the a11y tests, against the following URL: http://bbcthree-web-server.int.api.bbc.co.uk/bbcthree?usestubdata validation fails, reporting the following error: Validation: All documents must have a W3C recommended doctype - Missing w3c recommended doctype. Upon inspection, the tested URL does have a doctype.

Expected Behaviour

In this case I would expect the test to pass, as the page's doctype is as follows <!doctype html>.

Current Behaviour

As of current the test fails with the following error, reporting that a valid w3c doctype is not present.

✗ http://bbcthree-web-server.int.api.bbc.co.uk/bbcthree?usestubdata
  * Validation: All documents must have a W3C recommended doctype
    - Missing w3c recommended doctype

Possible Solution

I believe that this may be failing due to a potential issue with the test.

Currently, if (!$('html')[0].ownerDocument.doctype) is used to check for the presence of a doctype.

Upon pasting a snippet of this into Chrome's developer tools console undefined is returned, despite the doctype being present on page.

I have experimented with this for a short amount of time and found that the following works in retrieving the doctype: $('html').ownerDocument.doctype. Hopefully this could help with rectifying the failure? Please let me know if I have missed something/am misunderstanding what is likely going on here.

Steps to Reproduce (for bugs)

  1. Run a11y tests against https://www.int.bbc.co.uk/bbcthree?usestubdata
  2. Observe error (please ignore the numerous others, we are going to fix them!)
  3. Inspect page in dev tools to confirm presence of doctype.

Context & Motivation

This occurred whilst inspecting the BBC Three website in order to document potential improvements to the site.

Your Environment

Version(s) used: 1.4.0 & 2.1.0
OS: MacOS High Sierra
Project Link: https://github.com/bbc/bbcthree-web

Hope that the explanation of this issue is in depth enough - please let me know if more is required or if a demo would help!

Hi @marcusBBC

I just tried with bbc-a11y 2.1.0 and I did not get an error about the doctype:

> ./bin/bbc-a11y.js http://bbcthree-web-server.int.api.bbc.co.uk/bbcthree?usestubdata
✗ http://bbcthree-web-server.int.api.bbc.co.uk/bbcthree?usestubdata
  * Design: Content resizing: Text must be styled with units that are resizable in all browsers
    - Text styled with px unit: //div[@id='bbcprivacy-prompt']/h2
    - Text styled with px unit: //button[@id='bbcprivacy-continue-button']
    - Text styled with px unit: //span[@id='secondary-nav-label']
    - Text styled with px unit: //main[@id='content']/div[2]/div[1]/div/ul/li[1]/a/div[1]/h3
    - Text styled with px unit: //main[@id='content']/div[2]/div[1]/div/ul/li[2]/a/div[1]/h3
    - Text styled with px unit: //main[@id='content']/div[2]/div[1]/div/ul/li[3]/a/div[1]/h3
    - Text styled with px unit: //h2[@id='best-of-grid-header']
    - Text styled with px unit: //div[@id='best-of']/ul/li[1]/a/div/div/div/div[1]/div[2]/span
    - Text styled with px unit: //div[@id='best-of']/ul/li[1]/a/div/div/div/div[2]/h3
    - Text styled with px unit: //div[@id='best-of']/ul/li[2]/a/div/div/div/div[2]/h3
    - Text styled with px unit: //div[@id='best-of']/ul/li[3]/a/div/div/div/div[2]/h3
    - Text styled with px unit: //div[@id='best-of']/ul/li[4]/a/div/div/div/div[1]/div[2]/span
    - Text styled with px unit: //div[@id='best-of']/ul/li[4]/a/div/div/div/div[2]/h3
    - Text styled with px unit: //div[@id='best-of']/ul/li[5]/div/div/div/a/div[2]/h3
    - Text styled with px unit: //div[@id='best-of']/ul/li[5]/div/div/div/a/div[2]/div[1]
    - Text styled with px unit: //div[@id='best-of']/ul/li[5]/div/div/div/a/div[2]/div[2]/span
    - Text styled with px unit: //div[@id='best-of']/ul/li[6]/a/div/div/div/div[1]/div[2]/span
    - Text styled with px unit: //div[@id='best-of']/ul/li[6]/a/div/div/div/div[2]/h3
    - Text styled with px unit: //div[@id='best-of']/ul/li[7]/a/div/div/div/div[1]/div[2]/span
    - Text styled with px unit: //div[@id='best-of']/ul/li[7]/a/div/div/div/div[2]/h3
    - Text styled with px unit: //div[@id='best-of']/ul/li[9]/a/div/div/div/div[1]/div[2]/span
    - Text styled with px unit: //div[@id='best-of']/ul/li[9]/a/div/div/div/div[2]/h3
    - Text styled with px unit: //div[@id='orb-modules']/div/footer/div[1]/h2
    - Text styled with px unit: //div[@id='orb-modules']/div/footer/div[2]/div/div/div[1]/p
    - Text styled with px unit: //div[@id='orb-modules']/div/footer/div[2]/div/div/div[2]/div/a
    - Text styled with px unit: //div[@id='orb-aside']/div/h2
    - Text styled with px unit: //div[@id='orb-aside']/div/div/ul/li[1]/a
    - Text styled with px unit: //div[@id='orb-aside']/div/div/ul/li[2]/a
    - Text styled with px unit: //div[@id='orb-aside']/div/div/ul/li[3]/a
    - Text styled with px unit: //div[@id='orb-aside']/div/div/ul/li[4]/a
    - Text styled with px unit: //div[@id='orb-aside']/div/div/ul/li[5]/a
    - Text styled with px unit: //div[@id='orb-aside']/div/div/ul/li[6]/a
    - Text styled with px unit: //div[@id='orb-aside']/div/div/ul/li[7]/a
    - Text styled with px unit: //div[@id='orb-aside']/div/div/ul/li[8]/a
    - Text styled with px unit: //div[@id='orb-aside']/div/div/ul/li[9]/a
    - Text styled with px unit: //div[@id='orb-aside']/div/div/ul/li[10]/a
    - Text styled with px unit: //div[@id='orb-aside']/div/div/ul/li[11]/a
    - Text styled with px unit: //div[@id='orb-aside']/div/div/ul/li[12]/a
    - Text styled with px unit: //div[@id='orb-aside']/div/div/ul/li[13]/a
    - Text styled with px unit: //div[@id='orb-aside']/div/div/ul/li[14]/a
    - Text styled with px unit: //div[@id='orb-aside']/div/div/ul/li[15]/a
    - Text styled with px unit: //div[@id='orb-aside']/div/div/ul/li[16]/a
    - Text styled with px unit: //div[@id='orb-aside']/div/div/ul/li[17]/a
    - Text styled with px unit: //div[@id='orb-aside']/div/div/ul/li[18]/a
    - Text styled with px unit: //div[@id='orb-contentinfo']/div/ul/li[1]/a
    - Text styled with px unit: //div[@id='orb-contentinfo']/div/ul/li[2]/a
    - Text styled with px unit: //div[@id='orb-contentinfo']/div/ul/li[3]/a
    - Text styled with px unit: //div[@id='orb-contentinfo']/div/ul/li[4]/a
    - Text styled with px unit: //div[@id='orb-contentinfo']/div/ul/li[5]/a
    - Text styled with px unit: //div[@id='orb-contentinfo']/div/ul/li[6]/a
    - Text styled with px unit: //div[@id='orb-contentinfo']/div/ul/li[7]/a
    - Text styled with px unit: //div[@id='orb-contentinfo']/div/ul/li[8]/a
    - Text styled with px unit: //div[@id='orb-contentinfo']/div/small
    - Text styled with px unit: //div[@id='orb-contentinfo']/div/small/em
    - Text styled with px unit: //div[@id='orb-contentinfo']/div/small/span/a
  * Forms: Managing focus: Forms must have submit buttons
    - Form has no submit button: //form[@id='orb-search-form']
  ⚠ Structure: Headings: Headings must be in ascending order
    - First heading was not a main heading: //div[@id='bbcprivacy-prompt']/h2
  * Structure: Headings: Exactly one main heading
    - Found 0 h1 elements.
  * Text equivalents: Alternatives for non-text content: Images must have alt attributes
    - Image has no alt attribute: //div[@id='best-of']/ul/li[1]/a/div/div/div/div[1]/div[1]/img
    - Image has no alt attribute: //div[@id='best-of']/ul/li[2]/a/div/div/div/div[1]/div/img
    - Image has no alt attribute: //div[@id='best-of']/ul/li[3]/a/div/div/div/div[1]/div/img
    - Image has no alt attribute: //div[@id='best-of']/ul/li[4]/a/div/div/div/div[1]/div[1]/img
    - Image has no alt attribute: //div[@id='best-of']/ul/li[5]/div/div/div/a/div[1]/img
    - Image has no alt attribute: //div[@id='best-of']/ul/li[6]/a/div/div/div/div[1]/div[1]/img
    - Image has no alt attribute: //div[@id='best-of']/ul/li[7]/a/div/div/div/div[1]/div[1]/img
    - Image has no alt attribute: //div[@id='best-of']/ul/li[8]/div/div/div/div[2]/img
    - Image has no alt attribute: //div[@id='best-of']/ul/li[9]/a/div/div/div/div[1]/div[1]/img
    - Image has no alt attribute: //div[@id='best-of']/ul/li[10]/div/div/div/div[2]/img

For details on how to fix these errors, please see the following pages:
  - http://www.bbc.co.uk/guidelines/futuremedia/accessibility/mobile/design/content-resizing
  - http://www.bbc.co.uk/guidelines/futuremedia/accessibility/mobile/forms/managing-focus
  - http://www.bbc.co.uk/guidelines/futuremedia/accessibility/mobile/structure/headings
  - http://www.bbc.co.uk/guidelines/futuremedia/accessibility/mobile/text-equivalents/alternatives-for-non-text-content
1 page checked, 67 errors found, 1 warning, 0 standards skipped

Running $('html')[0].ownerDocument.doctype in Chrome will give you something different from bbc-a11y, because in that line of code in bbc-a11y, $ is jQuery, but in Chrome it's not. If you make $ actually jQuery and then run $('html')[0].ownerDocument.doctype, you get a doctype for this page.

How did you install bbc-a11y 2.1.0? Do you still have the issue if you do a full clean install?

I believe that this may have been an environment issue as I cannot recreate the issue at this point - apologies for that. Would you be happy for me to close this issue, given that?

Closing issue as the reporter is no longer able to reproduce.