System-wide, you need git
and pip
installed. You also need tox
(usually just pip install tox
).
You optionally need nose
, coverage
and flake8
(usually just pip install nose coverage flake8
) .
The code for this lives in the main repository, under the folder depends/docker-registry-core.
It provides:
- exceptions
- a driver interface describing how the registry interacts with the data storage
- a compatibility layer (eg: abstracting behavior differences between python versions)
- common useful utility code
- filesystem storage driver
It doesn't depend on anything, and is published as a standalone pip package. Its version closely reflects the driver interface versioning.
If you are going to change the way data is stored, this is where you should look.
If you are going to hack on the registry itself, this is probably not interesting for you.
If you are going to create a new storage driver, see below.
This is what lives in the main repository, and contains the bulk of the server code (including the s3 storage driver).
It depends on docker-registry-core
.
This is likely where you are going to hack if you want to modify the registry behavior.
It is published as a pip package, although the recommended way to use is to use the official docker image.
Storage drivers (like elliptics) are implemented as independent pip packages.
Said packages depend on docker-registry-core
only (save their own dependencies).
We use python namespaces.
docker-registry-core
uses:
docker_registry
docker_registry.core
docker_registry.testing
docker_registry.drivers
docker-registry
uses:
docker-registry
- others
Drivers must stay inside docker_registry.drivers
.
We use nose
, coverage
, hacking
(for flake
), tox
and travis
.
Wherever you are coding (registy, core, or driver), your friends are thus:
- run the tests:
python setup.py nosetests
- check your style:
flake8
- run the tests on all platform:
tox
If any of these three fail, then your PR will get rejected :-)
If the travis build fails, your PR will need to be updated.
Any new code must run with python2.7.
Any new code should better run with python2.6 and python3.4.
Existing code shouldn't regress.
Have a look at the elliptics driver and copy its stucture.
Explore the files.
Pretty much:
- you have to use namespaces
- you have to implement methods from the base.Driver interface
- you have to use the provided test suite
- all the tests must pass
Drivers are expected to receive bytes and to return bytes. Don't try to decode or encode content.