mirror of
				https://github.com/ets-labs/python-dependency-injector.git
				synced 2025-10-26 13:41:32 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			103 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			103 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| Flask Blueprints + Dependency Injector Example
 | |
| ==============================================
 | |
| 
 | |
| This is a `Flask <https://flask.palletsprojects.com/>`_ Blueprints +
 | |
| `Dependency Injector <https://python-dependency-injector.ets-labs.org/>`_ example application.
 | |
| 
 | |
| The example application helps to search for repositories on the Github.
 | |
| 
 | |
| .. image:: screenshot.png
 | |
| 
 | |
| Run
 | |
| ---
 | |
| 
 | |
| Create virtual environment:
 | |
| 
 | |
| .. code-block:: bash
 | |
| 
 | |
|    virtualenv venv
 | |
|    . venv/bin/activate
 | |
| 
 | |
| Install requirements:
 | |
| 
 | |
| .. code-block:: bash
 | |
| 
 | |
|     pip install -r requirements.txt
 | |
| 
 | |
| To run the application do:
 | |
| 
 | |
| .. code-block:: bash
 | |
| 
 | |
|     export FLASK_APP=githubnavigator.application
 | |
|     export FLASK_ENV=development
 | |
|     flask run
 | |
| 
 | |
| The output should be something like:
 | |
| 
 | |
| .. code-block::
 | |
| 
 | |
|     * Serving Flask app "githubnavigator.application" (lazy loading)
 | |
|     * Environment: development
 | |
|     * Debug mode: on
 | |
|     * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
 | |
|     * Restarting with fsevents reloader
 | |
|     * Debugger is active!
 | |
|     * Debugger PIN: 473-587-859
 | |
| 
 | |
| After that visit http://127.0.0.1:5000/ in your browser.
 | |
| 
 | |
| .. note::
 | |
| 
 | |
|    Github has a rate limit. When the rate limit is exceed you will see an exception
 | |
|    ``github.GithubException.RateLimitExceededException``. For unauthenticated requests, the rate
 | |
|    limit allows for up to 60 requests per hour. To extend the limit to 5000 requests per hour you
 | |
|    need to set personal access token.
 | |
| 
 | |
|    It's easy:
 | |
| 
 | |
|    - Follow this `guide <https://docs.github.com/en/github/authenticating-to-github/creating-a-personal-access-token>`_ to create a token.
 | |
|    - Set a token to the environment variable:
 | |
| 
 | |
|    .. code-block:: bash
 | |
| 
 | |
|       export GITHUB_TOKEN=<your token>
 | |
| 
 | |
|    - Restart the app with ``flask run``
 | |
| 
 | |
|    `Read more on Github rate limit <https://developer.github.com/v3/#rate-limiting>`_
 | |
| 
 | |
| Test
 | |
| ----
 | |
| 
 | |
| This application comes with the unit tests.
 | |
| 
 | |
| To run the tests do:
 | |
| 
 | |
| .. code-block:: bash
 | |
| 
 | |
|    py.test githubnavigator/tests.py --cov=githubnavigator
 | |
| 
 | |
| The output should be something like:
 | |
| 
 | |
| .. code-block::
 | |
| 
 | |
|    platform linux -- Python 3.12.3, pytest-8.3.2, pluggy-1.5.0
 | |
|    plugins: cov-6.0.0, flask-1.3.0
 | |
|    asyncio: mode=Mode.STRICT, default_loop_scope=None
 | |
|    collected 2 items
 | |
| 
 | |
|    githubnavigator/tests.py ..                                     [100%]
 | |
| 
 | |
|    ---------- coverage: platform darwin, python 3.10.0-final-0 ----------
 | |
|    Name                                     Stmts   Miss  Cover
 | |
|    ------------------------------------------------------------
 | |
|    githubnavigator/__init__.py                  0      0   100%
 | |
|    githubnavigator/application.py              13      0   100%
 | |
|    githubnavigator/blueprints/__init__.py       0      0   100%
 | |
|    githubnavigator/blueprints/example.py       12      0   100%
 | |
|    githubnavigator/containers.py                8      0   100%
 | |
|    githubnavigator/services.py                 14      0   100%
 | |
|    githubnavigator/tests.py                    34      0   100%
 | |
|    ------------------------------------------------------------
 | |
|    TOTAL                                       81      0   100%
 |