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.6.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.6-py3-none-any.whl (4.6 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: ou-tm129-py-0.0.6.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.6.tar.gz
Algorithm Hash digest
SHA256 7fb2509bbf182e21f315d13697c8a1cf540532037a5e2cbb76058932ed03cbeb
MD5 2c80f7c41c75f007d6c2f33e784de857
BLAKE2b-256 4696abdc03d559ebc3e0f1d6e32f15a71263470f47b0a9897ea548ddb5a87972

See more details on using hashes here.

File details

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

File metadata

  • Download URL: ou_tm129_py-0.0.6-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.6-py3-none-any.whl
Algorithm Hash digest
SHA256 fd97e4f876726a9b00489a87c1b3fa87f320d1b1456eac3b4c2356e11c07e67d
MD5 ed10366adf5ed3ddfa6b32049dffa7a9
BLAKE2b-256 8cda7b452112941b016cb1bc0e6443683aa895091b9511d195041e3ef2c8c6ae

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