mirror of
				https://github.com/ets-labs/python-dependency-injector.git
				synced 2025-10-25 05:01:11 +03:00 
			
		
		
		
	Add draft version of MovieLister example
This commit is contained in:
		
							parent
							
								
									40f7e6ed26
								
							
						
					
					
						commit
						59615bc88b
					
				
							
								
								
									
										33
									
								
								examples/stories/movie_lister/_create_db.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								examples/stories/movie_lister/_create_db.py
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,33 @@ | |||
| """Small script for initializing movies data.""" | ||||
| 
 | ||||
| import os | ||||
| import csv | ||||
| import sqlite3 | ||||
| import shutil | ||||
| 
 | ||||
| from settings import DATA_DIR | ||||
| from settings import MOVIES_CSV_PATH | ||||
| from settings import MOVIES_DB_PATH | ||||
| 
 | ||||
| 
 | ||||
| MOVIES = (('The Hunger Games: Mockingjay - Part 2', 2015, 'Francis Lawrence'), | ||||
|           ('The 33', 2015, 'Patricia Riggen'), | ||||
|           ('Star Wars: Episode VII - The Force Awakens', 2015, 'JJ Abrams')) | ||||
| 
 | ||||
| 
 | ||||
| if __name__ == '__main__': | ||||
|     # (Re)create data directory: | ||||
|     if os.path.exists(DATA_DIR): | ||||
|         shutil.rmtree(DATA_DIR) | ||||
|     os.makedirs(DATA_DIR) | ||||
| 
 | ||||
|     # Initialize sqlite database: | ||||
|     connection = sqlite3.connect(MOVIES_DB_PATH) | ||||
|     with connection: | ||||
|         connection.execute('CREATE TABLE movies ' | ||||
|                            '(name text, year int, director text)') | ||||
|         connection.executemany('INSERT INTO movies VALUES (?,?,?)', MOVIES) | ||||
| 
 | ||||
|     # Initialize csv database: | ||||
|     with open(MOVIES_CSV_PATH, 'w') as csv_file: | ||||
|         csv.writer(csv_file).writerows(MOVIES) | ||||
							
								
								
									
										39
									
								
								examples/stories/movie_lister/app_csv.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								examples/stories/movie_lister/app_csv.py
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,39 @@ | |||
| """A naive example of dependency injection in Python. | ||||
| 
 | ||||
| Example implementation of dependency injection in Python from Martin Fowler's | ||||
| article about dependency injection and inversion of control. | ||||
| 
 | ||||
| http://www.martinfowler.com/articles/injection.html | ||||
| """ | ||||
| 
 | ||||
| from movies.module import MoviesModule | ||||
| from movies.components import CsvMovieFinder | ||||
| 
 | ||||
| from settings import MOVIES_CSV_PATH | ||||
| 
 | ||||
| from dependency_injector import catalogs | ||||
| from dependency_injector import providers | ||||
| 
 | ||||
| 
 | ||||
| @catalogs.override(MoviesModule) | ||||
| class MyMoviesModule(catalogs.DeclarativeCatalog): | ||||
|     """Customized catalog of movie module components.""" | ||||
| 
 | ||||
|     movie_finder = providers.Factory(CsvMovieFinder, | ||||
|                                      csv_file=MOVIES_CSV_PATH, | ||||
|                                      delimeter=',') | ||||
| 
 | ||||
| 
 | ||||
| def main(): | ||||
|     """Main function.""" | ||||
|     movie_lister = MoviesModule.movie_lister() | ||||
| 
 | ||||
|     print movie_lister.movies_directed_by('Francis Lawrence') | ||||
|     print movie_lister.movies_directed_by('Patricia Riggen') | ||||
|     print movie_lister.movies_directed_by('JJ Abrams') | ||||
| 
 | ||||
|     print movie_lister.movies_released_in(2015) | ||||
| 
 | ||||
| 
 | ||||
| if __name__ == '__main__': | ||||
|     main() | ||||
							
								
								
									
										48
									
								
								examples/stories/movie_lister/app_db.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								examples/stories/movie_lister/app_db.py
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,48 @@ | |||
| """A naive example of dependency injection in Python. | ||||
| 
 | ||||
| Example implementation of dependency injection in Python from Martin Fowler's | ||||
| article about dependency injection and inversion of control. | ||||
| 
 | ||||
| http://www.martinfowler.com/articles/injection.html | ||||
| """ | ||||
| 
 | ||||
| import sqlite3 | ||||
| 
 | ||||
| from movies.module import MoviesModule | ||||
| from movies.components import SqliteMovieFinder | ||||
| 
 | ||||
| from settings import MOVIES_DB_PATH | ||||
| 
 | ||||
| from dependency_injector import catalogs | ||||
| from dependency_injector import providers | ||||
| 
 | ||||
| 
 | ||||
| class ApplicationModule(catalogs.DeclarativeCatalog): | ||||
|     """Catalog of application components.""" | ||||
| 
 | ||||
|     database = providers.Singleton(sqlite3.connect, | ||||
|                                    MOVIES_DB_PATH) | ||||
|     """:type: providers.Provider -> components.MovieFinder""" | ||||
| 
 | ||||
| 
 | ||||
| @catalogs.override(MoviesModule) | ||||
| class MyMoviesModule(catalogs.DeclarativeCatalog): | ||||
|     """Customized catalog of movie module components.""" | ||||
| 
 | ||||
|     movie_finder = providers.Factory(SqliteMovieFinder, | ||||
|                                      database=ApplicationModule.database) | ||||
| 
 | ||||
| 
 | ||||
| def main(): | ||||
|     """Main function.""" | ||||
|     movie_lister = MoviesModule.movie_lister() | ||||
| 
 | ||||
|     print movie_lister.movies_directed_by('Francis Lawrence') | ||||
|     print movie_lister.movies_directed_by('Patricia Riggen') | ||||
|     print movie_lister.movies_directed_by('JJ Abrams') | ||||
| 
 | ||||
|     print movie_lister.movies_released_in(2015) | ||||
| 
 | ||||
| 
 | ||||
| if __name__ == '__main__': | ||||
|     main() | ||||
							
								
								
									
										1
									
								
								examples/stories/movie_lister/data/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								examples/stories/movie_lister/data/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1 @@ | |||
| movies.* | ||||
							
								
								
									
										1
									
								
								examples/stories/movie_lister/movies/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								examples/stories/movie_lister/movies/__init__.py
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1 @@ | |||
| """Movies package.""" | ||||
							
								
								
									
										100
									
								
								examples/stories/movie_lister/movies/components.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										100
									
								
								examples/stories/movie_lister/movies/components.py
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,100 @@ | |||
| """Movies package components.""" | ||||
| 
 | ||||
| import csv | ||||
| 
 | ||||
| 
 | ||||
| class MovieLister(object): | ||||
|     """Movie lister.""" | ||||
| 
 | ||||
|     def __init__(self, movie_finder): | ||||
|         """Initializer.""" | ||||
|         self.movie_finder = movie_finder | ||||
| 
 | ||||
|     def movies_directed_by(self, director): | ||||
|         """Return list of movies that were directed by certain person. | ||||
| 
 | ||||
|         :param director: Director's name | ||||
|         :type director: str | ||||
| 
 | ||||
|         :rtype: list[:py:class:`Movie`] | ||||
|         :return: List of movie instances. | ||||
|         """ | ||||
|         return [movie for movie in self.movie_finder.find_all() | ||||
|                 if movie.director == director] | ||||
| 
 | ||||
|     def movies_released_in(self, year): | ||||
|         """Return list of movies that were released in certain year. | ||||
| 
 | ||||
|         :param year: Release year | ||||
|         :type year: int | ||||
| 
 | ||||
|         :rtype: list[:py:class:`Movie`] | ||||
|         :return: List of movie instances. | ||||
|         """ | ||||
|         return [movie for movie in self.movie_finder.find_all() | ||||
|                 if movie.year == year] | ||||
| 
 | ||||
| 
 | ||||
| class MovieFinder(object): | ||||
|     """Movie finder.""" | ||||
| 
 | ||||
|     def find_all(self): | ||||
|         """Return all found movies. | ||||
| 
 | ||||
|         :rtype: list[:py:class:`Movie`] | ||||
|         :return: List of movie instances. | ||||
|         """ | ||||
|         raise NotImplementedError() | ||||
| 
 | ||||
| 
 | ||||
| class CsvMovieFinder(MovieFinder): | ||||
|     """Movie finder that fetches movies info from csv file.""" | ||||
| 
 | ||||
|     def __init__(self, csv_file, delimeter): | ||||
|         """Initializer.""" | ||||
|         self.csv_file = csv_file | ||||
|         self.delimeter = delimeter | ||||
| 
 | ||||
|     def find_all(self): | ||||
|         """Return all found movies. | ||||
| 
 | ||||
|         :rtype: list[:py:class:`Movie`] | ||||
|         :return: List of movie instances. | ||||
|         """ | ||||
|         with open(self.csv_file) as csv_file: | ||||
|             reader = csv.reader(csv_file, delimiter=self.delimeter) | ||||
|             return [Movie(*row) for row in reader] | ||||
| 
 | ||||
| 
 | ||||
| class SqliteMovieFinder(MovieFinder): | ||||
|     """Movie finder that fetches movies info from sqlite database.""" | ||||
| 
 | ||||
|     def __init__(self, database): | ||||
|         """Initializer.""" | ||||
|         self.database = database | ||||
| 
 | ||||
|     def find_all(self): | ||||
|         """Return all found movies. | ||||
| 
 | ||||
|         :rtype: list[:py:class:`Movie`] | ||||
|         :return: List of movie instances. | ||||
|         """ | ||||
|         with self.database: | ||||
|             rows = self.database.execute('SELECT name, year, director ' | ||||
|                                          'FROM movies') | ||||
|             return [Movie(*row) for row in rows] | ||||
| 
 | ||||
| 
 | ||||
| class Movie(object): | ||||
|     """Movie model.""" | ||||
| 
 | ||||
|     def __init__(self, name, year, director): | ||||
|         """Initializer.""" | ||||
|         self.name = str(name) | ||||
|         self.year = int(year) | ||||
|         self.director = str(director) | ||||
| 
 | ||||
|     def __repr__(self): | ||||
|         """Return string representation of movie instance.""" | ||||
|         return 'Movie(name={0}, year={1}, director={2})'.format( | ||||
|             repr(self.name), repr(self.year), repr(self.director)) | ||||
							
								
								
									
										17
									
								
								examples/stories/movie_lister/movies/module.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								examples/stories/movie_lister/movies/module.py
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,17 @@ | |||
| """Movies package dependency injection module.""" | ||||
| 
 | ||||
| from . import components | ||||
| 
 | ||||
| from dependency_injector import catalogs | ||||
| from dependency_injector import providers | ||||
| 
 | ||||
| 
 | ||||
| class MoviesModule(catalogs.DeclarativeCatalog): | ||||
|     """Catalog of movie module components.""" | ||||
| 
 | ||||
|     movie_finder = providers.Factory(components.MovieFinder) | ||||
|     """:type: providers.Provider -> components.MovieFinder""" | ||||
| 
 | ||||
|     movie_lister = providers.Factory(components.MovieLister, | ||||
|                                      movie_finder=movie_finder) | ||||
|     """:type: providers.Provider -> components.MovieLister""" | ||||
							
								
								
									
										14
									
								
								examples/stories/movie_lister/settings.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								examples/stories/movie_lister/settings.py
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,14 @@ | |||
| """Settings module. | ||||
| 
 | ||||
| This module contains application's settings and constants. | ||||
| """ | ||||
| 
 | ||||
| import os | ||||
| 
 | ||||
| 
 | ||||
| DATA_DIR = os.path.abspath(os.path.dirname(__file__) + '/data') | ||||
| 
 | ||||
| MOVIES_CSV_PATH = DATA_DIR + '/movies.csv' | ||||
| MOVIES_CSV_DELIMETER = ',' | ||||
| 
 | ||||
| MOVIES_DB_PATH = DATA_DIR + '/movies.db' | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user