Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update docs for "add_additional_resource" and other fixes #233

Merged
merged 20 commits into from
Oct 20, 2023
Merged
Show file tree
Hide file tree
Changes from 16 commits
Commits
Show all changes
20 commits
Select commit Hold shift + click to select a range
2bc2ca8
ci: add ROOT v6.28 and Python v3.11 to test matrix
GraemeWatt Oct 13, 2023
674a872
docs: add "Adding resource links or files" etc.
GraemeWatt Oct 13, 2023
e9a4bde
examples: use add_additional_resource in notebooks
GraemeWatt Oct 13, 2023
666f799
hepdata_lib: add "type" to add_additional_resource
GraemeWatt Oct 13, 2023
2156317
.gitignore: add files output by example notebooks
GraemeWatt Oct 13, 2023
2dbb58e
.readthedocs.yml: install hepdata_lib package
GraemeWatt Oct 13, 2023
9ddc488
README.md: fix links to Jupyter notebooks
GraemeWatt Oct 13, 2023
8f1a167
setup.py: add extras_require w/ test requirements
GraemeWatt Oct 13, 2023
1aea7b2
ci: remove Python v3.11 from test matrix
GraemeWatt Oct 14, 2023
dfa0a89
docs: add "Analysing the code" section on Pylint
GraemeWatt Oct 14, 2023
a57b92f
hepdata_lib: add type of new "file_type" argument
GraemeWatt Oct 14, 2023
db27195
README.mb: fix Zenodo badge & give Python versions
GraemeWatt Oct 14, 2023
c5f19db
setup.py: remove upper bound on python_requires
GraemeWatt Oct 14, 2023
f4e311c
docs: reinstate SSH URL for "git clone"
GraemeWatt Oct 14, 2023
77cc768
ci: add Python 3.11 for tests but skip pylint step
GraemeWatt Oct 15, 2023
7d829b0
Revert "ci: add Python 3.11 for tests but skip pylint step"
GraemeWatt Oct 15, 2023
f11eb35
ci/docs: rename master to main and improve docs
GraemeWatt Oct 18, 2023
0d77f11
pylint: remove 'disable-msg' and fix imports
GraemeWatt Oct 18, 2023
497d462
docs: tweak "Further examples" etc.
GraemeWatt Oct 19, 2023
8b318b3
docs: correct link to Python venv module
GraemeWatt Oct 20, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 6 additions & 2 deletions .github/workflows/tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ jobs:
strategy:
matrix:
os: [ubuntu-latest]
root-version: ["6.24", "6.26"]
root-version: ["6.24", "6.26", "6.28"]
python-version: ["3.6", "3.7", "3.8", "3.9", "3.10"]
exclude:
- root-version: "6.24"
Expand All @@ -34,9 +34,13 @@ jobs:
python-version: "3.6"
- root-version: "6.26"
python-version: "3.7"
- root-version: "6.28"
python-version: "3.6"
- root-version: "6.28"
python-version: "3.7"
include:
- os: macos-latest
root-version: "6.26"
root-version: "6.28"
python-version: "3.10"

steps:
Expand Down
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
# output from examples
examples/submission.tar.gz
examples/example_output/
examples/output/
examples/correlation.root

# test output
submission.tar.gz
Expand Down
23 changes: 15 additions & 8 deletions .readthedocs.yml
Original file line number Diff line number Diff line change
Expand Up @@ -5,19 +5,26 @@
# Required
version: 2

# Build documentation in the docs/ directory with Sphinx
# Set the OS, Python version and other tools you might need
build:
os: ubuntu-22.04
tools:
python: "3.10"

# Build documentation in the "docs/" directory with Sphinx
sphinx:
configuration: docs/conf.py

# Build documentation with MkDocs
#mkdocs:
# configuration: mkdocs.yml
# Fail on all warnings to avoid broken references
fail_on_warning: true

# Optionally build your docs in additional formats such as PDF and ePub
formats: all

# Optionally set the version of Python and requirements required to build your docs
# Optional but recommended, declare the Python requirements required
# to build your documentation
# See https://docs.readthedocs.io/en/stable/guides/reproducible-builds.html
python:
version: 3.7
install:
- requirements: docs/requirements.txt
- requirements: docs/requirements.txt
- method: pip
path: .
30 changes: 24 additions & 6 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# hepdata_lib

[![DOI](https://zenodo.org/badge/129248575.svg)](https://zenodo.org/badge/latestdoi/129248575)
[![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.1217998.svg)](https://doi.org/10.5281/zenodo.1217998)
[![PyPI version](https://badge.fury.io/py/hepdata-lib.svg)](https://badge.fury.io/py/hepdata-lib)
[![Actions Status](https://github.com/HEPData/hepdata_lib/workflows/tests/badge.svg)](https://github.com/HEPData/hepdata_lib/actions)
[![Coverage Status](https://codecov.io/gh/HEPData/hepdata_lib/graph/badge.svg?branch=master)](https://codecov.io/gh/HEPData/hepdata_lib?branch=master)
Expand All @@ -9,6 +9,10 @@

Library for getting your data into HEPData

- Documentation: https://hepdata-lib.readthedocs.io

This code works with Python 3.6, 3.7, 3.8, 3.9 or 3.10.

## Installation

It is highly recommended you install `hepdata_lib` into a [virtual environment](https://packaging.python.org/guides/installing-using-pip-and-virtual-environments/).
Expand Down Expand Up @@ -53,11 +57,25 @@ Unpacking the image can take a few minutes the first time you use it. Please be

There are a few more examples available that can directly be run using the [binder](https://mybinder.org/) links below or using [SWAN](https://swan.cern.ch/) (CERN-only, please use LCG release LCG_94 or later) and selecting the corresponding notebook manually:

- [Reading in text files](examples/Getting_started.ipynb) [![Binder](https://mybinder.org/badge.svg)](https://mybinder.org/v2/gh/HEPData/hepdata_lib/master?filepath=examples/Getting_started.ipynb)
- [Reading in a CMS combine ntuple](examples/combine_limits.ipynb) [![Binder](https://mybinder.org/badge.svg)](https://mybinder.org/v2/gh/HEPData/hepdata_lib/master?filepath=examples/combine_limits.ipynb)
- [Reading in ROOT histograms](examples/reading_histograms.ipynb) [![Binder](https://mybinder.org/badge.svg)](https://mybinder.org/v2/gh/HEPData/hepdata_lib/master?filepath=examples/reading_histograms.ipynb)
- [Reading a correlation matrix](examples/correlation.ipynb) [![Binder](https://mybinder.org/badge.svg)](https://mybinder.org/v2/gh/HEPData/hepdata_lib/master?filepath=examples/correlation.ipynb)
- [Reading TGraph and TGraphError from '.C' files](examples/read_c_file.ipynb) [![Binder](https://mybinder.org/badge.svg)](https://mybinder.org/v2/gh/HEPData/hepdata_lib/master?filepath=examples/read_c_file.ipynb)
- [Reading in text files](https://github.com/HEPData/hepdata_lib/blob/master/examples/Getting_started.ipynb)\
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What's the reason you're changing this? Relative links would also work in branches whereas here you hard-code them to master. I'd prefer to keep things as they are.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The problem is that the README.md file is rendered in two different places. Firstly, on the main page of the repo (https://github.com/HEPData/hepdata_lib#further-examples) where it displays fine. But the README.md file is also converted to RST format for rendering on Read the Docs (https://hepdata-lib.readthedocs.io/en/latest/README.html#further-examples). This is currently broken. The relative links do not work giving "404 Not Found" from Read the Docs. The Binder images/links also do not render properly. The Read the Docs build gives error/warning messages like:

../README.md:96: ERROR: Unexpected indentation.
../README.md:101: ERROR: Unexpected indentation.
../README.md:106: ERROR: Unexpected indentation.
../README.md:111: ERROR: Unexpected indentation.
../README.md:116: ERROR: Unexpected indentation.
/home/docs/checkouts/readthedocs.org/user_builds/hepdata-lib/checkouts/stable/docs/contributing.rst:75: WARNING: Title underline too short.

These messages are also apparent when running Sphinx locally. My fixes are a compromise to get rid of these error messages and ensure an acceptable rendering on both GitHub and Read the Docs. Admittedly, the spacing now looks worse than before on GitHub, but it was the best I could do. Now I've enabled fail_on_warning: true in the Read the Docs configuration, such error messages will cause the build to fail rather than being hidden away.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I tried to improve the layout of the "Further examples" section in my latest commit. Now the Binder images/links appear on the same line as the text on GitHub (as before). On Read the Docs, the Binder images/links appear on the line below the text. The two line breaks <br/><br/> are needed to increase the separation after each bullet point because otherwise the Binder images/links appear immediately above the text of the next bullet point.

[![Binder](https://mybinder.org/badge.svg)](https://mybinder.org/v2/gh/HEPData/hepdata_lib/master?filepath=examples/Getting_started.ipynb)
<br/><br/>

- [Reading in a CMS combine ntuple](https://github.com/HEPData/hepdata_lib/blob/master/examples/combine_limits.ipynb)\
[![Binder](https://mybinder.org/badge.svg)](https://mybinder.org/v2/gh/HEPData/hepdata_lib/master?filepath=examples/combine_limits.ipynb)
<br/><br/>

- [Reading in ROOT histograms](https://github.com/HEPData/hepdata_lib/blob/master/examples/reading_histograms.ipynb)\
[![Binder](https://mybinder.org/badge.svg)](https://mybinder.org/v2/gh/HEPData/hepdata_lib/master?filepath=examples/reading_histograms.ipynb)
<br/><br/>

- [Reading a correlation matrix](https://github.com/HEPData/hepdata_lib/blob/master/examples/correlation.ipynb)\
[![Binder](https://mybinder.org/badge.svg)](https://mybinder.org/v2/gh/HEPData/hepdata_lib/master?filepath=examples/correlation.ipynb)
<br/><br/>

- [Reading TGraph and TGraphError from '.C' files](https://github.com/HEPData/hepdata_lib/blob/master/examples/read_c_file.ipynb)
[![Binder](https://mybinder.org/badge.svg)](https://mybinder.org/v2/gh/HEPData/hepdata_lib/master?filepath=examples/read_c_file.ipynb)
<br/><br/>

## External dependencies

Expand Down
2 changes: 1 addition & 1 deletion docs/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
#

# You can set these variables from the command line.
SPHINXOPTS =
SPHINXOPTS = -W --keep-going
SPHINXBUILD = sphinx-build
SPHINXPROJ = hepdata_lib
SOURCEDIR = .
Expand Down
8 changes: 4 additions & 4 deletions docs/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ def __getattr__(cls, name):
# -- Project information -----------------------------------------------------

project = 'hepdata_lib'
copyright = '2018-2022, Andreas Albert, Clemens Lange'
copyright = '2018-2023, Andreas Albert, Clemens Lange'
author = 'Andreas Albert, Clemens Lange'

# The short X.Y version
Expand All @@ -55,7 +55,7 @@ def __getattr__(cls, name):
# ones.
extensions = [
'sphinx.ext.githubpages',
'm2r2',
'sphinx_mdinclude',
'sphinx.ext.autodoc'
]

Expand All @@ -76,7 +76,7 @@ def __getattr__(cls, name):
#
# This is also used if you do content translation via gettext catalogs.
# Usually you set "language" from the command line for these cases.
language = None
language = 'en'

# List of patterns, relative to source directory, that match files and
# directories to ignore when looking for source files.
Expand All @@ -103,7 +103,7 @@ def __getattr__(cls, name):
# Add any paths that contain custom static files (such as style sheets) here,
# relative to this directory. They are copied after the builtin static files,
# so a file named "default.css" will overwrite the builtin "default.css".
html_static_path = ['_static']
# html_static_path = ['_static']

# Custom sidebar templates, must be a dictionary that maps document names
# to template names.
Expand Down
4 changes: 2 additions & 2 deletions docs/contributing.rst
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ The files in which the versions are updated as well as the current version can b
.. _sec-dev-pypi:

Uploading to PyPI
-----------------------------
-----------------

Once a new version has been tagged, the package should be uploaded to the Python Package Index (PyPI_).
For the markdown formatting to work, ``twine>=1.11.0`` is required.
Expand Down Expand Up @@ -72,7 +72,7 @@ You should then find the new version at `this location`_. You need to be a maint
.. _python packaging documentation: https://packaging.python.org/tutorials/packaging-projects/

Creating a new release automatically via an issue
-----------------------------
-------------------------------------------------

Opening an new issue automatically creates a new release if:

Expand Down
39 changes: 29 additions & 10 deletions docs/dev.rst
Original file line number Diff line number Diff line change
@@ -1,21 +1,22 @@
Developer information
======================
=====================

The testing system
--------------------
------------------

While further developing the code base, we want to ensure that any changes we make do not accidentally break existing functionality. For this purpose, we use continuous integration via GitHub Actions_. Practically, this means that we define a set of test code that is automatically run in a predefined environment every time we push to a branch or create a pull request. If the test code runs successfully, we know that everything works as expected.

To run the tests, move into the ``hepdata_lib`` directory and run
To run the tests, move into the ``hepdata_lib`` directory while in your virtual environment and run

::

python setup.py test
pip install -e ".[test]"
pytest tests

It is a good idea to run the tests manually to ensure that your changes do not cause any issues.

Definition of test cases
+++++++++++++++++++++++++
++++++++++++++++++++++++

Test cases are defined in the ``test`` subfolder of the repository. Independent sets of test code are defined in individual files in that directory, with each files being named like ``test_*.py``.

Expand All @@ -40,12 +41,12 @@ If all functions run without raising exceptions, the test is considered to be pa


When to test
~~~~~~~~~~~~~~~~~~~~~~~~
~~~~~~~~~~~~

Tests should be added any time functionality is added. If functionality is modified, so should the tests.

What to test
~~~~~~~~~~~~~~~~~~~~~~~~
~~~~~~~~~~~~

Generally, the tests should ensure that the code behaves as expected, whatever that may mean. They should be sufficiently rigorous to make sure that nothing can break silently, and that outputs are correct.

Expand All @@ -57,7 +58,7 @@ Broad inspiration for aspects to check:


How to test
~~~~~~~~~~~~~~~~~~~~~~~~
~~~~~~~~~~~

The ``TestCase`` base class provides functionality to help implement simple checks to verify the behavior. A test can immediately be made to fail by calling ``self.fail()``. For convenience, additional functions like ``assertTrue``, ``assertFalse``, etc. are provided, which work like normal python assertions. If the assertion fails, the test is considered to be failed. Additionally, the ``assertRaises`` method can be used as a context to ensure that exceptions are raised as expected. Here's a simple example:

Expand Down Expand Up @@ -95,10 +96,28 @@ Note that this is an overly simple example case: In a real testing case, you sho

Check out the unittest package documentation_ for details of the available testing functionality.

.. _Actions: https://docs.github.com/en/actions
.. _documentation: https://docs.python.org/2/library/unittest.html#unittest.TestCase


Building the documentation
--------------------------

After installing the ``hepdata_lib`` package, move into the ``hepdata_lib/docs`` directory and install the additional necessary packages into your virtual environment:

::

pip install -r requirements.txt

.. _Actions: https://docs.github.com/en/actions
.. _documentation: https://docs.python.org/2/library/unittest.html#unittest.TestCase
Then you can build the documentation locally with Sphinx using ``make html`` and view the output by opening a web browser at ``_build/html/index.html``.


Analysing the code
------------------

::

pylint hepdata_lib/*.py
pylint tests/*.py --rcfile=tests/pylintrc

These commands are run by GitHub Actions, so you should first check locally that no issues are flagged.
4 changes: 2 additions & 2 deletions docs/requirements.txt
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
m2r2==0.3.3
Sphinx<7
sphinx_rtd_theme
docutils==0.19
mistune<2.0.0
sphinx-mdinclude
19 changes: 17 additions & 2 deletions docs/setup.rst
Original file line number Diff line number Diff line change
Expand Up @@ -42,12 +42,18 @@ Setup for developers

The general comments about installing a python package (see :ref:`sec-setup-users`) apply here, too. Use a virtual environment (see :ref:`sec-setup-virtualenv`)!

If you would like to develop the code, you need to install the package from the up-to-date git repository rather than the stable release in pypi. To do this, you can use the pip `-e` syntax:
If you would like to develop the code, you need to install the package from the up-to-date `GitHub repository`_ rather than the stable release in PyPI. To do this, you can use the pip `-e` syntax.
The GitHub repository can be cloned using either an `HTTPS URL`_ or an `SSH URL`_.

.. _GitHub repository: https://github.com/HEPData/hepdata_lib
.. _HTTPS URL: https://docs.github.com/en/get-started/getting-started-with-git/about-remote-repositories#cloning-with-https-urls
.. _SSH URL: https://docs.github.com/en/get-started/getting-started-with-git/about-remote-repositories#cloning-with-ssh-urls

::

cd $SOMEPATH
git clone [email protected]:HEPData/hepdata_lib.git
git clone https://github.com/HEPData/hepdata_lib.git
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Switching to HTTPS is fine, though I like poking people towards using SSH when possible.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I guess it's personal preference whether to use HTTPS or SSH, so I've given both URLs and linked to the GitHub documentation. I just changed to HTTPS because that's what I use myself.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'd also prefer to keep SSH here

OR git clone [email protected]:HEPData/hepdata_lib.git
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

... and then make the HTTPS option a comment so one can copy and paste

Copy link
Member Author

@GraemeWatt GraemeWatt Oct 18, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

OK, I've reverted to giving SSH, with the HTTPS option given in the text above. Personally, I just find it easier to use HTTPS since it doesn't require an SSH keypair, especially if I just want to checkout a repository without pushing to it.


workon myhepdata # activate virtual environment!
pip install -e $SOMEPATH/hepdata_lib
Expand Down Expand Up @@ -92,6 +98,15 @@ You can always activate the virtual environment in another shell by calling the
workon hepdata_git
python myscript.py # Execute script using development branch

Alternatively, if you don't want to install the additional virtualenv_ and virtualenvwrapper_ packages, you can simply
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Since we're on this topic, I would actually prefer to have this the default since most people will not have virtualenv or virtualenvwrapper available and it will be confusing to state things that are using non-standard tools first. Maybe we should get rid of the virtualenv and virtualenvwrapper section altogether.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Agree, I think the text on virtualenv/virtualenvwrapper is a hangover from Python 2 where the venv module was not available. I've rewritten the text to use the venv module instead.

use the venv_ module from the Python standard library.

::

python3 -m venv env
source env/bin/activate

.. _venv: https://packaging.python.org/en/latest/guides/installing-using-pip-and-virtual-environments/#creating-a-virtual-environment

Setup on lxplus with CMSSW
--------------------------
Expand Down
10 changes: 10 additions & 0 deletions docs/source/hepdata_lib.rst
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,16 @@ Module contents
:undoc-members:
:show-inheritance:

.. automodule:: hepdata_lib.c_file_reader
:members:
:undoc-members:
:show-inheritance:

.. automodule:: hepdata_lib.helpers
:members:
:undoc-members:
:show-inheritance:

.. automodule:: hepdata_lib.root_utils
:members:
:undoc-members:
Expand Down
Loading