The Pa11y User Survey 2017 results
We wanted to find out more about how our users use our tools, what sort of things people think we’re doing well, and what sort of things we could do better. So we decided to run a survey to learn how you feel about the four main Pa11y packages.
We ran the survey from August 15th to September 11th. Here’s what we learned about you!
Table of contents
- About our users
- Pa11y CLI
- Pa11y Dashboard
- Pa11y Webservice
- Pa11y CI
- What we plan to improve
- Conclusions
About our users
More than three quarters of our respondents are developers.
Over three quarters of our respondents use Pa11y for work.
20% of respondents use Pa11y only for personal projects, and 10% for both work and personal. There’s no particular pattern in the way our respondents use Pa11y and the way they describe their job roles.
Pa11y CLI
The Pa11y command line tool is the “core” tool. It’s a simple command line interface that loads a URL and an optional configuration file, then runs HTML Codesniffer to generate a report on any accessibility errors it finds.
Two thirds of respondents have used the Pa11y CLI.
Of those who haven’t used it, one third of respondents say that it’s too difficult to set up, and one third have simply never heard of it. The rest just don’t have a need for it.
Of those who have used Pa11y CLI, we asked how easy/hard it is to set up. None of these respondents found it very difficult, but otherwise there is an even spread across the easy-to-hard spectrum. Most of the respondents who have used Pa11y CLI are developers; we’d expect this for a command-line tool. Greater familiarity with the command line amongst this group will also skew the results towards the “easier” end of the spectrum.
Once set up, most people find Pa11y CLI easy to use. Those that found it more difficult tend to be doing more complex things with it, and overall people find it more difficult to integrate Pa11y CLI into their existing workflow.
When we asked “what would make Pa11y CLI easier for you to integrate with your workflow?”, some of our respondents who found Pa11y CLI a little harder to use and to integrate said the following:
Better examples for different situations -- integration with node or non-node apps.
multiple urls support
Command lines are inherently difficult
We also asked about things we could do to make Pa11y CLI easier to use and to set up. Although a lot of people suggested that the documentation could be improved, more people said that they’d find tutorials helpful. This makes a lot of sense - things become more difficult as you start doing more complex work that takes you away from the basic use cases in the documentation.
Ide Aderinokun’s recent post on accessibility testing with Pa11y was called out as being particularly helpful.
We asked people what they like about Pa11y CLI. Most of the responses were from developers, who already find it easier to use and to work with:
Simple and easy to use.
excellent
The ease of use and UNIX WIZARDY!
easier
I like the output of the errors, and the ability to just scan for certain errors in certain page sections.
We also asked people what they don’t like so much. Again, mostly developers responded.
Doesn't show all the issues up front.
limited
I'm currently evaluating if I like how thorough the scan is.
Pa11y Dashboard
The Pa11y Dashboard is our second most popular tool. It’s a web interface that uses Pa11y CLI to automatically run daily accessibility tests. The results are displayed as graphs to help users easily track improvements and regressions over time. The web front end provides a more accessible interface for non-developer stakeholders.
Half of our respondents have used Pa11y Dashboard.
Of those who haven’t used it, more than half have simply never heard of it. The majority of the others just don’t need it for their purposes. One respondent found it too difficult to set up or use.
The majority of respondents found Pa11y Dashboard easy to set up. Unlike Pa11y CLI there was no skew towards developers finding setup easier - developers were actually more likely to report difficulty in setting up than non developers. It’s not clear from the results why this might be.
Once set up, most people find the Dashboard easy to use and easy to integrate with their workflow.
We asked people what would make it easier for them to set up and use Pa11y Dashboard. Respondents overwhelmingly said they want better documentation. We also asked what would help better integrate Pa11y Dashboard with user workflows. Most respondents had specific features in mind that would help them get information to stakeholders, particularly for larger websites or collections of web properties.
email reports
Being able to sort elements on the dashboard, and having multiple dashboard "pages". In one page we could see all of our competition, in another our own site pages, if that makes sense
display all errors and issues
multiple urls support
We asked what people like about Pa11y Dashboard. Respondents find the visual comparisons helpful:
Graphs
great way to overview our sites and see historical reports
Ease of use
Seeing our errors go down, or stay at zero. Keeping an eye on the competition, being able to have a history of improvements we've made to the site
easy to glance at issues, more friendly to non-developers
Easy
We also asked what people don’t like so much about Pa11y Dashboard. Most of these respondents would like to see improvements to the UX of the dashboard itself. One user reported stability issues.
limited to last 30 days
Colours seems to be clashing.
If left alone it tends to fail (widgets not load any data)
not able to see all errors and issues
Limited
Pa11y Webservice
The Pa11y webservice is the JSON-based webservice that supports Pa11y Dashboard. It allows you to integrate Pa11y with existing dashboards, build your own dashboard-like front ends, or repurpose Pa11y report data for consumption by other services.
Less than a quarter of our respondents have used the Pa11y Webservice.
Reasons for not using the Webservice were varied, but most people (80%) just hadn’t heard of it. Others said that it doesn’t do what they need, or that another tool fits their purposes better.
The Webservice is supposed to complement DIY solutions to dashboard services, so we weren’t expecting many people to have used this on its own. Pa11y Dashboard uses the Webservice under the hood and so the Dashboard (being a complete solution) is what the majority of users are likely to be interested in.
Our respondents who have used the Pa11y Webservice report it mostly being easy to use and set up:
They also reported it as being middling at integrating with their workflow:
We asked these respondents what would make it easier to set up, use, and integrate Pa11y Webservice with their workflow. In all cases, our respondents (all self-identified as developers) wanted more complete documentation. The responses from these individuals strongly suggest that they’re power users who know precisely what they want to achieve with the tool.
Pa11y CI
Pa11y CI is a command-line tool that iterates over a list of web pages and runs Pa11y on them. It’s designed to make it easier to use Pa11y with your Continuous Integration software.
Almost 3 quarters of our respondents have never used Pa11y CI.
Of those respondents who have never used Pa11y CI, we asked for their reasons. Their responses were quite varied, but around 40% of respondents have never heard of it. A few respondents said they’d like to use it but just hadn’t got round to it yet. Pa11y CI is a comparatively new addition to our ecosystem, but the responses here are encouraging; people seem to like the idea of integrating Pa11y with their CI!
When we asked our respondents to tell us what would make them more likely to use Pa11y CI, they said things like this:
If we had better, easier, free CI tools
When I have time!!
More tutorials please :)
If I knew what it was!
Of the respondents who have used Pa11y CI, they reported finding it easy to set up and to use. Pa11y CI has mostly been used by developers and power users - as with the Pa11y command line tool, this skews the answers to this question towards the easier end of the scale.
Also in common with the Pa11y command line tool, when we asked what would make Pa11y CI easier to set up and use, tutorials came out as most-wanted. CI is a fairly complex ecosystem, and it oftens helps to be able to see how things fit together end-to-end.
We asked how easily Pa11y CI fits with our respondents workflows, with mixed results.
One respondent who found it more difficult to integrate with their workflow also reported to us that they work as a QA tester. They had a few suggestions that would help make Pa11y CI integrate more easily with their purposes:
HTML reporter output
errors in specified file
acceptance of relative paths in sitemap.xml
The boundaries between different IT job roles are becoming more blurred, and technology that used to be mostly used by developers is now reaching a much larger audience. In doing so, the technology also needs to be able to meet sometimes radically different use cases.
What we plan to improve
Documentation, tutorials, and alternatives
Since we launched the survey, we’ve made a number of improvements to the documentation for Pa11y and Pa11y Dashboard. This is an ongoing effort, but we feel that the documentation is in a pretty good place currently. We want to keep on improving that.
We’re always on the lookout for high quality tutorials from users, as the Pa11y user community has shown itself to be excellent at writing them! A well-structured tutorial is often the best way for a new user to get up to speed, and we recognise how useful they are. We’re collecting the most comprehensive tutorials we come across, and tweeting and linking out to them so that everyone can benefit.
Not everyone who is interested in accessibility has the kind of skills needed to work with Pa11y. Pa11y Dashboard solves this to an extent, but it still needs to be set up and run on a server, and that’s not feasible for everyone. For those users, a great option is Koa11y, by Pa11y contributor @thejaredwilcurt. Koa11y wraps Pa11y in an installable desktop app.
Code changes
Since we launched the survey, we developed the Actions interface, to provide an easier way for people to interact with their pages before running accessibility tests. On release, there was an immediate, dramatic decline in people needing support with interactions. The improvement in quality of life for our users since releasing Actions was so startling that we’ve decided to retire beforeScript()
for Pa11y 5. We recognise that this means we’ll need to add more Actions over time, and we’re actively seeking suggestions.
In Pa11y 5, we’ll be moving from PhantomJS to headless Chrome. The Pa11y 5.x beta is already available for you to try out now.
Pa11y Dashboard will be eventually retired, and replaced with its successor, codenamed Sidekick. One of the things we wanted to do with Sidekick was to change the architecture to remove the reliance on Pa11y Webservice. Instead of a web application backed by a separate webservice, Sidekick will be a single package that includes a REST API. We hope this will be much easier for users to work with when integrating with their usual workflow.
Conclusions
We didn’t encounter any major surprises - our GitHub Issues lists do a good job of showing us what the main preoccupations of our users are. We know that our documentation doesn’t always give users what they need, and we’re committed to improving that.
We’re pleased to see that most of our respondents like Pa11y and find that it works well for their purposes. Over the next year, we want to make it even better, and we’d love to have you along for the journey 😊
Thanks so much to everyone who took part in the survey, and a big thanks to all of our users and contributors - you all help make Pa11y what it is.