Setting up a Modularity environment
If you decide to get involved in the Modularity project, sooner or later you'll be adding features or fixing bugs in the software components used to build modules. Every change should be tested locally and also have a testcase for automated testing. But setting up a local environment for Modularity can be challenging as there are a couple of components involved:
- fedpkg You need a special version that understands the module-build parameter. It is possible to circumvent this by sending a specially formatted string to a web URL where rida listens. fedpkg also handles certificates that are used to decide if this user is allowed to build a module.
- pdc pdc or product-definition-center gets fed by fedmsg notices and is a repository and API for storing and querying product metadata
- fedmsg fedmsg needs to be reconfigured to listen to messages from the Fedora staging environment
- rida The so called 'orchestrator' that accepts input from fedpkg, checks permissions, gets a list of build time dependencies, sets up a buildroot in koji and submits a build in koji.
- ridad ridad is part of the orchestrator and listens to messages on the fedmsg bus and acts on them
- koji koji creates buildroots and builds packages and modules in them. Setting up koji is not part of this exercise as you would need to download all binary and source packages of a given distribution and import them into a local koji. Instead of doing this, we'll use Fedora's staging koji environment, koji.stg.fedoraproject.org. Unfortunately this means at the moment that only certain users with admin privileges can build modules. Work is under way to fix this issue.
PDC
product-definition-center in a development environment needs to be configured to bypass all authentications. This can be done by adding a file pdc/settings_local.py
in the git checkout directory of pdc with the following content:
import os.path BASE_DIR = os.path.dirname(os.path.dirname(__file__)) DEBUG = True DEBUG_USER = 'superuser' DISABLE_RESOURCE_PERMISSION_CHECK = True DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), # 'USER': '', # 'PASSWORD': '', # 'HOST': '', # 'PORT': '', } } REST_API_URL = 'rest_api/' REST_API_VERSION = 'v1' BROWSABLE_DOCUMENT_MACROS = { 'HOST_NAME': 'http://localhost:8000', 'API_PATH': '%s%s' % (REST_API_URL, REST_API_VERSION), } def get_setting(setting): import settings return getattr(settings, setting) ADMINS = (('PDC Dev', 'pdc@example.com'),) EMAIL_HOST = 'smtp.example.com' SERVER_EMAIL = 'noreply@example.com' EMAIL_SUBJECT_PREFIX = '[PDC]' del get_setting('REST_FRAMEWORK')['DEFAULT_PERMISSION_CLASSES']"
Note the DEBUG_USER line, this user needs to be created after initializing the pdc database with
python manage.py migrate
with
python manage.py createsuperuser
(follow the instructions and enter 'superuser' as name and a password and emailaddress
fedmsg
the modularity devel environent requires that fedmsg listens to messages coming from the fedora staging
environment. Change /etc/fedmsg.d/endpoints.py
so that the
fedora-infrastructure endpoint points at tcp://stg.fedoraproject.org:9940 :
config = dict( endpoints={ "fedora-infrastructure": [ #"tcp://hub.fedoraproject.org:9940", "tcp://stg.fedoraproject.org:9940", ], }, )
For debugging it is also useful to change all fedmsg debugging levels in /etc/fedmsg.d/logging.py
to 'DEBUG'
fedmsg also needs to relay the incoming messages to the local system. This can
be done by modifying /etc/fedmsg.d/relay.py
so that it looks like this:
config = dict( endpoints={ "relay_outbound": [ "tcp://0.0.0.0:4001", ], }, relay_inbound=[ "tcp://127.0.0.1:2003", ], )
I've also set validate_signatures in /etc/fedmsg.d/ssl.py
to False
, although I'm not sure if that is really required.