Skip to content

Latest commit

 

History

History
100 lines (91 loc) · 4.03 KB

Development Notes.md

File metadata and controls

100 lines (91 loc) · 4.03 KB

Development Notes

General | Make Docs | Running Tests | Build PyPi Package|

General Notes

  • TODOs
    • Test collect when there isn't an available _eval_collect (not sure how to get there).
    • Test for _binary_op NotImplemented error (not sure how to get there).
  • To consider
    • Include Sympy Plot Backends in the default setup.
    • Change Equation constructor to accept Equality, Set, List or lhs, rhs, rather than just lhs, rhs.
    • Extend .subs to accept .subs(a=2*c, b = sin(q), ...).
    • MathLive on another web page as possible input engine.

Constructing the Documentation

  1. Make sure pdoc is installed and updated in the virtual environment pip install -U pdoc.
  2. Update any .md files included in _init_.py.
    • Generally URLs should be absolute, not relative.
  3. At the root level run pdoc pdoc --logo https://gutow.github.io/Algebra_with_Sympy/alg_w_sympy.svg --logo-link https://gutow.github.io/Algebra_with_Sympy/ --footer-text "Algebra with Sympy vX.X.X" --math -html -o docs ./algebra_with_sympy where X.X.X is the version number.

Tasks for Documentation

  • Readme.md & Development Notes.md
    • Use absolute path to github pages for more examples.

Running Tests

  1. Install updated pytest in the virtual environment:
    pipenv shell
    pip install -U pytest
    
  2. Run standard tests: pytest --ignore='Developer Testing' --ignore-glob='*test_preparser.py'.
  3. Run preparser tests: ipython -m pytest tests/test_preparser.py
  4. Run doctests: pytest --ignore='tests' --ignore='Developer Testing' --ignore-glob='*old*' --doctest-modules

You can run all the tests using the dotests script: ./dotests.sh.

NOTE: Some warnings about invalid escape characters are expected because raw strings are being passed with specialized LaTex escaped characters.

Building PyPi package

  1. Make sure to update the version number in setup.py first.
  2. Install updated setuptools and twine in the virtual environment:
    pipenv shell
    pip install -U setuptools wheel twine
    
  3. Build the distribution python -m setup sdist bdist_wheel.
  4. Test it on test.pypi.org.
    1. Upload it (you will need an account on test.pypi.org): python -m twine upload --repository testpypi dist/*.
    2. Create a new virtual environment and test install into it:
      exit # to get out of the current environment
      cd <somewhere>
      mkdir <new virtual environment>
      cd <new directory>
      pipenv shell #creates the new environment and enters it.
      pip install -i https://test.pypi.org/..... # copy actual link from the
                                                 # repository on test.pypi.
      
      There are often install issues because sometimes only older versions of some of the required packages are available on test.pypi.org. If this is the only problem change the version to end in rc0 for release candidate and try it on the regular pypi.org as described below for releasing on PyPi.
    3. After install test by running a jupyter notebook in the virtual environment.

Releasing on PyPi

Proceed only if testing of the build is successful.

  1. Double check the version number in version.py.
  2. Rebuild the release: python -m setup sdist bdist_wheel.
  3. Upload it: python -m twine upload dist/*
  4. Make sure it works by installing it in a clean virtual environment. This is the same as on test.pypi.org except without -i https://test.pypy.... If it does not work, pull the release.