automate 0.1.9-preview
See the version list below for details.
dotnet tool install --global automate --version 0.1.9-preview
dotnet new tool-manifest # if you are setting up this repo dotnet tool install --local automate --version 0.1.9-preview
#tool dotnet:?package=automate&version=0.1.9-preview&prerelease
nuke :add-package automate --version 0.1.9-preview
┌─┐┬ ┬┌┬┐┌─┐┌┬┐┌─┐┌┬┐┌─┐
├─┤│ │ │ │ ││││├─┤ │ ├┤
┴ ┴└─┘ ┴ └─┘┴ ┴┴ ┴ ┴ └─┘
Question to a Team Developer:
What if I gave you a command line tool, that wrote a lot of your code for you? and it took about ~5 commands (or so)? to build an API endpoint, or all the scaffolding for a UI page?
- You would use this tool once per API or once per UI page.
Question to the Team's Tech Lead:
What if I gave you a command line tool, that built that command line tool for your developer? and it took about ~15 commands (or so) to build it?
- You would only need to do this once per codebase you work together on.
What if that command line tool was updated (by you) as the codebase evolved? and it refactored and automatically fixed the code for the developer automatically over time?
What if you had a library of these tools for this codebase and others that you work on?
What is Automate?
Automate is a tool for Tech Leads, Lead Developers or Tech Consultants to give their fellow codebase contributors dev tools that capture and apply their coding patterns consistently across to their codebases, as they evolve and change.
How does it work?
It works like this:
- You identify a pattern in your codebase. eg. It might be a layer pattern (an interface) or a vertical slice pattern (a domain pattern), or a way to compose certain components together that is done similarly in multiple places.
- You pick (from your codebase) the files and folders where the code exists for this pattern right now.
- Those files are automatically extracted for you into a template.
- You name the pattern, and you define some attributes for it. The things that could be variable in it, when it gets used elsewhere in the codebase. (eg: the names of functions, classes, types, file, folders in the pattern etc.)
- You modify the templates to add substitutions (and calculations) for the attributes that you defined, that will be executed when the template is rendered.
- You can define automation commands that can be executed on the codebase before and after the template is applied. eg. you want to run some automated tests to verify the code has not been broken.
- Optionally, you define constraints about where the pattern can be re-used in a codebase (eg. only in certain languages etc).
- You publish your pattern. A toolkit is automatically built for you containing this template, and containing a custom executable tool (CLI or IDE plugin) to help apply it onto another codebase.
- You ship this toolkit to your dev teams to use.
- They download and run the toolkit (CLI or IDE plugin), and they construct an instance of the template and fill values for the attributes that were defined in it, configured for their specific use case and their codebase.
- The toolkit renders the template into: code, files, folders etc, into their codebase automatically.
Dealing with change
At some point later, you will want to update the pattern. Refactor it, modify it, or fix a defect in it, or just add new capabilities to it etc.
- You edit the pattern, edit or add more templates, optionally change the commands and change the constraints.
- An upgraded toolkit version is created for you automatically containing this upgrade.
- You ship this upgraded toolkit to your team to use.
- They download and run the upgraded toolkit (CLI or IDE plugin) and upgrade their codebase.
- The toolkit automatically detects the previous files/folders that were written before, and detects the previous attribute configuration that was used before. The toolkit re-applies the upgraded pattern. The codebase evolves.
Does automate apply to you?
If these assumptions about your software team are all true, then you might consider taking a look at this tool.
You work on a codebase with others - you are working in a software team.
You are the Tech Lead/Lead Dev/Tech Consultant of the team. (or have some other well respected, position of responsibility in the team).
You contribute code yourself to this codebase, and you communicate often with others on your team about the code.
You have some coding patterns, or can create some coding patterns, that are worth sharing in this specific codebase.
Your team values: consistency, clarity, and maintainability.
You accept that you can be wrong sometimes, and that your codebase necessarily changes over time.
If this sounds like your situation then maybe we can help you define (and enforce) some codebase specific coding patterns for your team to reuse.
Getting Started
See our Documentation for more details on each of the commands below.
Install the automate tool:
- Installers are here:
https://github.com/jezzsantos/automate/releases
- Otherwise, if .NET installed:
dotnet tool install --global automate
- Installers are here:
Navigate to your codebase, and harvest your first pattern from it:
automate create pattern "MyPattern1"
Add attributes, code templates, and automation to make it programmable:
automate edit add-attribute "Name" --isrequired
automate edit add-codetemplate "Controllers/BookingController.cs"
automate edit add-codetemplate-command "CodeTemplate1" --withpath "~/Controllers/{{name}}Controller.cs"
automate edit add-command-launchpoint "*" --name "Generate"
Edit the contents of the code template:
- Edit the codetemplate located at:
automate/patterns/<PATTERNID>/CodeTemplates/<CODETEMPLATEID>.cs
- Add the following snippet somewhere in this file:
Here is the {{name}}Contoller.
- Save the file
Generate the toolkit for this pattern, to share with others on your team:
automate build toolkit
this will build, version a self-contained toolkit file, and will export it to the desktop on your machine.
Share the toolkit file over email/slack/etc with someone on your team.
Now that person, can:
Install the automate tool:
- Installers are here:
https://github.com/jezzsantos/automate/releases
- Otherwise, if .NET installed:
dotnet tool install --global automate
- Installers are here:
Install the toolkit, fetched from above (i.e email/slack/etc):
automate install toolkit "<DOWNLOADLOCATION>/MyPattern1_0.1.0.toolkit"
- Create a new 'Solution' from this installed toolkit:
automate configure on "{MyPattern1}" --and-set "Name=Banana"
- Now run the automation:
automate execute command "Generate"
this command will generate the code from the code template into the destination folder (--withpath
), using the value of theName
property which you configured asBanana
- If you now open that generated file, you will see the value of
Banana
in the contents of the file.
The pattern and code templates can now be edited (by its author), and the toolkit can be rebuilt and redeployed (by its author).
It can be reinstalled (by its user) to rewrite any new and improved code, using the changes in the toolkit.
Learn more
At present we are in a validation stage. Validation, viability and research work is captured in the docs
and discovery
folders.
There is a detailed prototype walkthrough available which you can follow: prototype scenario to see how things are done.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 is compatible. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
This package has no dependencies.
Version | Downloads | Last updated |
---|---|---|
1.3.1 | 130 | 10/30/2024 |
1.3.0 | 332 | 5/14/2023 |
1.2.0 | 193 | 5/7/2023 |
1.1.0 | 503 | 11/5/2022 |
1.0.7 | 492 | 10/29/2022 |
1.0.5 | 478 | 10/15/2022 |
1.0.4 | 519 | 10/3/2022 |
1.0.3 | 502 | 9/28/2022 |
1.0.2 | 472 | 9/25/2022 |
1.0.1 | 498 | 9/19/2022 |
0.2.7-preview | 261 | 8/9/2022 |
0.2.6-preview | 250 | 7/3/2022 |
0.2.5-preview | 218 | 6/20/2022 |
0.2.4-preview | 215 | 6/17/2022 |
0.2.3-preview | 279 | 6/12/2022 |
0.2.2-preview | 289 | 6/9/2022 |
0.2.1-preview | 336 | 6/5/2022 |
0.2.0-preview | 265 | 6/4/2022 |
0.1.13-preview | 276 | 5/31/2022 |
0.1.12-preview | 240 | 5/29/2022 |
0.1.11-preview | 257 | 5/27/2022 |
0.1.10-preview | 256 | 5/17/2022 |
0.1.9-preview | 263 | 5/16/2022 |
0.1.8-preview | 255 | 4/25/2022 |
0.1.7-preview | 252 | 3/28/2022 |
0.1.6-preview | 317 | 3/18/2022 |
0.1.5-preview | 264 | 3/11/2022 |
0.1.4-preview | 264 | 3/6/2022 |
0.1.1-preview | 285 | 2/23/2022 |