Skip to content

Latest commit

 

History

History
executable file
·
293 lines (209 loc) · 10.7 KB

docs-nwpackageversions.md

File metadata and controls

executable file
·
293 lines (209 loc) · 10.7 KB

nwpackageversions

Contact: [email protected]

Revision History

Date Author Description
2024-10-07 numbworks Created.
2024-10-22 numbworks Updated to v1.1.0.
2024-10-24 numbworks Updated to v1.2.0.
2024-10-31 numbworks Updated to v1.6.0.
2024-12-01 numbworks Updated to v1.8.0.
2024-12-27 numbworks Updated to v1.8.1.

Introduction

nwpackageversions is a Python library that helps with retrieving package information from PyPi.org and comparing them with what you have installed locally.

Getting Started

To inspect the functionalities of this Python module on Windows and Linux:

  1. Download and install Visual Studio Code;

  2. Download and install Docker;

  3. Download and install Git;

  4. Open your terminal application of choice and type the following commands:

    mkdir nwpackageversions
    cd nwpackageversions
    git clone https://github.com/numbworks/nwpackageversions.git
    
  5. Launch Visual Studio Code and install the following extensions:

  6. In order for Pylance to perform type checking, click on File > Preferences > Settings and set the python.analysis.typeCheckingMode setting to basic;

  7. Click on File > Open folder > nwpackageversions;

  8. Click on View > Command Palette and type:

    > Dev Container: Reopen in Container
    
  9. Wait some minutes for the container defined in the .devcointainer folder to be built;

  10. Open the Python file (src/nwpackageversions.py);

  11. Done!

Demo

The primary purpose of this Python library is to simplify and strengthen the process of keeping all project dependencies up-to-date.

An interactive demo environment for the scenario above is provided in the attached Jupyter Notebook file (nwpackageversions.ipynb).

Unit Tests

To run the unit tests in Visual Studio Code (while still connected to the Dev Container):

  1. click on the Testing icon on the sidebar, right-click on tests > Run Test;
  2. select the Python interpreter inside the Dev Container (if asked);
  3. Done!

To calculate the total unit test coverage in Visual Studio Code (while still connected to the Dev Container):

  1. Terminal > New Terminal;

  2. Run the following commands to get the total unit test coverage:

    cd tests
    coverage run -m unittest nwpackageversionstests.py
    coverage report --omit=nwpackageversionstests.py
    
  3. Run the following commands to get the unit test coverage per class:

    cd tests
    coverage run -m unittest nwpackageversionstests.py
    coverage html --omit=nwpackageversionstests.py && sed -n '/<table class="index" data-sortable>/,/<\/table>/p' htmlcov/class_index.html | pandoc --from html --to plain && sleep 3 && rm -rf htmlcov
    
  4. Done!

Dependency Update

To check for the updatability of the dependencies this library is built upon, you can use the library itself. Please:

  1. Launch Visual Studio Code;

  2. Click on File > Open folder > nwpackageversions;

  3. Terminal > New Terminal;

  4. Run the following commands to perform the requirement check (it requires an internet connection):

    cd src
    python3
    from nwpackageversions import RequirementChecker
    RequirementChecker().check("/workspaces/nwpackageversions/.devcontainer/Dockerfile")
    
  5. You will get a log containing a list of up-to-date and out-of-date dependencies, that you can use to decide which update to perform.

  6. Done!

How-To Release

To try out if this Python module installs as a package as expected in the projects that have it as dependency, you'll need to simulate a release.

In order to do so:

  1. Once you pushed all the changes to Gihub and merged them to master, create a new release and add a version tag to it - i.e. v1.8.1;

  2. Open your terminal application of choice and type the following commands:

    docker run -it python:3.12.5-bookworm /bin/bash
    pip install 'git+https://github.com/numbworks/[email protected]#egg=nwpackageversions&subdirectory=src'
    pip show nwpackageversions | grep "Version"
    
  3. Perform an additional verification by using the Python interpreter in the container:

    python3
    from nwpackageversions import PyPiReleaseManager
    release_manager : PyPiReleaseManager = PyPiReleaseManager()
    exit()
    
  4. Exit from the container by typing exit;

  5. Remove the stopped container using the following commands:

    docker ps -a
    docker rm {container_id}
    
  6. Done!

Note: if something goes wrong, don't panic - Github releases can be deleted and re-created as many times as you want.

The makefile

This software package ships with a makefile that include all the pre-release verification actions:

  1. Launch Visual Studio Code;

  2. Click on File > Open folder > nwpackageversions;

  3. Terminal > New Terminal;

  4. Run the following commands:

    cd /workspaces/nwpackageversions/scripts
    make -f makefile <target_name>
    
  5. Done!

The avalaible target names are:

Target Name Description
type-verbose Runs a type verification task and logs everything.
coverage-verbose Runs a unit test coverage calculation task and logs the % per class.
tryinstall-verbose Creates a venv and tries to build+install this package to verify everything is ok.
all-concise Runs a batch of verification tasks and logs one summary line for each of them.

The expected outcome for all-concise is:

MODULE_NAME: nwpackageversions
MODULE_VERSION: 1.8.1
COVERAGE_THRESHOLD: 70%
[WARNING] type-concise: not passed! '1' error(s) found!
[OK] howtorelease-concise: 'How-to Release' updated to current version!
[WARNING] changelog-concise: 'CHANGELOG' not updated to current version!
[OK] setup-concise: 'setup.py' updated to current version!
[OK] coverage-concise: unit test coverage >= 70%.

Considering the old-fashioned syntax adopted by make, here a summary of its less intuitive aspects:

Aspect Description
.PHONY All the targets that need to be called from another target need to be listed here.
SHELL := /bin/bash By default, make uses sh, which doesn't support some functions such as string comparison.
@ By default, make logs all the commands included in the target. The @ disables this behaviour.
$$ Necessary to escape $.
$@ Variable that stores the target name.

Known Issues - "Import nwpackageversions could not be resolved Pylance (reportMissingImports)"

If while trying to import nwpackageversions in Visual Studio Code the following warning appears:

Import nwpackageversions could not be resolved Pylance (reportMissingImports)

please:

  1. in your terminal application of choice, launch the Python interpreter:
PS C:\> python
  1. run the following command:
import nwpackageversions
print(nwpackageversions.__file__)
  1. the console will output something like this:
C:\Users\Rubèn\src\nwpackageversions\src\nwpackageversions.py
  1. open Visual Studio Code > File > Preferences > Settings and search for Python › Analysis: Extra Paths;

  2. click on Add item and add the path above without the python file name:

C:\Users\Rubèn\src\nwpackageversions\src\
  1. restart Visual Studio Code;
  2. Done!

Appendix - The "label_pattern"

The PyPiBadgeFetcher.try_fetch() method adopts the following two XPath patterns:

version_pattern : str = "//p[@class='release__version'][span]/text()"
label_pattern : str = "//p[@class='release__version']/span[1]/text()"

The [1] ("take only the first span element") in the second pattern is necessary due of some packages having more than one badge per version - i.e openpyxl:

...
<p class="release__version">
   3.2.0b1
   <span class="badge badge--warning">pre-release</span>
   <span class="badge badge--danger">yanked</span>
</p>
<p class="release__version">
   2.6.0b1
   <span class="badge badge--warning">pre-release</span>
</p>
<p class="release__version">
   2.6.0a1
   <span class="badge badge--warning">pre-release</span>
</p>
...

Appendix - Example files

  1. Dockerfile
  2. releases.xml
  3. requirements.txt
  4. history.html

Disclaimer

This software includes a RSS reader for PyPi.org. Due of the lack of a badge-related field in the RSS feed, which are necessary to discern stable releases from the others ("pre-release", "yanked"), a minimal web scraping functionality has been added in order to retrieve the badge from the release history page (https://pypi.org/project/<package_name>/#history).

At the moment of writing, the three legal pages related to PyPi.org do not prohibit web scraping:

For clarity, I am providing HTML snapshots as of today:

This functionality has been gracefully implemented, adopting a minimum waiting_time of five seconds for each GET request to not overload the servers, and it's disabled by default.

The functionality is clearly explained in this documentation file, and users must actively enable it, assuming full responsibility for its fair use. The developer cannot be held responsible for any eventual improper use of this software.

Markdown Toolset

Suggested toolset to view and edit this Markdown file: