Skip to content

Commit

Permalink
do not force pty for netconf connections; flag to control this for sy…
Browse files Browse the repository at this point in the history
…stem transport
  • Loading branch information
carlmontanari committed Aug 14, 2021
1 parent ac141d4 commit dad399f
Show file tree
Hide file tree
Showing 4 changed files with 12 additions and 12 deletions.
3 changes: 0 additions & 3 deletions scrapli_netconf/transport/plugins/paramiko/transport.py
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,4 @@ def _open_channel(self) -> None:

self.session_channel = self.session.open_session()
self._set_timeout(self._base_transport_args.timeout_transport)
# unlike "normal" paramiko -- we do *not* need to enable the "shell" on the channel...
# we *do* still want it to be a pty though!
self.session_channel.get_pty()
self.session_channel.invoke_subsystem("netconf")
3 changes: 0 additions & 3 deletions scrapli_netconf/transport/plugins/ssh2/transport.py
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,4 @@ def _open_channel(self) -> None:
raise ScrapliConnectionNotOpened

self.session_channel = self.session.open_session()
# unlike "normal" ssh2 -- we do *not* need to enable the "shell" on the channel...
# we *do* still want it to be a pty though!
self.session_channel.pty()
self.session_channel.subsystem("netconf")
16 changes: 11 additions & 5 deletions scrapli_netconf/transport/plugins/system/transport.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,11 +20,17 @@ def __init__(

def _build_open_cmd(self) -> None:
super()._build_open_cmd()
# adding `-tt` forces tty allocation which lets us send a string greater than 1024 chars;
# without this we are basically capped at 1024 chars and scrapli will/the connection will
# die. it *may* be possible to alter ptyprocess vendor'd code to add `stty -icanon` which
# should also have a similar affect, though this seems simpler.
self.open_cmd.extend(["-tt"])

# JunOS devices do not allocate pty on port 830 on some (all?) platforms, users can cause
# system transport to *not* force the pty (forcing pty is *default behavior*) by setting the
# transport arg `netconf_force_pty` to `False`. This defaults to `True` (forcing a pty) as
# that has been the default behavior for a while and seems to work in almost all cases,
# additionally without this -- in pytest (only in pytest for some reason?) output seems to
# come from devices out of order causing all the echo check logic to break... with this pty
# being forced that seems to never occur. Worth digging into more at some point...
if self._base_transport_args.transport_options.get("netconf_force_pty", True) is True:
self.open_cmd.append("-tt")

self.open_cmd.extend(["-s", "netconf"])
self.logger.debug(f"final open_cmd: {self.open_cmd}")

Expand Down
2 changes: 1 addition & 1 deletion tests/functional/driver/test_sync_driver.py
Original file line number Diff line number Diff line change
Expand Up @@ -164,7 +164,7 @@ def test_edit_config_and_discard(sync_conn, test_cases, config_replacer_dict, xm
validate_filter = test_cases[device_type]["edit_config"]["validate_config_filter"]

conn.open()
conn.get_config()

target = "candidate"
response = conn.edit_config(config=config, target=target)
assert isinstance(response, NetconfResponse)
Expand Down

0 comments on commit dad399f

Please sign in to comment.