mhchia
b007bb4d07
Use the latest async-service
2020-02-04 17:46:30 +08:00
mhchia
89338914d3
Add comment for serve_tcp
2020-02-04 17:45:56 +08:00
mhchia
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
mhchia
66975ae3f2
Pubsub: change run_task
to run_daemon_task
2020-02-04 17:43:39 +08:00
mhchia
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
mhchia
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
mhchia
3fc60cb312
SwarmConn: iterate streams.copy
in _cleanup
...
To avoid `RuntimeError` if `streams` is changed.
2020-02-04 17:04:28 +08:00
mhchia
d483982acb
SwarmConn: don't catch exceptions in handler
2020-02-04 15:10:49 +08:00
mhchia
5da102d1c9
Ping protocol: move with
statement out of try
2020-02-04 15:09:42 +08:00
mhchia
113696dce2
TravisCI: use python 3.7
instead of 3.7-dev
2020-02-03 16:04:32 +08:00
mhchia
22963a3099
Fix trio-typing>=0.3,<0.4
...
To be consistent with trinity
2020-02-02 18:18:01 +08:00
mhchia
05d5d045ea
Fix pubsub interop: missing unsubscribe_fn
2020-02-02 18:17:22 +08:00
mhchia
1588be2be9
Change the channel size of peer queue
...
Back to `0`, to avoid unlimited buffer size.
2020-01-31 17:42:47 +08:00
mhchia
e57d01f360
PR feedback
...
- Use f-string
- Fix wrongly indented comments
- Add dep `trio-typing`
2020-01-28 15:48:41 +08:00
mhchia
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
mhchia
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
mhchia
92ea35e147
Fix IPubsub
and add IPubsub.wait_until_ready
2020-01-27 00:10:33 +08:00
mhchia
e3a1dd62e4
Use new type hinting for trio channel
2020-01-26 23:56:19 +08:00
mhchia
42bc4d5d06
INetworkService
implement ServiceAPI
2020-01-26 23:55:31 +08:00
mhchia
ddfbf9ffc8
Use raise from
to reserve stacktrace
2020-01-26 23:54:29 +08:00
mhchia
b85bab1a09
Don't catch trio.BusyResourceError
2020-01-26 23:09:56 +08:00
mhchia
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
mhchia
6e01a7da31
PR feedback: async with host.run()
2020-01-26 16:44:42 +08:00
Kevin Mai-Husan Chia
8e0972f256
Merge pull request #389 from ShadowJonathan/f-string_clean
...
Apply f-string formatting to everything (except logging)
2020-01-20 18:41:20 +08:00
Jonathan de Jong
4c3510f738
Merge branch 'master' into f-string_clean
...
# Conflicts:
# libp2p/network/connection/raw_connection.py
2020-01-20 11:25:37 +01:00
Kevin Mai-Husan Chia
0a2d86a3d0
Merge pull request #392 from ShadowJonathan/lru_lint
...
add lru to known_third_parties (to fix windows lint)
2020-01-20 11:20:12 +08:00
mhchia
dcc4aa52fc
Merge branch 'master' into feature/porting-to-trio
2020-01-19 16:56:40 +08:00
mhchia
f0c4254bbd
Use Service
instead of ServiceAPI
...
To fix error with async-service==0.1.0a5
2020-01-18 00:31:39 +08:00
mhchia
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
mhchia
54871024cc
Pin the version of async-service to a4
2020-01-16 18:54:19 +08:00
mhchia
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
mhchia
eab59482c0
Use the real get_unused_tcp_port
...
To get rid of the fake one
2020-01-07 16:45:59 +08:00
mhchia
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
mhchia
4db043a26a
Remove pexpect from tox
2020-01-07 16:23:00 +08:00
mhchia
52f85586b8
Fix docs
2020-01-07 15:41:44 +08:00
mhchia
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
mhchia
000e777ac7
Try older async-service
2019-12-26 20:44:58 +08:00
mhchia
94f0fcb6ad
Iterate dead_peer_receive_channel
with async for
2019-12-26 20:44:32 +08:00
mhchia
68c84b273d
Use cls
over the name of the factory
2019-12-26 20:44:10 +08:00
mhchia
3c98b1973d
Remove useless conftest for pubsub
2019-12-26 20:43:38 +08:00
NIC Lin
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
NIC619
3b0386d861
Raise RawConnError
2019-12-24 22:27:16 +08:00
NIC619
c62f1f374f
Check if transport is closing before write/close
2019-12-24 22:23:38 +08:00
NIC619
a390d21385
Remove RawConnError
from exception handling
2019-12-24 21:57:13 +08:00
mhchia
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
mhchia
6ae3f5dc1b
Add checkpoints in tests
2019-12-24 21:28:37 +08:00
mhchia
53dbb0aff1
Fix pubsub_notifee.py
...
For wrong syntax and import
2019-12-24 18:37:59 +08:00
mhchia
573c049d0f
Catch expections in PubsubNotifee
...
Also, add lock to avoid resource race condition
2019-12-24 18:31:39 +08:00
mhchia
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
mhchia
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