Skip to main content

Python environment for TM129

Project description

ou-tm129-py

Python package for installing Python packages required for TM129

This repo is exploring how we might distribute Python packages to students via a single installable package.

A Python package can be "empty" other than requiring the presence of particular packages.

We can define multiple levels of requirement using install_requires=[] for necessary packages and extras_require={} for optional packages.

Optional package collections can be installed via eg pip install .[jupyter,production], using extras_require dictionary keys for the additional package collections we want to install.

So for example, we could deliver:

  • core packages that configure a base Python environment: pip install PACKAGE;
  • core packages and packages that customise a Jupyter environment in a particular way: pip install PACKAGE[jupyter];
  • core packages and packages that customise a Jupyter environment in a particular way and provides additional packages for ALs: pip install PACKAGE[jupyter,AL];
  • core packages plus production / development packages: pip install PACKAGE[dev];
  • core packages plus packages required to customise an OU hosted environment: pip install PACKAGE[ouhosted];
  • etc.

We could also use a package to deliver payloads to the student desktop, either in terms of files or services. eg we could supply command line utilites, a simple webserver/homepage, or a data files via a Python package.

Using Package version numbers (or extras_require) we could easily manage slightly different package versions/distributions for different module presentations.

Using pip install --upgrade PACKAGE gives us a way of pushing updates to students.

Note that installing from repos is increasingly tricky to do; it's no longer supported from PyPi installed packages, so if things were only available from a (public) repo they'd have to be done manually. (We could provide a cli tool to do this, installed from the package; eg tm129_utils install-extras that runs a pip git+... set of installs.)

I'm not sure if Python package namespaces are also relevant? These let you package separate distributions but under the same namespace. Eg we could have separate packages for different modules but all under the ou or openuni or openuniversity namespace? (So we'd have things like from openuniversity import tm351 etc. and installed via pip install openuni-tm351 or pip install openuni-tm129==2020.10.1 or whatever (is there a restriction or limits on the version numbering convention? Does it have to be numeric? Inside a certain range?)

Identifying what packages can support an effective teaching and learning environment is an act of curation, and as such is somewhere where we can add value. By sharing environments that may be useful to others:

  • we support folk in their own teaching and learning, work and play;
  • we raise awareness of the OU and OU modules, getting a presence on PyPi, maybe using ou and course code identifiers in package names etc;
  • if we ship useful commmand line utilities, they can occasionly print OU advertising messages when run...
  • if we ship a a simple web server, it can include module marketing information, "are you read for..?" activities or even sample module content;
  • if we bundle files in the package, these can be retrieved on the student desktop via a simple CLI command; (can we also get desktop shortcuts onto a desktop some how?)
  • the same package could be used to easily support related OpenLearn content;

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

ou-tm129-py-0.0.5.tar.gz (4.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ou_tm129_py-0.0.5-py3-none-any.whl (4.6 kB view details)

Uploaded Python 3

File details

Details for the file ou-tm129-py-0.0.5.tar.gz.

File metadata

  • Download URL: ou-tm129-py-0.0.5.tar.gz
  • Upload date:
  • Size: 4.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.6

File hashes

Hashes for ou-tm129-py-0.0.5.tar.gz
Algorithm Hash digest
SHA256 045471732296b4ff52ee8429a6700540a588619e33f897ae082eb38b43b2fa90
MD5 fba9b4e89e67c9db641977e9328e028a
BLAKE2b-256 5ccd8c384e2124e6fd3c4651fbc9967febd0f576490cdbdce231ee4c7dbe7317

See more details on using hashes here.

File details

Details for the file ou_tm129_py-0.0.5-py3-none-any.whl.

File metadata

  • Download URL: ou_tm129_py-0.0.5-py3-none-any.whl
  • Upload date:
  • Size: 4.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.6

File hashes

Hashes for ou_tm129_py-0.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 3c33a313acc8b8ec28862b0623293224ac85dc01715defcd8c6ada99f1e152ee
MD5 aa1519a9229d90145b429aa89947ea0a
BLAKE2b-256 f0a2685a771ce082231034a536a5ced1861918b9ab5100cbbbe526d7b89b694d

See more details on using hashes here.

Supported by

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