From 27cde9a79816ae8eb70301b96e1e0777eb5f709c Mon Sep 17 00:00:00 2001 From: Mark Bonicillo Date: Sat, 8 Jun 2024 14:08:16 -0700 Subject: [PATCH 1/5] Remove attestation step --- .github/workflows/publish-to-dockerhub.yml | 7 ------- 1 file changed, 7 deletions(-) diff --git a/.github/workflows/publish-to-dockerhub.yml b/.github/workflows/publish-to-dockerhub.yml index bc3bd6b4..7f0b412e 100644 --- a/.github/workflows/publish-to-dockerhub.yml +++ b/.github/workflows/publish-to-dockerhub.yml @@ -59,10 +59,3 @@ jobs: with: tags: hypernetx/hypernetx:latest push: true - - - name: Generate artifact attestation - uses: actions/attest-build-provenance@v1 - with: - subject-name: hypernetx/hypernetx - subject-digest: ${{ steps.push.outputs.digest }} - push-to-registry: true From 15197c94fb2656e4f240294dad2117c27486b892 Mon Sep 17 00:00:00 2001 From: Mark Bonicillo Date: Mon, 10 Jun 2024 10:15:42 -0700 Subject: [PATCH 2/5] Make subsection in LONG_DESCRIPTION --- LONG_DESCRIPTION.rst | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/LONG_DESCRIPTION.rst b/LONG_DESCRIPTION.rst index ee816721..e6c85f3c 100644 --- a/LONG_DESCRIPTION.rst +++ b/LONG_DESCRIPTION.rst @@ -1,7 +1,7 @@ .. _long_description: HyperNetX -================= +========= The HyperNetX library provides classes and methods for the analysis and visualization of complex network data modeled as hypergraphs. @@ -25,7 +25,7 @@ Documentation is available at: https://pnnl.github.io/HyperNetX For questions and comments contact the developers directly at: hypernetx@pnnl.gov HyperNetX 2.3 -============= +~~~~~~~~~~~~~ HyperNetX 2.3. is the latest, stable release. The core library has been refactored to take better advantage of Pandas Dataframes, improve readability and maintainability, address bugs, and make it easier to change. From 4e6d05c29c4114ae09d50b37799c976f918678bc Mon Sep 17 00:00:00 2001 From: Mark Bonicillo Date: Mon, 10 Jun 2024 10:16:06 -0700 Subject: [PATCH 3/5] Adjust pylint settings --- pylintrc | 2 +- tox.ini | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/pylintrc b/pylintrc index 5ceacf76..c6615209 100644 --- a/pylintrc +++ b/pylintrc @@ -1,7 +1,7 @@ [MAIN] # Specify a score threshold to be exceeded before program exits with error. -fail-under=7.00 +# fail-under= # A comma-separated list of package or module names from where C extensions may # be loaded. Extensions are loading into the active Python interpreter and may diff --git a/tox.ini b/tox.ini index d753703a..04e29757 100644 --- a/tox.ini +++ b/tox.ini @@ -44,7 +44,7 @@ basepython = python3.11 commands_pre = poetry install --with lint commands = - poetry run pylint --recursive=y --persistent=n hypernetx + poetry run pylint --recursive=y --exit-zero --persistent=n hypernetx poetry run flake8 hypernetx --exit-zero poetry run pre-commit install poetry run pre-commit run --all-files From 6bd4bd99fec950c8a854bb92ec344d149e797bb0 Mon Sep 17 00:00:00 2001 From: Mark Bonicillo Date: Mon, 10 Jun 2024 11:09:37 -0700 Subject: [PATCH 4/5] Modify Makefile --- Makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Makefile b/Makefile index b40349d4..bf36b44f 100644 --- a/Makefile +++ b/Makefile @@ -66,7 +66,7 @@ lint: pylint flake8 .PHONY: pylint pylint: - @$(PYTHON3) -m pylint --recursive=y --persistent=n --verbose hypernetx + @$(PYTHON3) -m pylint --recursive=y --persistent=n --exit-zero --verbose hypernetx # Todo: fix flake8 errors and remove --exit-zero .PHONY: flake8 From e5d756194872669bc6ad871bd0d7324910a02ce0 Mon Sep 17 00:00:00 2001 From: Mark Bonicillo Date: Mon, 10 Jun 2024 16:40:08 -0700 Subject: [PATCH 5/5] Update README --- README.md | 106 ++++++++++++++++++++++++++++++------------------------ 1 file changed, 60 insertions(+), 46 deletions(-) diff --git a/README.md b/README.md index 0f0bd772..17fd9706 100644 --- a/README.md +++ b/README.md @@ -235,41 +235,57 @@ After the container has started, access the HyperNetX Jupyter Notebooks by openi [http://localhost:8888/tree](http://localhost:8888/tree) -Development -=========== +# Development -Install an editable version -``` -pip install -e . -``` +As a developer, set up your environment using either the standard `pip` tool or [`Poetry`](https://python-poetry.org/). + +## Using Pip -Install additional dependencies to support testing and jupyter notebooks: +### Setup virtual environment and install HNX + +Create a virtual environement. Then install an editable version of HNX and also install additional dependencies to support testing and jupyter notebooks: ``` +python -m venv venv-hnx +source venv-hnx/bin/activate +pip install -e . pip install -r requirements.txt ``` -You can also install all these requirements in one Make target: +As an alternative, you can also install all these requirements in one Make target: ``` +make venv +source venv-hnx/bin/activate make install ``` -Poetry -====== +### Setup pre-commit + +Use the [pre-commit framework](https://pre-commit.com/) to automatically point out issues and resolve those issues before code review. +It is highly recommended to install pre-commit in your development environment so that issues with your code can be found before you submit a +pull request. More importantly, using pre-commit will automatically format your code changes so that they pass the CI build. For example, pre-commit will +automatically run the formatter Black on your code changes. + +```shell +# Once installed, pre-commit will be triggered every time you make a commit in your environment +pre-commit install +``` + + +## Using Poetry This library uses [Poetry](https://python-poetry.org/docs/) to manage dependencies and packaging. Poetry can also be used to manage your environment for development. -Prerequisites -------------- +### Prerequisites * [Install Poetry](https://python-poetry.org/docs/#installation) -Configure Poetry ----------------- +### Configure Poetry + +[Configure your Poetry](https://python-poetry.org/docs/configuration/) to ensure that the virtual environment gets created in your project directory (this is not necessary but recommended for convenience): -[Configure your Poetry](https://python-poetry.org/docs/configuration/) to create the virtual environment in your project directory: ``` poetry config virtualenvs.in-project true @@ -277,21 +293,38 @@ poetry config virtualenvs.in-project true poetry config --list ``` -Set up virtual environment ----------------------------- +### Setup virtual environment and install HNX Create and activate a virtual environment. + ``` poetry shell ``` -Install required dependencies and HyperNetX in editable mode. +Install HyperNetX in editable mode, the library's core/required dependencies, and the optional dependencies to support development. + ``` -poetry install +poetry install --with test,lint,docs,release,tutorials ``` -Install support for testing ------------------------------ +Details about these dependencies are defined in [pyproject.toml](pyproject.toml). + +### Setup Pre-commit + +Use the [pre-commit framework](https://pre-commit.com/) to automatically point out issues and resolve those issues before code review. +It is highly recommended to install pre-commit in your development environment so that issues with your code can be found before you submit a +pull request. More importantly, using pre-commit will automatically format your code changes so that they pass the CI build. For example, pre-commit will +automatically run the formatter Black on your code changes. + +```shell +# Once installed, pre-commit will be triggered every time you make a commit in your environment +pre-commit install +``` + +### Details about optional dependencies + +#### Install support for testing + > ℹ️ **NOTE:** This project has pytest configuration contained in pyproject.toml. By default, pytest will use those configuration settings to run tests. @@ -312,8 +345,7 @@ coverage html open htmlcov/index.html ``` -Install support for tutorials ------------------------------ +#### Install support for tutorials ```shell poetry install --with tutorials @@ -325,8 +357,8 @@ poetry shell make tutorials ``` -Code Quality ------------- +#### Code Quality: Pylint, Black + HyperNetX uses a number of tools to maintain code quality: * Pylint @@ -341,8 +373,6 @@ poetry install --with lint poetry shell ``` -Pylint ------- [Pylint](https://pylint.pycqa.org/en/latest/index.html) is a static code analyzer for Python-based projects. From the [Pylint docs](https://pylint.pycqa.org/en/latest/index.html#what-is-pylint): @@ -362,8 +392,6 @@ pylint hypernetx --output=pylint-results.txt For more information on configuration, see https://pylint.pycqa.org/en/latest/user_guide/configuration/index.html -Black ------ [Black](https://black.readthedocs.io/en/stable/) is a PEP 8 compliant formatter for Python-based project. This tool is highly opinionated about how Python should be formatted and will automagically reformat your code. @@ -371,21 +399,7 @@ Black black hypernetx ``` -Pre-commit ---------- - -Use the [pre-commit framework](https://pre-commit.com/) to automatically point out issues and resolve those issues before code review. -It is highly recommended to install pre-commit in your development environment so that issues with your code can be found before you submit a -pull request. More importantly, using pre-commit will automatically format your code changes so that they pass the CI build. For example, pre-commit will -automatically run the formatter Black on your code changes. - -```shell -# Once installed, pre-commit will be triggered every time you make a commit in your environment -pre-commit install -``` - -Documentation -------------- +### Documentation Build and view documentation locally: @@ -422,8 +436,8 @@ The HTML pages are in docs/html. Click on [http://127.0.0.1:8000/install.html](http://127.0.0.1:8000/install.html) to open the docs on your browser. Since this will auto-rebuild, every time you change a document file, it will automatically render on your browser, allowing you to verify your document changes. -Testing the Docker Image ------------------------- + +## Developing and Testing the Docker Image If you want to test the Docker image after making any source code changes, follow this workflow: