This repository provides a ready-to-go CI/CD workflow for KiCad with GitHub actions.
- Integration with GitHub releases to automatically produce documentation and fabrication files on every GitHub release, including automatic date and version stamping of schematics and PCBs.
- KiBot preflighting on every pull request (ERC/DRC checks disabled by default).
- VSCode dev container and default build task for easy local testing of KiBot scripts.
To create a KiCad project using this GitHub template:
- Hit the Use this template button then follow the steps from GitHub to create a copy of the repo. The repository name must exactly match the name of the KiCad project. Do not use spaces in either the repository or the project name.
- Clone the new repo locally.
- Go to File > New > Project... in KiCad.
- Name the project the exact same name as the GitHub repository name.
- Uncheck the Create a new directory for this project option. This is very important!
- Save the project into the top level of the folder for the GitHub repository.
Do not use spaces in the GitHub repository or KiCad project name. Use underscores or hyphens instead, for example TBM930_De-Ice_-_Panel
or Collins-FMS-3000
.
If you've done all the steps correctly the folder structure will look similar like this:
Notice that the folder name (which is also the GitHub repo name) and project name are exactly the same and there are no spaces.
The GitHub automation can automatically set the date and version number in the generated schematic and PCBs. Before using this make sure
to set the timezone to your local timezone in the .github\workflows\documentation-only.yml
and .github\workflows\release.yml
files.
Version number and date replacement is done on the %%version%%
and %%date%%
string wherever they appear in your .sch
and .kicad_pcb
files.
Typically you will use them in the Page settings dialog for the schematic and as text in silkscreen and/or copper layers on your board:
The following documents are generated on every release build:
- Interactive BOM - HTML
- Schematic - PDF
- PCB front copper and explanatory drawings layers - PDF
- PCB back copper and explanatory drawings layers - PDF
- 3D render - STEP
- PCB front - JPEG
- PCB back - JPEG
These documents can also be generated by manually running the KiBot - Generate documentation
action on GitHub.
The following fabrication files are generated on every release build:
- JLCPCB gerbers and drill files, with BOM and placement files for SMT service
- PCBWay gerbers and drill files
The fabrication files can also be generated by manually running the KiBot - Release
action on GitHub.
A complete CodeTour is included in this repository that walks through all the components of how KiBot scripts and GitHub actions work. Use github.dev to view the CodeTour!
This repository template includes the files necessary to run in a VSCode dev container, which dramatically reduces the effort required to use KiBot on Windows machines.
Never used VSCode remote containers before on Windows? Here's how to get set up:
- From a PowerShell install WSL2 with this command:
wsl --install
- Install Visual Studio Code and Docker Desktop(https://www.docker.com/products/docker-desktop)
- Install the Remote Containers extension for VSCode
When installing Docker Desktop you may be told you have to enable virtualization in your computer's BIOS. Setting that up is outside the scope of this readme but isn't hard. Just do a web search for your motherboard for how to enter the BIOS and what the exact name of the setting is, then turn it on.