locomotivemtl/charcoal-queue
最新稳定版本:0.5.0
Composer 安装命令:
composer require locomotivemtl/charcoal-queue
包简介
Queue, Queue items and Queueable objects for Charcoal
关键字:
README 文档
README
Queue Managers, Queue Items and Queueable objects (through Interface & Trait) for Charcoal.
How to install
composer require locomotivemtl/charcoal-queue`
Dependencies
locomotivemtl/charcoal-corefor theCollectionLoaderlocomotivemtl/charcoal-factoryfor the queue-item factory.
Queueing System
Queue managers loop queue items. Queue items represent actions to be performed (as defined by the process() method).
Queue Manager
The queue manager is available as an abstract class: AbstractQueueManager.
This class implements the QueueManagerInterface.
The processing speed (throttle) can be controlled via the rate property, in items per second.
The batch limit (number of items to process per iteration) can be controlled with the limit property.
The queue can be identified with the queue_id. It can be set with setQueueId().
The queue can be processed with processQueue().
If for any reason the items need to be loaded, it can be done with loadQueueItems().
There are 4 callbacks that can be defined:
setProcessedCallback()setItemCallback()setItemSuccessCallbak()setItemFailureCallback()
There are only 1 abstract method:
queueItemProto()which must returns aQueueItemInterfaceinstance
Queue Items
Queue Items should implement the QueueItemInterface. This can be helped via the QueueItemTrait.
Queue items can be identified with a queue_id. (The same queue_id used by the queue manager).
Items can be processed with process($callback, $successCallback, $failureCallback).
The queue item properties are:
queue_idqueue_item_dataqueued_dateprocessing_dateprocessed_dateprocessed
Queuable Objects
The QueueableInterface defines objects that can be queued. This interface is really simple and only provides:
setQueueId()which can be inherited fromQueueableTraitqueueId()(queue_idgetter) which can be inherited fromQueueableTraitqueue($ts = null)which is abstract and must be written inside class which implement the queueable interface
Development
To install the development environment:
$ composer install --prefer-source
Run tests with
$ composer test
API documentation
- The auto-generated
phpDocumentorAPI documentation is available at https://locomotivemtl.github.io/charcoal-queue/docs/master/ - The auto-generated
apigenAPI documentation is available at https://codedoc.pub/locomotivemtl/charcoal-queue/master/
Development dependencies
phpunit/phpunitsquizlabs/php_codesnifferphp-coveralls/php-coveralls
Continuous Integration
| Service | Badge | Description |
|---|---|---|
| Travis | Runs code sniff check and unit tests. Auto-generates API documentation. | |
| Scrutinizer | Code quality checker. Also validates API documentation quality. | |
| Coveralls | Unit Tests code coverage. | |
| Sensiolabs | Another code quality checker, focused on PHP. |
Coding Style
The Charcoal-Validator module follows the Charcoal coding-style:
- PSR-1
- PSR-2
- PSR-4, autoloading is therefore provided by Composer.
- phpDocumentor comments.
- Read the phpcs.xml file for all the details on code style.
Coding style validation / enforcement can be performed with
composer phpcs. An auto-fixer is also available withcomposer phpcbf.
Authors
- Mathieu Ducharme mat@locomotive.ca
License
Charcoal is licensed under the MIT license. See LICENSE for details.
统计信息
- 总下载量: 14.33k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 2
- 依赖项目数: 1
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2015-09-23