Commit Graph

197 Commits

Author SHA1 Message Date
6d97702da7 Merge pull request #277 from ralexstokes/add-io-abstractions
Introduces IO abstractions and classes for `msgio` IO
2019-09-04 19:11:50 +02:00
1f3c9af45b Add the missing is_proc_running=True 2019-09-04 22:19:11 +08:00
0e3d4508d6 PR feedback
- Use `Sequence` instead of `List`
- Add note
- Remove redundant words in docstring
2019-09-04 20:52:18 +08:00
db0da8083a Do p2pd.close if not all of them succeed 2019-09-04 20:52:17 +08:00
51d547ccc5 Update tests/interop/utils.py
Co-Authored-By: NIC Lin <twedusuck@gmail.com>
2019-09-04 20:38:38 +08:00
b72c489f4e Update tests/interop/daemon.py
Co-Authored-By: NIC Lin <twedusuck@gmail.com>
2019-09-04 20:36:42 +08:00
a843514afb Update tests/interop/daemon.py
Co-Authored-By: NIC Lin <twedusuck@gmail.com>
2019-09-04 20:35:42 +08:00
155f523c9f Update tests/interop/daemon.py
Co-Authored-By: NIC Lin <twedusuck@gmail.com>
2019-09-04 20:33:50 +08:00
bd21b2f66f Update tests/interop/conftest.py
Co-Authored-By: NIC Lin <twedusuck@gmail.com>
2019-09-04 20:33:29 +08:00
dddaacad62 Move install script under tests/interop/go_pkgs 2019-09-04 16:33:25 +08:00
677531db76 Fix pubsub tests 2019-09-04 15:33:07 +08:00
8e8318aa5c Introduces IO abstractions apart from asyncio or those attached to IRawConnection
Also adds `msgio` utilities to mirror the Go implementation
2019-09-03 21:59:50 -07:00
7f20ab781d Fix gosssipsub tests 2019-09-03 23:37:34 +08:00
5280f3965c Update install script for interop
And adjust the structure of go packages for interop
2019-09-03 17:41:17 +08:00
749ff275ed Refactor make_p2pd
Let `make_p2pd` get rid of `unused_tcp_port_factory`, which should only
exist in fixtures/tests.
2019-09-03 16:55:42 +08:00
7385a7a677 Add is_gossipsub fixture in interop test
To use the same code to test against both routers: floodsub and
gossipsub.
2019-09-03 16:49:00 +08:00
33dae87c35 Add pubsub test for gossipsub 2019-09-03 16:07:44 +08:00
194b494057 Tested against subscriptions and publish 2019-09-02 23:21:57 +08:00
3717dc9adf Add helper functions 2019-09-02 21:01:13 +08:00
a883816881 Add connect utility function 2019-09-02 18:40:12 +08:00
56ef0b962c Add test for host connect and disconnect 2019-09-02 17:32:15 +08:00
dfd9ebdc5e Change PeerInfo to remove dep on PeerData 2019-09-02 14:30:27 +08:00
b77834d129 Use asyncio.subprocess over pexpect
In the test for pubsub, since there were unknown issues when I test
against pexpect.
2019-09-02 14:30:27 +08:00
1b5d064a8d Add utility functions for libp2p bindings
To prepare for pubsub interop test
2019-09-02 14:30:25 +08:00
b955c0fa02 Explicitly import ID, Transport from secio 2019-08-31 22:38:46 +08:00
9e8a6bdf29 Update tests/conftest.py
Co-Authored-By: NIC Lin <twedusuck@gmail.com>
2019-08-31 22:32:43 +08:00
cec2aea928 Move shared fixtures and constants to files 2019-08-29 22:38:08 +08:00
9ceb5f55bb Call make_echo_proc with is_host_insecure
Use the fixture, this way we can configure `is_host_insecure` to support
the test against secio.
2019-08-29 22:08:27 +08:00
c61a06706a Refactor interop tests and factories
- Add `close` and `disconnect` in `Host`
- Add `close` and `close_peer` in `Network`
- Change `IListener.close` to async, to await for server's closing
- Add factories for security transports, and modify `HostFactory`
2019-08-29 21:38:06 +08:00
64c0dab3af Fix isort 2019-08-29 00:01:48 +08:00
b726d7c9da Add tox and CI for interop 2019-08-28 23:39:33 +08:00
d35b8ffc64 Conform stream_id to go-mplex 2019-08-28 21:43:34 +08:00
66c3bacf7e Merge pull request #254 from ralexstokes/implement-secio
Implement `secio`
2019-08-26 19:22:00 +02:00
fa0acd9fc5 Apply PR feedback 2019-08-26 10:03:12 -07:00
5e68aff1d1 Fix conn attribute and docstring in mplex 2019-08-25 14:42:44 +08:00
f08aa339b4 Verify the channel can pass some plaintext 2019-08-24 23:26:26 +02:00
737195f461 Simplify testing connection w/ other simplifications 2019-08-24 23:15:31 +02:00
10e30beb42 Disable "friendly" IDs for tests that expect a full string 2019-08-24 22:57:22 +02:00
9355f33da8 Add basic test for secio
Two peers in-memory can create a secure, bidirectional channel
2019-08-24 22:38:26 +02:00
3f4589d497 Get tests working 2019-08-24 22:38:25 +02:00
8e913a3faa Dispatch serialization of keys based on key type
- Add some tests to check high-level roundtrip
2019-08-24 22:37:45 +02:00
7ccdeaf308 Remove test suite for asyncio, *not* py-libp2p 2019-08-24 22:10:47 +02:00
73495038e1 remove simple security 2019-08-24 21:39:25 +02:00
16a4fd33c1 PR feedbacks
- Move exceptions to exceptions.py
- Raise `UpgradeFailure` in upgrader
- Refine the try/catch for upgraders in swarm
2019-08-22 22:53:49 +08:00
3e04480d62 Raise HandshakeFailure in transport
Change the exception handling flow.
Raise `SecurityUpgradeFailure` in security_multistream.
2019-08-22 22:53:48 +08:00
0b62321265 Fix test_security_multistream
By passing initiator keypairs to node.
2019-08-22 22:53:47 +08:00
87d943aa39 Internalize the protobuf serialization to the concept of a Key
Given its use across various components of `libp2p` (not just peer IDs),
it makes the abstraction cleaner to pull the serialization into the
key class and expose the canonical serialization to bytes.
2019-08-20 19:01:36 +02:00
7535a02da7 Clean up key gen 2019-08-15 19:24:30 -07:00
d17e6f3392 Fix some test imports that got botched in rebase 2019-08-15 16:46:23 -07:00
82bae341a7 Run isort over files that were missing it 2019-08-15 16:33:35 -07:00