fix reload smu issue (#41270)

* fix reload smu issue

* review comments
This commit is contained in:
saichint 2018-06-13 20:47:33 -07:00 committed by Trishna Guha
parent 32c191ee9c
commit 79dd206b3e
2 changed files with 118 additions and 14 deletions

View file

@ -37,6 +37,8 @@ notes:
- For patches, the minimum platform version needed is 7.0(3)I2(5)
- For feature rpms, the minimum platform version needed is 7.0(3)I6(1)
- The module manages the entire RPM lifecycle (Add, activate, commit, deactivate, remove)
- For reload patches, this module is NOT idempotent until the patch is
committed.
options:
pkg:
description:
@ -49,7 +51,8 @@ options:
their default values.
default: bootflash
aggregate:
description: List of RPM/patch definitions.
description:
- List of RPM/patch definitions.
state:
description:
- If the state is present, the rpm will be installed,
@ -113,7 +116,7 @@ def config_cmd_operation(module, cmd):
while iteration < 10:
msg = load_config(module, [cmd], True)
if msg:
if 'another install operation is in progress' in msg[0].lower():
if 'another install operation is in progress' in msg[0].lower() or 'failed' in msg[0].lower():
time.sleep(2)
iteration += 1
else:
@ -153,6 +156,25 @@ def activate_operation(module, show_cmd, pkg):
return cmd
def activate_reload(module, pkg, flag):
iteration = 0
if flag:
cmd = 'install activate {0} forced'.format(pkg)
else:
cmd = 'install deactivate {0} forced'.format(pkg)
opts = {'ignore_timeout': True}
while iteration < 10:
msg = load_config(module, [cmd], True, opts)
if msg:
if isinstance(msg[0], int):
if msg[0] == -32603:
return cmd
elif isinstance(msg[0], str):
if 'another install operation is in progress' in msg[0].lower() or 'failed' in msg[0].lower():
time.sleep(2)
iteration += 1
def commit_operation(module, show_cmd, pkg):
cmd = 'install commit {0}'.format(pkg)
config_cmd_operation(module, cmd)
@ -176,6 +198,7 @@ def remove_operation(module, show_cmd, pkg):
def install_remove_rpm(module, full_pkg, file_system, state):
commands = []
reload_patch = False
splitted_pkg = full_pkg.split('.')
pkg = '.'.join(splitted_pkg[0:-1])
@ -184,6 +207,7 @@ def install_remove_rpm(module, full_pkg, file_system, state):
show_active = 'show install active'
show_commit = 'show install committed'
show_patches = 'show install patches'
show_pkg_info = 'show install pkg-info {0}'.format(pkg)
if state == 'present':
inactive_body = execute_show_command(show_inactive, module)
@ -192,14 +216,23 @@ def install_remove_rpm(module, full_pkg, file_system, state):
if pkg not in inactive_body and pkg not in active_body:
commands.append(add_operation(module, show_inactive, file_system, full_pkg, pkg))
patch_type_body = execute_show_command(show_pkg_info, module)
if patch_type_body and 'Patch Type : reload' in patch_type_body:
# This is reload smu/patch rpm
reload_patch = True
if pkg not in active_body:
commands.append(activate_operation(module, show_active, pkg))
if reload_patch:
commands.append(activate_reload(module, pkg, True))
return commands
else:
commands.append(activate_operation(module, show_active, pkg))
commit_body = execute_show_command(show_commit, module)
if pkg not in commit_body:
patch_body = execute_show_command(show_patches, module)
if pkg in patch_body:
# this is an smu
# This is smu/patch rpm
commands.append(commit_operation(module, show_active, pkg))
else:
err = 'Operation "install activate {0} forced" Failed'.format(pkg)
@ -209,13 +242,22 @@ def install_remove_rpm(module, full_pkg, file_system, state):
commit_body = execute_show_command(show_commit, module)
active_body = execute_show_command(show_active, module)
patch_type_body = execute_show_command(show_pkg_info, module)
if patch_type_body and 'Patch Type : reload' in patch_type_body:
# This is reload smu/patch rpm
reload_patch = True
if pkg in commit_body and pkg in active_body:
commands.append(deactivate_operation(module, show_active, pkg, True))
commit_body = execute_show_command(show_commit, module)
if pkg in commit_body:
# This is smu/patch rpm
commands.append(commit_operation(module, show_inactive, pkg))
commands.append(remove_operation(module, show_inactive, pkg))
if reload_patch:
commands.append(activate_reload(module, pkg, False))
return commands
else:
commands.append(deactivate_operation(module, show_active, pkg, True))
commit_body = execute_show_command(show_commit, module)
if pkg in commit_body:
# This is smu/patch rpm
commands.append(commit_operation(module, show_inactive, pkg))
commands.append(remove_operation(module, show_inactive, pkg))
elif pkg in commit_body:
# This is smu/patch rpm
@ -224,8 +266,12 @@ def install_remove_rpm(module, full_pkg, file_system, state):
elif pkg in active_body:
# This is smu/patch rpm
commands.append(deactivate_operation(module, show_inactive, pkg, False))
commands.append(remove_operation(module, show_inactive, pkg))
if reload_patch:
commands.append(activate_reload(module, pkg, False))
return commands
else:
commands.append(deactivate_operation(module, show_inactive, pkg, False))
commands.append(remove_operation(module, show_inactive, pkg))
else:
inactive_body = execute_show_command(show_inactive, module)

View file

@ -22,7 +22,7 @@
- block:
- name: Install smu RPM
nxos_rpm: &tsmurpm
pkg: "nxos.sample-n9k_ALL-1.0.0-7.0.3.I7.3.lib32_n9000.rpm"
pkg: "nxos.sample-n9k_ALL-1.0.0-7.0.3.I6.1.lib32_n9000.rpm"
register: result
- assert: &true1
@ -39,7 +39,7 @@
- name: Remove smu RPM
nxos_rpm: &rsmurpm
pkg: "nxos.sample-n9k_ALL-1.0.0-7.0.3.I7.3.lib32_n9000.rpm"
pkg: "nxos.sample-n9k_ALL-1.0.0-7.0.3.I6.1.lib32_n9000.rpm"
state: absent
register: result
@ -92,4 +92,62 @@
when: sdk_run
- block:
- name: Install reload smu RPM
nxos_rpm: &trsmurpm
pkg: "nxos.CSCve91311-n9k_ALL-1.0.0-7.0.3.I6.1.lib32_n9000.rpm"
register: result
- assert: *true1
- name: Wait for device to come back up
wait_for:
port: 22
state: started
timeout: 600
delay: 60
host: "{{ inventory_hostname_short }}"
- name: Continue with install reload smu RPM
nxos_rpm: *trsmurpm
register: result
- assert: *true1
- name: Check Idempotence
nxos_rpm: *trsmurpm
register: result
- assert: *false1
- name: Remove reload smu RPM
nxos_rpm: &rrsmurpm
pkg: "nxos.CSCve91311-n9k_ALL-1.0.0-7.0.3.I6.1.lib32_n9000.rpm"
state: absent
register: result
- assert: *true1
- name: Wait for device to come back up
wait_for:
port: 22
state: started
timeout: 600
delay: 60
host: "{{ inventory_hostname_short }}"
- name: Continue with remove reload smu RPM
nxos_rpm: *rrsmurpm
register: result
- assert: *true1
- name: Check Idempotence
nxos_rpm: *rrsmurpm
register: result
- assert: *false1
when: smu_run
- debug: msg="END connection={{ ansible_connection }} nxos_rpm sanity test"