Skip to content

Latest commit

 

History

History
59 lines (41 loc) · 4.21 KB

README.md

File metadata and controls

59 lines (41 loc) · 4.21 KB

Guides

This section is intended to be a place where developers can add guides on different aspects of working with Alfa so that other developers can benefit from the knowledge shared.

Adding code

Remember to Add a change set to your pull requests if needed.

Investigating

Operations

  • How to Release a new version of Alfa.

Alfa structure

List of Alfa repositories, both public and private, and some of their particularities…

  • Alfa (this repository): The main repository for Alfa code.

  • Alfa integrations (public): Contains integrations of Alfa with various frameworks, including a Command Line Interface and the Accessibility Code Checker API.

    • The CLI, alfa-test-utils, and integrations with browsers automations are actively maintained. The other integrations are more dormant.
    • The packages are published still associated with the Alfa repository for historical reasons.
    • Alfa core packages are auto-updated by Renovate. Other dependencies of actively maintained packages also are.
    • Other packages are not auto-updated (except for security updates), notably due to the low amount of tests decreasing confidence in CI results.
    • Has very few tests overall, especially in the non actively maintained packages.
  • Alfa examples (public): Curated list of examples of Alfa usage.

    • Contains both "unit" examples of integrations, more end-to-end examples of integrations with Siteimprove Accessibility Code Checker, and some advanced usages of Alfa.
    • Alfa packages, and the ones needed for actively maintained integration, are automatically updated by Renovate.
  • Alfa ACT-R (public): Acceptance testing of Alfa rules against the ACT Rules test cases.

    • This mostly contains only tests and fixtures to run them…
    • All dependencies are auto updated by Renovate.
    • Test cases are auto-fetched every Monday morning from the W3C website, and implementation reports are automatically updated with the new test cases.
    • The published implementation reports are used to build the WAI implementation reports, updated every Thursday (see also nightly build snapshot).
    • We aim at maintaining the rules on par with the latest ACT Rules changes, so when these tests break and our implementation numbers decrease, we need to update the rules.
  • Alfa companion (private): Incubator for Alfa related projects before they make it to the main repository.

    • Low overall test coverage, this is mostly an experiment/incubator repo.
    • Auto update of Alfa and other packages via Renovate.
    • Can be used for experiments, both on code or on tooling, before deploying to the main Alfa repository and to production.
  • Alfa performance benchmarking (private): Set up for testing performance impact of changes.

    • Runs with a git submodule for Alfa, which allow to measure unreleased code. But must therefore live in its own repository.
    • Used for testing changes that may impact performances. It is possible to work on the Alfa submodule directly.
  • Sanshikan (private): Siteimprove's copy of ACT Rules, plus Siteimprove's own rules.

    • Only markdown (for the rules) and a bit of JSON (for the metadata). No actual code.
    • Metadata is published and used in Siteimprove platform and web extension.
  • Alfa Hub (private): Build a static website to show Sanshikan's rules; plus documentation for the Accessibility Code Checker.

    • Build a static website inside a Docker container.
    • The site is published at alfa.siteimprove.com, it is publicly available and serves as technical documentation for our rules.
    • Mostly ReactJS, plus processing of the markdown files.