Skip to content

Commit

Permalink
Merge branch 'main' into pr-4
Browse files Browse the repository at this point in the history
  • Loading branch information
baodrate committed Jan 16, 2022
2 parents a9dd0fb + a9924a6 commit 76fb107
Show file tree
Hide file tree
Showing 7 changed files with 106 additions and 59 deletions.
3 changes: 3 additions & 0 deletions .flake8
Original file line number Diff line number Diff line change
@@ -1,2 +1,5 @@
[flake8]
max-line-length = 99
exclude =
.venv,
.git
4 changes: 2 additions & 2 deletions mypy.ini
Original file line number Diff line number Diff line change
Expand Up @@ -8,5 +8,5 @@ warn_unused_ignores = True
warn_unused_configs = True
warn_unreachable = True

[mypy-twisted.*]
ignore_missing_imports = True
files =
pika-stubs
28 changes: 13 additions & 15 deletions pika-stubs/__init__.pyi
Original file line number Diff line number Diff line change
@@ -1,15 +1,13 @@
from .adapters import ( # noqa: F401
BaseConnection as BaseConnection,
BlockingConnection as BlockingConnection,
SelectConnection as SelectConnection,
)
from .adapters.utils.connection_workflow import ( # noqa: F401
AMQPConnectionWorkflow as AMQPConnectionWorkflow,
)
from .connection import ( # noqa: F401
ConnectionParameters as ConnectionParameters,
SSLOptions as SSLOptions,
URLParameters as URLParameters,
)
from .credentials import PlainCredentials as PlainCredentials # noqa: F401
from .spec import BasicProperties as BasicProperties # noqa: F401
from .connection import ConnectionParameters as ConnectionParameters
from .connection import SSLOptions as SSLOptions
from .connection import URLParameters as URLParameters
from .credentials import PlainCredentials as PlainCredentials
from .spec import BasicProperties as BasicProperties
from .delivery_mode import DeliveryMode as DeliveryMode

from . import adapters
from .adapters import BaseConnection as BaseConnection
from .adapters import BlockingConnection as BlockingConnection
from .adapters import SelectConnection as SelectConnection

from .adapters.utils.connection_workflow import AMQPConnectionWorkflow as AMQPConnectionWorkflow
104 changes: 66 additions & 38 deletions pika-stubs/adapters/twisted_connection.pyi
Original file line number Diff line number Diff line change
@@ -1,47 +1,69 @@
from __future__ import annotations

from typing import Any, Callable, List, Mapping, NamedTuple, Optional, Sequence, Union
from typing import (
Any,
Callable,
List,
Mapping,
NamedTuple,
Optional,
Sequence,
Union,
TypeVar,
Tuple,
)

import twisted.internet.base
import twisted.internet.defer
import twisted.internet.interfaces
import twisted.internet.protocol
import twisted.python.failure
from twisted.internet.defer import Deferred, DeferredQueue

from .. import channel as channel_, connection as connection_, spec
from .. import amqp_object
from .. import frame
from .. import spec
from ..connection import Connection
from ..connection import Parameters
from ..channel import Channel

_T = TypeVar("_T")

class ClosableDeferredQueue(twisted.internet.defer.DeferredQueue): # type: ignore
class ClosableDeferredQueue(DeferredQueue[_T]):

closed: Any = ... # TODO
closed: Union[twisted.python.failure.Failure, Exception] = ...

def __init__(
self,
size: Optional[int] = ...,
backlog: Optional[int] = ...,
) -> None: ...

def put(self, obj: Any) -> None: ...
def get(self) -> twisted.internet.defer.Deferred: ...
def close(self, reason: Union[twisted.python.failure.Failure, Exception]) -> None: ...
def put(self, obj: _T) -> None: ...
def get(self) -> Deferred[_T]: ...
def close(self, reason: Union[twisted.python.failure.Failure, Exception, str]) -> None: ...


# Generic [named] tuples aren't supported (https://github.com/python/mypy/issues/685)
# so we can't provide more specific type hints for `method`
class ReceivedMessage(NamedTuple):

channel: TwistedChannel
method: spec.Basic.Return
method: amqp_object.Method
properties: spec.BasicProperties
body: bytes



class TwistedChannel:

def __init__(self, channel: channel_.Channel) -> None: ...
on_closed: Deferred[Union[twisted.python.failure.Failure, Exception, str]]

def __init__(self, channel: Channel) -> None: ...

@property
def channel_number(self) -> int: ...
@property
def connection(self) -> connection_.Connection: ...
def connection(self) -> Connection: ...

@property
def is_closed(self) -> bool: ...
Expand All @@ -57,28 +79,32 @@ class TwistedChannel:

def callback_deferred(
self,
deferred: twisted.internet.defer.Deferred,
deferred: Deferred[Any],
replies: Sequence[Any],
) -> None: ...

# ReceivedMessage.method: spec.Basic.Return
def add_on_return_callback(self, callback: Callable[[ReceivedMessage], None]) -> None: ...
def basic_ack(self, delivery_tag: int = ..., multiple: bool = ...) -> None: ...
def basic_cancel(self, consumer_tag: str = ...) -> None: ...


# ReceivedMessage.method: spec.Basic.Deliver
def basic_consume(
self,
queue: str,
auto_ack: bool = ...,
exclusive: bool = ...,
consumer_tag: Optional[str] = ...,
arguments: Optional[Mapping[str, Any]] = ...,
) -> twisted.internet.defer.Deferred: ...
) -> Deferred[Tuple[ClosableDeferredQueue[ReceivedMessage], str]]: ...

# ReceivedMessage.method: spec.Basic.GetOk
def basic_get(
self,
queue: str,
auto_ack: bool = ...,
) -> twisted.internet.defer.Deferred: ...
) -> Deferred[ReceivedMessage]: ...

def basic_nack(
self,
Expand All @@ -94,28 +120,30 @@ class TwistedChannel:
body: bytes,
properties: Optional[spec.BasicProperties] = ...,
mandatory: bool = ...,
) -> twisted.internet.defer.Deferred: ...
) -> Deferred[None]: ...

def basic_qos(
self,
prefetch_size: int = ...,
prefetch_count: int = ...,
global_qos: bool = ...,
) -> twisted.internet.defer.Deferred: ...
) -> Deferred[frame.Method[spec.Basic.QosOk]]: ...

def basic_reject(self, delivery_tag: int, requeue: bool = ...) -> None: ...
def basic_recover(self, requeue: bool = ...) -> twisted.internet.defer.Deferred: ...
def basic_recover(
self, requeue: bool = ...
) -> Deferred[frame.Method[spec.Basic.RecoverOk]]: ...

def close(self, reply_code: int = ..., reply_text: str = ...) -> None: ...
def confirm_delivery(self) -> twisted.internet.defer.Deferred: ...
def confirm_delivery(self) -> Deferred[frame.Method[spec.Confirm.SelectOk]]: ...

def exchange_bind(
self,
destination: str,
source: str,
routing_key: str = ...,
arguments: Optional[Mapping[str, Any]] = ...,
) -> twisted.internet.defer.Deferred: ...
) -> Deferred[frame.Method[spec.Exchange.BindOk]]: ...

def exchange_declare(
self,
Expand All @@ -126,23 +154,23 @@ class TwistedChannel:
auto_delete: bool = ...,
internal: bool = ...,
arguments: Optional[Mapping[str, Any]] = ...,
) -> twisted.internet.defer.Deferred: ...
) -> Deferred[frame.Method[spec.Exchange.DeclareOk]]: ...

def exchange_delete(
self,
exchange: Optional[str] = ...,
if_unused: bool = ...,
) -> twisted.internet.defer.Deferred: ...
) -> Deferred[frame.Method[spec.Exchange.DeleteOk]]: ...

def exchange_unbind(
self,
destination: Optional[str] = ...,
source: Optional[str] = ...,
routing_key: str = ...,
arguments: Optional[Mapping[str, Any]] = ...,
) -> twisted.internet.defer.Deferred: ...
) -> Deferred[frame.Method[spec.Exchange.UnbindOk]]: ...

def flow(self, active: bool) -> twisted.internet.defer.Deferred: ...
def flow(self, active: bool) -> Deferred[frame.Method[spec.Channel.FlowOk]]: ...
def open(self) -> None: ...

def queue_bind(
Expand All @@ -151,7 +179,7 @@ class TwistedChannel:
exchange: str,
routing_key: Optional[str] = ...,
arguments: Optional[Mapping[str, Any]] = ...,
) -> twisted.internet.defer.Deferred: ...
) -> Deferred[frame.Method[spec.Queue.BindOk]]: ...

def queue_declare(
self,
Expand All @@ -161,42 +189,42 @@ class TwistedChannel:
exclusive: bool = ...,
auto_delete: bool = ...,
arguments: Optional[Mapping[str, Any]] = ...,
) -> twisted.internet.defer.Deferred: ...
) -> Deferred[frame.Method[spec.Queue.DeclareOk]]: ...

def queue_delete(
self,
queue: str,
if_unused: bool = ...,
if_empty: bool = ...,
) -> twisted.internet.defer.Deferred: ...
) -> Deferred[frame.Method[spec.Queue.DeleteOk]]: ...

def queue_purge(self, queue: str) -> twisted.internet.defer.Deferred: ...
def queue_purge(self, queue: str) -> Deferred[frame.Method[spec.Queue.PurgeOk]]: ...

def queue_unbind(
self,
queue: str,
exchange: Optional[str] = ...,
routing_key: Optional[str] = ...,
arguments: Optional[Mapping[str, Any]] = ...,
) -> twisted.internet.defer.Deferred: ...
) -> Deferred[frame.Method[spec.Queue.UnbindOk]]: ...

def tx_commit(self) -> twisted.internet.defer.Deferred: ...
def tx_rollback(self) -> twisted.internet.defer.Deferred: ...
def tx_select(self) -> twisted.internet.defer.Deferred: ...
def tx_commit(self) -> Deferred[frame.Method[spec.Tx.CommitOk]]: ...
def tx_rollback(self) -> Deferred[frame.Method[spec.Tx.RollbackOk]]: ...
def tx_select(self) -> Deferred[frame.Method[spec.Tx.SelectOk]]: ...


class TwistedProtocolConnection(twisted.internet.protocol.Protocol): # type: ignore
class TwistedProtocolConnection(twisted.internet.protocol.Protocol):

ready: twisted.internet.defer.Deferred = ...
closed: Optional[twisted.internet.defer.Deferred] = ...
ready: Deferred[TwistedProtocolConnection] = ...
closed: Optional[Deferred[Union[twisted.python.failure.Failure, Exception]]] = ...

def __init__(
self,
parameters: Optional[connection_.Parameters] = ...,
parameters: Optional[Parameters] = ...,
custom_reactor: Optional[twisted.internet.base.ReactorBase] = ...,
) -> None: ...

def channel(self, channel_number: Optional[int] = ...) -> twisted.internet.defer.Deferred: ...
def channel(self, channel_number: Optional[int] = ...) -> Deferred[TwistedChannel]: ...

@property
def is_closed(self) -> bool: ...
Expand All @@ -205,7 +233,7 @@ class TwistedProtocolConnection(twisted.internet.protocol.Protocol): # type: ig
self,
reply_code: int = ...,
reply_text: str = ...,
) -> twisted.internet.defer.Deferred: ...
) -> Deferred[Exception]: ...

# IProtocol methods

Expand All @@ -215,4 +243,4 @@ class TwistedProtocolConnection(twisted.internet.protocol.Protocol): # type: ig

# Our own methods

def connectionReady(self) -> None: ...
def connectionReady(self) -> TwistedProtocolConnection: ...
6 changes: 6 additions & 0 deletions pika-stubs/delivery_mode.pyi
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
from enum import Enum


class DeliveryMode(Enum):
Transient: int
Persistent: int
8 changes: 8 additions & 0 deletions pika-stubs/exchange_type.pyi
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
from enum import Enum


class ExchangeType(Enum):
direct: str
fanout: str
headers: str
topic: str
12 changes: 8 additions & 4 deletions setup.cfg
Original file line number Diff line number Diff line change
Expand Up @@ -2,20 +2,21 @@
name = pika-stubs
version = 0.1.3
license = MIT
author = Chi-En Wu
author_email = jason.wu@hahow.in
author = Bao Trinh
author_email = qubidt@gmail.com
description = PEP-484 stubs for Pika
long_description = file:README.md
long_description_content_type = text/markdown
url = https://github.com/hahow/pika-stubs
url = https://github.com/qubidt/pika-stubs
classifiers =
Development Status :: 1 - Planning
Development Status :: 5 - Production/Stable
Intended Audience :: Developers
License :: OSI Approved :: MIT License
Operating System :: OS Independent
Programming Language :: Python :: 3
Topic :: Software Development :: Libraries
Topic :: Software Development :: Libraries :: Python Modules
Typing :: Stubs Only

[options]
packages = pika-stubs
Expand All @@ -27,3 +28,6 @@ install_requires =
dev =
flake8~=3.8.3
mypy~=0.780
tornado
twisted
gevent

0 comments on commit 76fb107

Please sign in to comment.