2021-06-12 21:58:18 +01:00
|
|
|
{ lib
|
|
|
|
, stdenv
|
|
|
|
, async-timeout
|
|
|
|
, attrs
|
|
|
|
, buildPythonPackage
|
|
|
|
, cryptography
|
|
|
|
, fetchFromGitHub
|
|
|
|
, pytest-aiohttp
|
|
|
|
, pytestCheckHook
|
2020-04-22 07:24:35 +01:00
|
|
|
}:
|
2019-12-21 10:27:31 +00:00
|
|
|
|
|
|
|
buildPythonPackage rec {
|
|
|
|
pname = "snitun";
|
2021-06-12 21:58:18 +01:00
|
|
|
version = "0.27.0";
|
2019-12-21 10:27:31 +00:00
|
|
|
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "NabuCasa";
|
|
|
|
repo = pname;
|
|
|
|
rev = version;
|
2021-06-12 21:58:18 +01:00
|
|
|
sha256 = "sha256-vx9F+Nat69Yadd+YpsnBCstnxCEICFJI14TdG6PvstI=";
|
2019-12-21 10:27:31 +00:00
|
|
|
};
|
|
|
|
|
2021-06-12 21:58:18 +01:00
|
|
|
propagatedBuildInputs = [
|
|
|
|
async-timeout
|
|
|
|
attrs
|
|
|
|
cryptography
|
|
|
|
];
|
2019-12-21 10:27:31 +00:00
|
|
|
|
2021-06-12 21:58:18 +01:00
|
|
|
checkInputs = [
|
|
|
|
pytest-aiohttp
|
|
|
|
pytestCheckHook
|
|
|
|
];
|
2019-12-21 10:27:31 +00:00
|
|
|
|
2020-04-22 07:24:35 +01:00
|
|
|
disabledTests = lib.optionals stdenv.isDarwin [
|
|
|
|
"test_multiplexer_data_channel_abort_full" # https://github.com/NabuCasa/snitun/issues/61
|
|
|
|
# port binding conflicts
|
|
|
|
"test_snitun_single_runner_timeout"
|
|
|
|
"test_snitun_single_runner_throttling"
|
python3Packages.snitun: disable failing test on darwin (#119009)
The upstream advertises this package as "OS independent", but from
issues it is clear they cannot test it on MacOS. So we simply disable
this test.
```
______________________ test_peer_listener_timeout[pyloop] ______________________
raise_timeout = None
peer_manager = <snitun.server.peer_manager.PeerManager object at 0x10a4a6df0>
peer_listener = <snitun.server.listener_peer.PeerListener object at 0x10a4a6a30>
test_client_peer = Client(reader=<StreamReader exception=ConnectionResetError(54, 'Connection reset by peer') transport=<_SelectorSocketT...by peer') transport=<_SelectorSocketTransport closed fd=19>>>, close=<asyncio.locks.Event object at 0x10909ee50 [set]>)
async def test_peer_listener_timeout(
raise_timeout, peer_manager, peer_listener, test_client_peer
):
"""Run a full flow of with a peer."""
valid = datetime.utcnow() + timedelta(days=1)
aes_key = os.urandom(32)
aes_iv = os.urandom(16)
hostname = "localhost"
fernet_token = create_peer_config(valid.timestamp(), hostname, aes_key, aes_iv)
crypto = CryptoTransport(aes_key, aes_iv)
test_client_peer.writer.write(fernet_token)
await test_client_peer.writer.drain()
with pytest.raises(asyncio.IncompleteReadError):
> token = await test_client_peer.reader.readexactly(32)
tests/server/test_listener_peer.py:110:
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
/nix/store/dpa7p7v00xvr26dv2myh3k5p1zkagqsm-python3-3.8.5/lib/python3.8/asyncio/streams.py:723: in readexactly
await self._wait_for_data('readexactly')
/nix/store/dpa7p7v00xvr26dv2myh3k5p1zkagqsm-python3-3.8.5/lib/python3.8/asyncio/streams.py:517: in _wait_for_data
await self._waiter
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
self = <_SelectorSocketTransport closed fd=19>
def _read_ready__data_received(self):
if self._conn_lost:
return
try:
> data = self._sock.recv(self.max_size)
E ConnectionResetError: [Errno 54] Connection reset by peer
```
2021-04-11 07:18:59 +01:00
|
|
|
# ConnectionResetError: [Errno 54] Connection reset by peer
|
|
|
|
"test_peer_listener_timeout"
|
2020-04-22 07:24:35 +01:00
|
|
|
];
|
2019-12-21 10:27:31 +00:00
|
|
|
|
2021-06-12 21:58:18 +01:00
|
|
|
pythonImportsCheck = [ "snitun" ];
|
|
|
|
|
2019-12-21 10:27:31 +00:00
|
|
|
meta = with lib; {
|
|
|
|
homepage = "https://github.com/nabucasa/snitun";
|
|
|
|
description = "SNI proxy with TCP multiplexer";
|
2021-06-12 21:58:18 +01:00
|
|
|
license = licenses.gpl3Only;
|
2019-12-21 10:27:31 +00:00
|
|
|
maintainers = with maintainers; [ Scriptkiddi ];
|
2021-06-12 21:58:18 +01:00
|
|
|
platforms = platforms.linux;
|
2019-12-21 10:27:31 +00:00
|
|
|
};
|
|
|
|
}
|