Skip to main content

SCROLL: Automatically generates documentation and unit-tests for python programs

Project description

SCROLL: Automatically generates documentation and unit-tests for python programs

Built with Data processing programs in mind

PyPI version Downloads Python 3.6+ Code style: black

How it works

This tool monitors your function calls and returns while you "exercise" you program (i.e run functional tests). It will collect this information (traces), record the order in which your functions run and generate documentation / tests using that information.

Design concept

The final goal is to enable a developer/user browser through documentation that flows in the order in which functions in the program run, hence the name SCROLL.

Installation

pip install scroll

To install using wheel files, Check in Distribution files

Example Usage

Lets say your file which contains the main entry function is called main.py

An example main file with an entry function

# main.py

def run():
    '''this is your singular entry function'''
    # your code here


if __name__ == '__main__':
    run()

Run the file using scroll on bash

scroll main.py

How about some guidelines?

  • There should be only one main entry function in your code

To-Do

  • add creating of url with class name / func name ancored on it
  • add creating of SCROLL.md that has scroll of all functions

Contributing

To get started contributing, visit the CONTRIBUTING GUIDE

Contributors and acknowledgment

  1. Edison Abahurire simicode

Similar Libraries that do Runtime-Introspection:

  1. pythoscope for Auto unit-test generation
  2. auger for Auto Unit-test generation
  3. MonkeyType for Auto Type hinting / Annotation
  4. hypothesis for Auto test-case generation

License

MIT

Credits

  • MonkeyType: When I got this idea, My first option was to just plagiarise their code ;) I also learned a lot from issue-conversations with @carljm.
  • Flit which this wonderful library is packaged with.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

scroll-2021.11.17.tar.gz (17.2 kB view details)

Uploaded Source

Built Distribution

scroll-2021.11.17-py3-none-any.whl (10.0 kB view details)

Uploaded Python 3

File details

Details for the file scroll-2021.11.17.tar.gz.

File metadata

  • Download URL: scroll-2021.11.17.tar.gz
  • Upload date:
  • Size: 17.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.26.0

File hashes

Hashes for scroll-2021.11.17.tar.gz
Algorithm Hash digest
SHA256 1e45975e63bf355f1c174743f10d63eec38bae186fd96442cf8cf4d6e15b2729
MD5 0adfb2c672739050f055850051661d69
BLAKE2b-256 03e9da6efa03fc90f5a86497d77727541167d13dda9e43f79ce33330b672136d

See more details on using hashes here.

File details

Details for the file scroll-2021.11.17-py3-none-any.whl.

File metadata

  • Download URL: scroll-2021.11.17-py3-none-any.whl
  • Upload date:
  • Size: 10.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.26.0

File hashes

Hashes for scroll-2021.11.17-py3-none-any.whl
Algorithm Hash digest
SHA256 b103edb996bbea58add30ccc7a2902341b368b11fd231af76376b7c5d4606835
MD5 6973d8771e8a8b6d5bb85dc3a909056d
BLAKE2b-256 ad5e0cd9a531f6498ae65d9ff89decd14b4ba7627b78e231cd1185e92cccb16a

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page