When working with accessibility, it is important to have tools that will allow you to test current accessibility features.
Based on the currently available tools, we can define them as:
- Testing tools
- Verification tools
Testing tools are tools that can be used in standard testing like; UI testing. On the other hand, verification tools give us information about the current accessibility implementation status.
On iOS, we can support both testing and verification tools. When talking about testing tools, we will cover the tools that can be used as a part of UI testing; while talking about verification tools, we will cover the tool which is a part of the Xcode to verify the current status of the application (or screen of the application).
To test the accessibility features of our application, UI tests need to be written. Apple does not provide a specific framework or tool to test accessibility features by default.
Still, with well-written UI tests, we can test accessibility features like labels, the touch area, size of the element, etc.
Most of those checks are not just accessibility-related, but they can give us information if we provide or create an interface as defined by design.
final class LoginAccessibilityTests: XCTest {
let applicatioon = XCUIApplication()
override func setUp() {
// ... navigate to the login page
}
func testSubmitButton() {
let submitButton = application.buttons["Submit"]
XCTAssert(button.frame.size.height == 50)
...
}
}
To make XCUI tests a bit better, Google provides its framework, which can help get more information about the accessibility state of the particular screen.
They developed the framework called GTXiLib. GTXiLib provides many helper methods and feedback about current elements on the screen. Also, based on the accessibility status of the component, the test can fail.
The great thing about GTXiLib is that it will provide additional feedback if some component does not have an accessibility label, if the touch target size is too small, etc.
While two previous tools were testing tools where some implementation was needed to get feedback about the accessibility state of the application, Accessibility Inspector does not require any implementation.
Accessibility Inspector is a tool already included in Xcode, and when used, it can inspect the currently active screen and components. We can get information about accessibility implementation and other accessibility features like contrast, hit area, unsupported dynamic font size, etc.
Xcode inspector is available in the Xcode by Xcode > Open Developer Tools... > Accessibility Inspector.
In this document, the usage of component identifiers like accessibilityIdentifier
or resourceId
is not defined because they are not used for accessibility features but rather for automation testing.
Flutter apps can be tested for accessibility in the same way as native apps. On Android with the Accessibility Scanner, and on iOS with Accessibility Inspector.
⎯