AppVeyor and python formatting
10x learner
Posted on March 31, 2022
Hello ! Iβm Xavier Jouvenot and in this small post, I am going to explain how to automatically check if your python code is well formatted with AppVeyor.
Self promotion: Here are a few social networks where you can follow me and check my work as a programmer and a writer π
personal website, Twitter, Dev.to, CodeNewbie, Medium, GitHub
Problematic
Today, we are going to focus on how we can automatically check if the python code you are versioning is well formatted, and more specifically, how you can use AppVeyor to do so. To automate this process will make your team more efficient and the code more consistent since everyone will have to be on board and format their code each time they want to contribute.
If you are not convinced that you should format you code, I really encourage you to go look at the previous article I did on Formatting and Automation, where I go in detail on why you should definitively format your code, and do it in a automatic way, to make your code more readable and make your team more productive since they wonβt have to spend time arguing about Spaces VS Tabs, for example.
Solution
The short answer, for the people who donβt want to read through the entire article (I know you do that! I do it too π) is to insert the following steps in your AppVeyor process:
install:
- pip3 install black
build_script:
- black --check .
If you have my previous article about "Formatting Python β Why and How !", you may already know about about the tool named black. For those who donβt know, this is a code formatter, described by its authors as follow:
Black is the uncompromising Python code formatter. By using it, you agree to cede control over minutiae of hand-formatting. In return, Black gives you speed, determinism, and freedom from pycodestyle nagging about formatting. You will save time and mental energy for more important matters.
In the steps above, I start by installing this tool with the python package manager pip. Then, I run black
at the root of the folder, meaning that it is going to find all the Python files in repository and, since we are using the flag --check
, verify if they are well formatted. If one Python file is not formatted correctly, then, the black command will return an error, and the corresponding step in AppVeyor will fail.
If you want, you can specify directly the list of the Python files, instead of letting the tool scan through all the repository recursively. π
Finally, it is important to specify that those steps work only on a majority of the environments available in AppVeyor. Indeed, black only works with the version Python 3.6 and above which is not the default version on some AppVeyor environments. On Windows and Ubuntu environments, you will have to first update the default version of Python used by the environment before being able to run black on your Python code. You can take a look at this script, to see how I have done it when working on this article π
I actually made a GitHub repository in which I setup AppVeyor to run the steps described before on every environment available. You can take a look here as I will update it when new environment will be available on AppVeyor π
Thank you all for reading this article, And until my next article, have a splendid day π
Interesting links
- GitHub repository with the actual working code up to date, and the Azure Pipelines jobs runned
- AppVeyor Windows, Linux, and MacOs environments
- black GitHub repository, documentation and python package
- Python website
- pip website
- 10xlearner website, Twitter, Dev.to, CodeNewbie, Medium, GitHub
Posted on March 31, 2022
Join Our Newsletter. No Spam, Only the good stuff.
Sign up to receive the latest update from our blog.