rafe is a tool for inspecting python environments and building packages (irrespective of language) in a reproducible manner.
To press a fresh rafe wheel from source, simply run:
python setup.py bdist_wheel
And the wheel should be available in the dist/
folder.
To install rafe, simply pip install the wheel
pip install <wheel>
Before starting to use rafe, it needs to generate a configuration. Do this by running:
rafe config --init
Now, you can use rafe however you'd like. Note that you can call it in two ways:
python -m rafe
rafe
Both are valid.
Assuming you have already run rafe config --init
you will have the folder .rafe/work/
- place your git repo folder there, such that numpy would be at .rafe/work/numpy/
With this in place you should next run
python rafe check-api-breaks --package numpy --old v1.12.1 --new v1.17.5`
In older griffe versions, if you are given a git branch error, you'll need to clean up the griffe created branches before rerunning. E.g. git branch -D griffe_v1.12.1
from the appropriate folder
It has been verified that this is no longer an issue with griffe v0.30.1 (last to support py3.7)
Once you have run the above you should be able to run the verify pass (for objects removed) using the command below:
python rafe verify-breaks --package numpy --path ./numpy_objects_removed.json`
This will attempt to eval a hasattr()
for each of the missing items, and where it fails it may attempt to import the missing attribute and try again. The resulting numpy_actual_misses.json
should be much closer to the truth.