Mercurial > dropbear
view test/test_svrauth.py @ 1933:e093ddc5b585
Fix extra default -i arguments for multihop
When multihop executes dbclient it should only add -i arguments
from the original commandline, not the default id_dropbear key.
Otherwise multiple -i arguments keep getting added which
results in servers disconnecting with too many auth attempts
author | Matt Johnston <matt@ucc.asn.au> |
---|---|
date | Fri, 01 Apr 2022 11:56:10 +0800 |
parents | 30fd047f6ebf |
children |
line wrap: on
line source
from test_dropbear import * import signal import queue import socket import os from pathlib import Path # Tests for server side authentication # Requires keyfile and authorized_keys set up in github action build.yml @pytest.mark.skipif('DBTEST_IN_ACTION' not in os.environ, reason="DBTEST_IN_ACTION not set") def test_pubkeyinfo(request, dropbear): kf = str(Path.home() / ".ssh/id_dropbear_key2") r = dbclient(request, "-i", kf, "echo -n $SSH_PUBKEYINFO", capture_output=True) # stop at first space assert r.stdout.decode() == "key2" @pytest.mark.skipif('DBTEST_IN_ACTION' not in os.environ, reason="DBTEST_IN_ACTION not set") def test_pubkeyinfo_special(request, dropbear): kf = str(Path.home() / ".ssh/id_dropbear_key3") r = dbclient(request, "-i", kf, "echo -n $SSH_PUBKEYINFO", capture_output=True) # comment contains special characters so the SSH_PUBKEYINFO should not be set assert r.stdout.decode() == "" @pytest.mark.skipif('DBTEST_IN_ACTION' not in os.environ, reason="DBTEST_IN_ACTION not set") def test_pubkeyinfo_okchar(request, dropbear): kf = str(Path.home() / ".ssh/id_dropbear_key4") r = dbclient(request, "-i", kf, "echo -n $SSH_PUBKEYINFO", capture_output=True) # comment contains special characters so the SSH_PUBKEYINFO should not be set assert r.stdout.decode() == "key4,char"