Commit Graph

1438 Commits

Author SHA1 Message Date
f884bfa39e SwarmConn: don't access Swarm.manager
Open a local nursery instead.
2020-02-04 21:57:11 +08:00
0548d28568 Fix: StreamReset in the stream handlers
Since we don't catch `Exception` in the stream handlers, catch them in
the stream handlers in the tests.
2020-02-04 20:46:40 +08:00
a7ba59bf9f Add a nursery in Swarm
To avoid using the one in `Service`
2020-02-04 20:45:58 +08:00
b007bb4d07 Use the latest async-service 2020-02-04 17:46:30 +08:00
89338914d3 Add comment for serve_tcp 2020-02-04 17:45:56 +08:00
857bb34f4e Add checkpoints in PubsubNotifee
Since some of the methods in `PubsubNotifee` are doing nothing,
add checkpoints to yield control.
2020-02-04 17:45:37 +08:00
66975ae3f2 Pubsub: change run_task to run_daemon_task 2020-02-04 17:43:39 +08:00
7ae9de9002 Fix handler in net_stream_pair_factory
Change it to async function. It wasn't discovered since we caught all
exceptions raised in stream handlers.
2020-02-04 17:09:26 +08:00
3a91f114ab Swarm: add default_stream_handler
Advantage:
- To avoid `None` checks
- If users forget to register a stream handler for `Swarm`,
with the default stream handler, opened streams aren't removed
until `Swarm` finishes.
2020-02-04 17:05:53 +08:00
3fc60cb312 SwarmConn: iterate streams.copy in _cleanup
To avoid `RuntimeError` if `streams` is changed.
2020-02-04 17:04:28 +08:00
d483982acb SwarmConn: don't catch exceptions in handler 2020-02-04 15:10:49 +08:00
5da102d1c9 Ping protocol: move with statement out of try 2020-02-04 15:09:42 +08:00
113696dce2 TravisCI: use python 3.7 instead of 3.7-dev 2020-02-03 16:04:32 +08:00
22963a3099 Fix trio-typing>=0.3,<0.4
To be consistent with trinity
2020-02-02 18:18:01 +08:00
05d5d045ea Fix pubsub interop: missing unsubscribe_fn 2020-02-02 18:17:22 +08:00
1588be2be9 Change the channel size of peer queue
Back to `0`, to avoid unlimited buffer size.
2020-01-31 17:42:47 +08:00
e57d01f360 PR feedback
- Use f-string
- Fix wrongly indented comments
- Add dep `trio-typing`
2020-01-28 15:48:41 +08:00
095a848f30 Add clean-up logics into TrioSubscriptionAPI
Register an `unsubscribe_fn` when initializing the TrioSubscriptionAPI.
`unsubscribe_fn` is called when subscription is unsubscribed.
2020-01-28 00:29:05 +08:00
c3ba67ea87 Remove locks in PubsubNotifee
- Change `open_memory_channel(0)` to `open_memory_channel(math.inf)`, to
avoid `peer_queue.send` and `dead_peer_queue.send` blocking. This allows
us to remove the locks.
- Only catch `trio.BrokenResourceError`, which is caused by Pubsub when
it's closing.
2020-01-27 14:30:44 +08:00
92ea35e147 Fix IPubsub and add IPubsub.wait_until_ready 2020-01-27 00:10:33 +08:00
e3a1dd62e4 Use new type hinting for trio channel 2020-01-26 23:56:19 +08:00
42bc4d5d06 INetworkService implement ServiceAPI 2020-01-26 23:55:31 +08:00
ddfbf9ffc8 Use raise from to reserve stacktrace 2020-01-26 23:54:29 +08:00
b85bab1a09 Don't catch trio.BusyResourceError 2020-01-26 23:09:56 +08:00
5b4b65faa8 Change default value of read()
From `n = -1` to `n = None`, to comply with trio API
2020-01-26 23:03:38 +08:00
6e01a7da31 PR feedback: async with host.run() 2020-01-26 16:44:42 +08:00
dcc4aa52fc Merge branch 'master' into feature/porting-to-trio 2020-01-19 16:56:40 +08:00
f0c4254bbd Use Service instead of ServiceAPI
To fix error with async-service==0.1.0a5
2020-01-18 00:31:39 +08:00
6c7aa30191 Add events in Pubsub
To ensure `handle_peer_queue` and `handle_dead_peer_queue` are indeed
run before the tests finish. Previously, we get errors when performing
`iter_dag` after cancellation. This is because `handle_peer_queue` or
`handle_dead_peer_queue` is not actually run before the Service is
cancelled.
2020-01-18 00:17:30 +08:00
54871024cc Pin the version of async-service to a4 2020-01-16 18:54:19 +08:00
eef241e70e Make Mplex and SwarmConn not Service
After second thoughts, they seem not a good candidate of `Service`.
The shutdown logic becomes simpler by making them not `Service`.
2020-01-07 21:50:03 +08:00
eab59482c0 Use the real get_unused_tcp_port
To get rid of the fake one
2020-01-07 16:45:59 +08:00
45eeb4fba3 Change notify_xxx to sync functions
Since we already have `Swarm.run_task`, we can just change notify
functions to sync.
2020-01-07 16:45:06 +08:00
4db043a26a Remove pexpect from tox 2020-01-07 16:23:00 +08:00
52f85586b8 Fix docs 2020-01-07 15:41:44 +08:00
fe4354d377 Fix tests_interop
- Remove pexpect
- Use new version of `p2pclient`, which makes use of anyio
- Clean up tests
2020-01-07 14:14:34 +08:00
000e777ac7 Try older async-service 2019-12-26 20:44:58 +08:00
94f0fcb6ad Iterate dead_peer_receive_channel with async for 2019-12-26 20:44:32 +08:00
68c84b273d Use cls over the name of the factory 2019-12-26 20:44:10 +08:00
3c98b1973d Remove useless conftest for pubsub 2019-12-26 20:43:38 +08:00
4d814f0587 Merge pull request #394 from NIC619/fix_closing_a_reset_connection
Fix `close` an already reset connection
2019-12-26 12:13:26 +08:00
3b0386d861 Raise RawConnError 2019-12-24 22:27:16 +08:00
c62f1f374f Check if transport is closing before write/close 2019-12-24 22:23:38 +08:00
a390d21385 Remove RawConnError from exception handling 2019-12-24 21:57:13 +08:00
fb6076c061 Upgrade to 0.1.0a4
Probably it can solve the dag issue:
https://github.com/ethereum/async-service/issues/12
2019-12-24 21:50:42 +08:00
6ae3f5dc1b Add checkpoints in tests 2019-12-24 21:28:37 +08:00
53dbb0aff1 Fix pubsub_notifee.py
For wrong syntax and import
2019-12-24 18:37:59 +08:00
573c049d0f Catch expections in PubsubNotifee
Also, add lock to avoid resource race condition
2019-12-24 18:31:39 +08:00
2287dc95be Fix test for info_from_p2p_addr
It is because I removed some checks in the function. This checks should
be useless thanks to mypy
2019-12-24 18:08:33 +08:00
3372c32432 Fix examples and modify new_node
- Fix examples `chat.py` and `echo.py`
    - Use trio directly, instead of `trio-asyncio`
    - Remove redundant code
- Change entry API `new_node` to `new_host_trio`
2019-12-24 18:03:18 +08:00