Skip to content

Latest commit

 

History

History
129 lines (83 loc) · 2.61 KB

README.md

File metadata and controls

129 lines (83 loc) · 2.61 KB

Sonny: Importer framework

Build Status

An importing framework, that makes writing of importers easy, and allows to do a lot of snooping and metrics gathering behind the scenes.

It's considered a work in progress, where it's final form is not yet necessarily there, and developers are encouraged to try and improve it's API, and way of doing things.

Getting started

Create a virtual environment, and isntall dependencies via make

mkvirtualenv sonny
make

Usage

To see all jobs defined:

./list.py

Copy conf/local.py-dist to conf/local.py, and make sure the details for the local DB, and Dashboard instance, are correct

To run a job, with FTP/Email/DB access, it's enough to do:

./run.py path.to.importer.package.ImporterClass

To test a job, which mocks most functionality with side effects (eg FTP, DB, etc):

./test.py path.to.importer.package.ImporterClass

In dev/production environment prepend with IMPORT_CONF=<environment>,

where IMPORT_CONF should be the appropriate environment. It defaults to conf.local.

Customising runs

To pass named arguments:

./run.py importer example=value demo=argument list_argument[]=first list_argument[]=second

To pass a boolean:

./run.py importer flag1?=True flag2?=False

To pass facility settings overrides:

./run.py importer importer_arg=value --FacilityName.setting_name=value

Useful CLI facility overrides

To limit the amount of logs:

./test.py importer --InMemoryLogger.log_level='INFO'

To selectively not mock some facilities, eg don't mock saving to/loading from DB:

./test.py importer --MockRegistry.no_mock_classes[]=DbSaver --MockRegistry.mock_classes[]=DbLoader

Or, to selectively mock only some facilities, eg mock only fetching:

./run.py importer --MockRegistry.mock_classes[]=FtpFetcher --MockRegistry.mock_classes[]=LocalFileDeleter

When testing locally, you can use the importer's scripts to setup and tear down the DB:

./run.py importer --TemporaryDB.force_run?=True

Tests

It's enough to do:

./run-tests.sh

which uses nosetests

Dashboard

To use your local dashboard , you can register the jobs available:

./run.py import_jobs.register_jobs_to_dashboard.RegisterJobsToDashboard

Name

From the Django web framework background, this project is named after Sonny Rollins